Commands
Command
Each plugin has a list of commands.
Also see LocalizedCommand
.
Each command has the following properties:
name
- Type:
string
Friendly-name of the command (not necessarily the words used to call it). Should be title-cased.
match
- Type:
string | string[] |
DynamicMatch
The word(s) the user can say to execute this command.
Make sure it's completely lowercase and without any punctuation. Use "#" in the string as an ordinal place holder. Use "*" as a wildcard placeholder. Lastly, a function DynamicMatch
can be used for the most advanced cases
description
- Optional
- Type:
string
Detailed description visible in the options page.
global
- Type:
boolean
- Default:
false
Let the command work on any page (not restricted by the match
of the Plugin).
pageFn
- Optional
- Type:
(transcript: TsData, ...matchOutput: any) => Promise<void>
An async function to run on the page when the command is called. Special matches (*
and #
) will be arguments after the transcript string argument, and will come in the order they are specified in the match property. rawTranscript
is the transcript before trimming, lowercasing, removing hyphens, and other special characters. There will be a number argument if the match string accepts an ordinal (eg. has a #
) in it, or a string argument if the match string accepts a wildcard (eg. has a *
in it).
Optionally resolve the promise when this function is finished to help chaining work. Eg. we can use return await PluginBase.util.sleep(500);
if we know a command will take no longer than 500ms to finish, and to only execute the next command in the chain after that 500ms delay.
Also see fn vs. pageFn
nice
Optional
Type:
NiceCommand
See
NiceCommand
.
fn
- Optional
- Type:
(transcript: TsData, ...matchOutput: any) => Promise<void>
An async function that runs in the Chrome extension context when the command is called. First arg is the transcript that matched, rest of arguments are what's returned from the match command.
Resolve this promise when the command is done executing in order for chaining to work properly (if desired).
Also see fn vs. pageFn.
enterContext
- Optional
- Type:
string
What context to enter if this command matches.
This is a sugar for writing:
fn: () => PluginBase.util.enterContext(...)
See Contexts for details.
normal
- Type:
boolean
- Default:
true
Make false
if you don't wan't this command included in the "Normal" (default) context.
See Contexts for details.
minConfidence
- Optional
- Type:
number
A decimal between 0.0 and 1.0 that specifies the minimum confidence needed for this command to be considered a match.
Useful for lowering sensitivity of specific commands if they are relatively "dangerous" to execute, for example.
See also onlyFinal
.
onlyFinal
- Optional
- Type:
true
- Default:
false
Only execute the command if it's the final transcript (not a partial, interim transcript that comes in as best current guess). Especially useful for commands with wildcards where we don't want to execute prematurely with an early guess.
See also minConfidence
.
delay
- Optional
- Type:
number | number[]
How long to wait for additional input for before executing this command. Overrides delay that is built-in for commands with match strings that end in ordinals or wildcards.
Useful for when you want to allow time for more words to come through.
Use an array with indices that correspond to the different match strings if you should have different delays based on the match string.
Use 0 to override dynamically calculated delay and to execute command immediately on match.
activeDocument
- Type:
boolean
- Default:
false
Whether to execute this command in the focused frame or iFrame. Won't work if the final focus is document.body.
test
- Optional
- Type:
(t: ExecutionContext<CommandTestContext>, say: (s?: string) => Promise<void>, client: WebdriverIO.Browser) => void
AVA integration test for this command.
fn
vs. pageFn
TIP
pageFn
runs in the context of the page so it has access to the DOM, but doesn't have access to Chrome extension APIs like chrome.tabs
. fn
on the other hand runs in the (sandboxed) context of the Chrome extension; it doesn't have access to the page or it's DOM but it does have access to the Chrome extension APIs.
DynamicMatch
- Type:
{description: string, fn: (transcript: string) =>
DynamicMatchFnResp
}
A function and it's description. The function decides whether a command matches based on a transcript input for more dynamic command word possibilities. Returns non-void if the command should execute on the given transcript. The description is used to inform the user what command words match. It's seen in plugins list in the LipSurf options, and in the help.
DynamicMatchFnResp
- Type:
[startMatchIndex: number, endMatchIndex: number, matchOutput?: any[]] | false | undefined
(or aPromise
with the same result type).
The start match index, the end match index and an array of any
type args to pass over to pageFn
as the ...matchOutput: any[]
arguments. Don't include the transcript argument, as it's automatically included (and trimmed depending on the start and end match indices).
When to return false
Return false
or Promise<false>
if there is a partial match. If there is a partial match we will delay other commands that might already want to execute.
For example, imagine there's a command word for reddit and a dynamic match command for reddit message that are both valid on a given page. If the user says reddit message the transcripts will come down the wire something like this:
- red
- read it
- read it mess
- reddit mess
- reddit message
Can you see the problem? Our "reddit" command will execute even though we only want "reddit" message to.
If you don't want the first "reddit" command to match, return false
when there is a partial match for the dynamic reddit command for transcripts that start with "reddit".
LocalizedCommand
See also Command
and LocalizedPlugin
.
name
- Type:
string
The original name of the command to match this localized version with.
match
- Type:
string | string[] |
DynamicMatch
A localized command can match in a way independent from the base (en) command.
description
- Optional
- Type:
string
delay
- Optional
- Type:
number | number[]
Delays for a localized version of a command can be completely different from the base English version.
nice
- Optional
- Type:
string | ((transcript: TsData, ...matchOutput: any[]) => string)
Sometimes we want to adjust the transcript as it is shown on the live transcript. For example if the user says go to are meal time videos we would want to show that as go to r/mealtimevideos.
Returns the complete "live transcript" that should be shown. rawInput
is the transcript (eg. "go to are meal time videos") matchOutput
is an array returned from the match command if DynamicMatch
is used.