mirror of
https://github.com/ZaidElkurdi/AssistantPlus.git
synced 2025-01-22 19:40:51 +00:00
- Passthrough for Activator listeners
- Wildcards for custom replies
This commit is contained in:
parent
a836b59617
commit
c4f0c1f295
@ -23,7 +23,7 @@
|
|||||||
|
|
||||||
BOOL passthrough = false;
|
BOOL passthrough = false;
|
||||||
if (dict[@"passthrough"]) {
|
if (dict[@"passthrough"]) {
|
||||||
enabled = [dict[@"passthrough"] boolValue];
|
passthrough = [dict[@"passthrough"] boolValue];
|
||||||
}
|
}
|
||||||
|
|
||||||
self.name = name;
|
self.name = name;
|
||||||
|
@ -663,6 +663,7 @@
|
|||||||
B86E670C1ACE7A77007C6014 /* Release */,
|
B86E670C1ACE7A77007C6014 /* Release */,
|
||||||
);
|
);
|
||||||
defaultConfigurationIsVisible = 0;
|
defaultConfigurationIsVisible = 0;
|
||||||
|
defaultConfigurationName = Release;
|
||||||
};
|
};
|
||||||
B86E670D1ACE7A77007C6014 /* Build configuration list for PBXNativeTarget "assistantappTests" */ = {
|
B86E670D1ACE7A77007C6014 /* Build configuration list for PBXNativeTarget "assistantappTests" */ = {
|
||||||
isa = XCConfigurationList;
|
isa = XCConfigurationList;
|
||||||
@ -671,6 +672,7 @@
|
|||||||
B86E670F1ACE7A77007C6014 /* Release */,
|
B86E670F1ACE7A77007C6014 /* Release */,
|
||||||
);
|
);
|
||||||
defaultConfigurationIsVisible = 0;
|
defaultConfigurationIsVisible = 0;
|
||||||
|
defaultConfigurationName = Release;
|
||||||
};
|
};
|
||||||
B88C0A591ABF794E00D4D107 /* Build configuration list for PBXProject "AssistantPlusApp" */ = {
|
B88C0A591ABF794E00D4D107 /* Build configuration list for PBXProject "AssistantPlusApp" */ = {
|
||||||
isa = XCConfigurationList;
|
isa = XCConfigurationList;
|
||||||
|
Binary file not shown.
@ -1,7 +1,7 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
<document type="com.apple.InterfaceBuilder3.CocoaTouch.XIB" version="3.0" toolsVersion="6751" systemVersion="14A329f" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" launchScreen="YES" useTraitCollections="YES">
|
<document type="com.apple.InterfaceBuilder3.CocoaTouch.XIB" version="3.0" toolsVersion="6250" systemVersion="14C109" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" launchScreen="YES" useTraitCollections="YES">
|
||||||
<dependencies>
|
<dependencies>
|
||||||
<plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="6736"/>
|
<plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="6244"/>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
<objects>
|
<objects>
|
||||||
<placeholder placeholderIdentifier="IBFilesOwner" id="-1" userLabel="File's Owner"/>
|
<placeholder placeholderIdentifier="IBFilesOwner" id="-1" userLabel="File's Owner"/>
|
||||||
|
@ -35,23 +35,29 @@
|
|||||||
UIView *switchBackground = [[UIView alloc] initWithFrame:CGRectMake(0, 90, self.view.frame.size.width, 50)];
|
UIView *switchBackground = [[UIView alloc] initWithFrame:CGRectMake(0, 90, self.view.frame.size.width, 50)];
|
||||||
switchBackground.backgroundColor = [UIColor whiteColor];
|
switchBackground.backgroundColor = [UIColor whiteColor];
|
||||||
|
|
||||||
UILabel *enabledSwitchLabel = [[UILabel alloc] initWithFrame:CGRectMake(10, 0, 80, 50)];
|
self.enabledSwitch = [[UISwitch alloc] initWithFrame:CGRectMake(85, 9.5, 51, 31)];
|
||||||
enabledSwitchLabel.text = @"Enabled:";
|
|
||||||
|
|
||||||
UILabel *passthroughSwitchLabel = [[UILabel alloc] initWithFrame:CGRectMake(170, 0, 80, 50)];
|
|
||||||
passthroughSwitchLabel.text = @"Pass-Through:";
|
|
||||||
|
|
||||||
self.enabledSwitch = [[UISwitch alloc] initWithFrame:CGRectMake(100, 9.5, 51, 31)];
|
|
||||||
[self.enabledSwitch addTarget:self action:@selector(didToggleSwitch:) forControlEvents:UIControlEventValueChanged];
|
[self.enabledSwitch addTarget:self action:@selector(didToggleSwitch:) forControlEvents:UIControlEventValueChanged];
|
||||||
self.enabledSwitch.on = self.currListener.enabled;
|
self.enabledSwitch.on = self.currListener.enabled;
|
||||||
|
|
||||||
self.passthroughSwitch = [[UISwitch alloc] initWithFrame:CGRectMake(100, 9.5, 51, 31)];
|
|
||||||
|
UILabel *enabledSwitchLabel = [[UILabel alloc] initWithFrame:CGRectMake(10, 0, 80, 50)];
|
||||||
|
enabledSwitchLabel.text = @"Enabled:";
|
||||||
|
|
||||||
|
CGFloat viewWidth = self.view.frame.size.width;
|
||||||
|
|
||||||
|
self.passthroughSwitch = [[UISwitch alloc] initWithFrame:CGRectMake(viewWidth-61, 9.5, 51, 31)];
|
||||||
[self.passthroughSwitch addTarget:self action:@selector(didToggleSwitch:) forControlEvents:UIControlEventValueChanged];
|
[self.passthroughSwitch addTarget:self action:@selector(didToggleSwitch:) forControlEvents:UIControlEventValueChanged];
|
||||||
self.passthroughSwitch.on = self.currListener.willPassthrough;
|
self.passthroughSwitch.on = self.currListener.willPassthrough;
|
||||||
|
|
||||||
|
CGFloat passthroughSwitchXOrigin = self.passthroughSwitch.frame.origin.x;
|
||||||
|
|
||||||
|
UILabel *passthroughSwitchLabel = [[UILabel alloc] initWithFrame:CGRectMake(passthroughSwitchXOrigin-110, 0, 110, 50)];
|
||||||
|
passthroughSwitchLabel.text = @"Passthrough:";
|
||||||
|
|
||||||
[switchBackground addSubview:enabledSwitchLabel];
|
[switchBackground addSubview:enabledSwitchLabel];
|
||||||
[switchBackground addSubview:passthroughSwitchLabel];
|
[switchBackground addSubview:passthroughSwitchLabel];
|
||||||
[switchBackground addSubview:self.enabledSwitch];
|
[switchBackground addSubview:self.enabledSwitch];
|
||||||
|
[switchBackground addSubview:self.passthroughSwitch];
|
||||||
[self.view addSubview:switchBackground];
|
[self.view addSubview:switchBackground];
|
||||||
|
|
||||||
UIView *nameBackground = [[UIView alloc] initWithFrame:CGRectMake(0, 170, self.view.frame.size.width, 50)];
|
UIView *nameBackground = [[UIView alloc] initWithFrame:CGRectMake(0, 170, self.view.frame.size.width, 50)];
|
||||||
@ -77,18 +83,26 @@
|
|||||||
[triggerBackground addSubview:triggerLabel];
|
[triggerBackground addSubview:triggerLabel];
|
||||||
[triggerBackground addSubview:self.triggerField];
|
[triggerBackground addSubview:self.triggerField];
|
||||||
[self.view addSubview:triggerBackground];
|
[self.view addSubview:triggerBackground];
|
||||||
|
|
||||||
|
[[NSNotificationCenter defaultCenter]
|
||||||
|
addObserver:self
|
||||||
|
selector:@selector(saveChangesIfNecessary)
|
||||||
|
name:UIApplicationWillResignActiveNotification
|
||||||
|
object:nil];
|
||||||
}
|
}
|
||||||
|
|
||||||
- (void)viewWillDisappear:(BOOL)animated {
|
- (void)viewWillDisappear:(BOOL)animated {
|
||||||
[super viewWillDisappear:animated];
|
[super viewWillDisappear:animated];
|
||||||
|
[self saveChangesIfNecessary];
|
||||||
|
}
|
||||||
|
|
||||||
|
- (void)saveChangesIfNecessary {
|
||||||
if (self.didChange) {
|
if (self.didChange) {
|
||||||
self.currListener.trigger = self.triggerField.text;
|
self.currListener.trigger = self.triggerField.text;
|
||||||
self.currListener.name = self.nameField.text;
|
self.currListener.name = self.nameField.text;
|
||||||
[self.delegate listenerDidChange:self.currListener];
|
[self.delegate listenerDidChange:self.currListener];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#pragma mark - UI Delegates
|
#pragma mark - UI Delegates
|
||||||
|
|
||||||
- (void)didToggleSwitch:(UISwitch*)theSwitch {
|
- (void)didToggleSwitch:(UISwitch*)theSwitch {
|
||||||
|
@ -10,26 +10,27 @@
|
|||||||
#define kPreferencesPath "/var/mobile/Library/Preferences/com.assistantplus.app.plist"
|
#define kPreferencesPath "/var/mobile/Library/Preferences/com.assistantplus.app.plist"
|
||||||
|
|
||||||
@implementation customReplyCommands {
|
@implementation customReplyCommands {
|
||||||
NSDictionary *phrases;
|
NSMutableArray *phrases;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// @{ trigger : NSRegularExpression
|
||||||
|
// response : NSString }
|
||||||
|
|
||||||
- (void)createPhraseDictionary:(NSDictionary*)repliesDict {
|
- (void)createPhraseDictionary:(NSDictionary*)repliesDict {
|
||||||
NSMutableDictionary *dict = [[NSMutableDictionary alloc] init];
|
phrases = [[NSMutableArray alloc] init];
|
||||||
NSArray *customReplies = repliesDict[@"customReplies"];
|
NSArray *customReplies = repliesDict[@"customReplies"];
|
||||||
if (customReplies) {
|
if (customReplies) {
|
||||||
for (NSDictionary *currReply in customReplies) {
|
for (NSDictionary *currReply in customReplies) {
|
||||||
NSString *currTrigger = currReply[@"trigger"];
|
NSString *currTrigger = currReply[@"trigger"];
|
||||||
NSString *currResponse = currReply[@"response"];
|
NSString *currResponse = currReply[@"response"];
|
||||||
if ([dict objectForKey:[currTrigger lowercaseString]]) {
|
NSRegularExpression *regExpression = [NSRegularExpression regularExpressionWithPattern:currTrigger options:NSRegularExpressionCaseInsensitive error:nil];
|
||||||
NSMutableArray *mutableCmds = [[dict objectForKey:[currTrigger lowercaseString]] mutableCopy];
|
if (currTrigger && regExpression) {
|
||||||
[mutableCmds addObject:currResponse];
|
[phrases addObject:@{@"trigger" : regExpression,
|
||||||
[dict setObject:mutableCmds forKey:[currTrigger lowercaseString]];
|
@"response" : currResponse}];
|
||||||
} else {
|
|
||||||
[dict setObject:@[currResponse] forKey:[currTrigger lowercaseString]];
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
phrases = dict;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
-(BOOL)handleSpeech:(NSString *)text withTokens:(NSSet *)tokens withSession:(id<APSiriSession>)session {
|
-(BOOL)handleSpeech:(NSString *)text withTokens:(NSSet *)tokens withSession:(id<APSiriSession>)session {
|
||||||
@ -40,11 +41,21 @@
|
|||||||
|
|
||||||
text = [[text stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceCharacterSet]] lowercaseString];
|
text = [[text stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceCharacterSet]] lowercaseString];
|
||||||
|
|
||||||
if ([phrases objectForKey:text]) {
|
BOOL didHandle = NO;
|
||||||
NSArray *customReplies = [phrases objectForKey:text];
|
for (NSDictionary *currDict in phrases) {
|
||||||
for (NSString *currReply in customReplies) {
|
NSRegularExpression *regExpression = currDict[@"trigger"];
|
||||||
[session sendTextSnippet:currReply temporary:NO scrollToTop:YES dialogPhase:@"Completion"];
|
if (regExpression) {
|
||||||
|
NSArray *arrayOfAllMatches = [regExpression matchesInString:text options:0 range:NSMakeRange(0, [text length])];
|
||||||
|
for (NSTextCheckingResult *match in arrayOfAllMatches) {
|
||||||
|
if (match.numberOfRanges > 0) {
|
||||||
|
[session sendTextSnippet:currDict[@"response"] temporary:NO scrollToTop:YES dialogPhase:@"Completion"];
|
||||||
|
didHandle = YES;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (didHandle) {
|
||||||
[session sendRequestCompleted];
|
[session sendRequestCompleted];
|
||||||
return YES;
|
return YES;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user