From 00dc1d881be75e3802e1c4b07b08ad66361ad262 Mon Sep 17 00:00:00 2001 From: Laurent Cozic Date: Thu, 10 Jun 2021 11:46:41 +0200 Subject: [PATCH] Desktop: Allow passing arguments to commands in command palette --- packages/app-desktop/plugins/GotoAnything.tsx | 33 +++++++++++++++---- 1 file changed, 27 insertions(+), 6 deletions(-) diff --git a/packages/app-desktop/plugins/GotoAnything.tsx b/packages/app-desktop/plugins/GotoAnything.tsx index c5b0cbf36..45a473d2e 100644 --- a/packages/app-desktop/plugins/GotoAnything.tsx +++ b/packages/app-desktop/plugins/GotoAnything.tsx @@ -47,6 +47,12 @@ interface State { listType: number; showHelp: boolean; resultsInBody: boolean; + commandArgs: string[]; +} + +interface CommandQuery { + name: string; + args: string[]; } class GotoAnything { @@ -87,6 +93,7 @@ class Dialog extends React.PureComponent { listType: BaseModel.TYPE_NOTE, showHelp: false, resultsInBody: false, + commandArgs: [], }; this.styles_ = {}; @@ -250,6 +257,15 @@ class Dialog extends React.PureComponent { return this.markupToHtml_; } + private parseCommandQuery(query: string): CommandQuery { + const fullQuery = query; + const splitted = fullQuery.split(/\s+/); + return { + name: splitted.length ? splitted[0] : '', + args: splitted.slice(1), + }; + } + async updateList() { let resultsInBody = false; @@ -260,13 +276,16 @@ class Dialog extends React.PureComponent { let listType = null; let searchQuery = ''; let keywords = null; + let commandArgs: string[] = []; if (this.state.query.indexOf(':') === 0) { // COMMANDS - const query = this.state.query.substr(1); - listType = BaseModel.TYPE_COMMAND; - keywords = [query]; + const commandQuery = this.parseCommandQuery(this.state.query.substr(1)); - const commandResults = CommandService.instance().searchCommands(query, true); + listType = BaseModel.TYPE_COMMAND; + keywords = [commandQuery.name]; + commandArgs = commandQuery.args; + + const commandResults = CommandService.instance().searchCommands(commandQuery.name, true); results = commandResults.map((result: CommandSearchResult) => { return { @@ -367,6 +386,7 @@ class Dialog extends React.PureComponent { keywords: keywords ? keywords : await this.keywords(searchQuery), selectedItemId: results.length === 0 ? null : results[0].id, resultsInBody: resultsInBody, + commandArgs: commandArgs, }); } } @@ -379,7 +399,7 @@ class Dialog extends React.PureComponent { }); if (item.type === BaseModel.TYPE_COMMAND) { - void CommandService.instance().execute(item.id); + void CommandService.instance().execute(item.id, ...item.commandArgs); void focusEditorIfEditorCommand(item.id, CommandService.instance()); return; } @@ -426,6 +446,7 @@ class Dialog extends React.PureComponent { id: itemId, parent_id: parentId, type: itemType, + commandArgs: this.state.commandArgs, }); } @@ -466,7 +487,7 @@ class Dialog extends React.PureComponent { selectedItem() { const index = this.selectedItemIndex(); if (index < 0) return null; - return this.state.results[index]; + return { ...this.state.results[index], commandArgs: this.state.commandArgs }; } input_onKeyDown(event: any) {