diff --git a/packages/plugin-ext-vscode/src/browser/plugin-vscode-commands-contribution.ts b/packages/plugin-ext-vscode/src/browser/plugin-vscode-commands-contribution.ts index 1d65eec541e55..34a2d180eae14 100644 --- a/packages/plugin-ext-vscode/src/browser/plugin-vscode-commands-contribution.ts +++ b/packages/plugin-ext-vscode/src/browser/plugin-vscode-commands-contribution.ts @@ -30,7 +30,7 @@ import { CommandService } from '@theia/core/lib/common/command'; import TheiaURI from '@theia/core/lib/common/uri'; import { EditorManager } from '@theia/editor/lib/browser'; import { CodeEditorWidget } from '@theia/plugin-ext/lib/main/browser/menus/menus-contribution-handler'; -import { TextDocumentShowOptions } from '@theia/plugin-ext/lib/common/plugin-api-rpc-model'; +import { TextDocumentShowOptions, Location } from '@theia/plugin-ext/lib/common/plugin-api-rpc-model'; import { DocumentsMainImpl } from '@theia/plugin-ext/lib/main/browser/documents-main'; import { createUntitledResource } from '@theia/plugin-ext/lib/main/browser/editor/untitled-resource'; import { toDocumentSymbol } from '@theia/plugin-ext/lib/plugin/type-converters'; @@ -40,6 +40,7 @@ import { WorkspaceService, WorkspaceInput } from '@theia/workspace/lib/browser/w import { DiffService } from '@theia/workspace/lib/browser/diff-service'; import { MonacoEditor } from '@theia/monaco/lib/browser/monaco-editor'; import { inject, injectable } from 'inversify'; +import { Position } from '@theia/plugin-ext/lib/common/plugin-api-rpc'; import URI from 'vscode-uri'; export namespace VscodeCommands { @@ -374,8 +375,36 @@ export class PluginVscodeCommandsContribution implements CommandContribution { }) } ); + // TODO register other `vscode.execute...` commands. // see https://github.com/microsoft/vscode/blob/master/src/vs/workbench/api/common/extHostApiCommands.ts + commands.registerCommand( + { + id: 'vscode.executeReferenceProvider' + }, + { + execute: ((resource: URI, position: Position) => { + const args = { + resource: monaco.Uri.from(resource), + position: position + }; + return commands.executeCommand('_executeReferenceProvider', args); + }) + } + ); + commands.registerCommand( + { + id: 'vscode.executeImplementationProvider' + }, + { + execute: ((resource: URI, position: Position) => { + const args = { + resource: monaco.Uri.from(resource), + position: position + }; + return commands.executeCommand('_executeImplementationProvider', args); + }) + } + ); } - } diff --git a/packages/plugin-ext/src/common/index.ts b/packages/plugin-ext/src/common/index.ts index 70fe4d10aa5f9..9d653b922fe83 100644 --- a/packages/plugin-ext/src/common/index.ts +++ b/packages/plugin-ext/src/common/index.ts @@ -18,4 +18,3 @@ export * from './plugin-protocol'; export * from './plugin-api-rpc'; export * from './plugin-ext-api-contribution'; -export * from './known-commands'; diff --git a/packages/plugin-ext/src/common/plugin-api-rpc.ts b/packages/plugin-ext/src/common/plugin-api-rpc.ts index 1622b83fc3580..b2ed0db29ac5b 100644 --- a/packages/plugin-ext/src/common/plugin-api-rpc.ts +++ b/packages/plugin-ext/src/common/plugin-api-rpc.ts @@ -514,6 +514,8 @@ export interface TreeViewsMain { $unregisterTreeDataProvider(treeViewId: string): void; $refresh(treeViewId: string): void; $reveal(treeViewId: string, treeItemId: string): Promise; + $setMessage(treeViewId: string, message: string): void; + $setTitle(treeViewId: string, title: string): void; } export interface TreeViewsExt { diff --git a/packages/plugin-ext/src/main/browser/view/plugin-view-registry.ts b/packages/plugin-ext/src/main/browser/view/plugin-view-registry.ts index 5b5a8e0c6ef81..f98cabfe6c044 100644 --- a/packages/plugin-ext/src/main/browser/view/plugin-view-registry.ts +++ b/packages/plugin-ext/src/main/browser/view/plugin-view-registry.ts @@ -268,6 +268,19 @@ export class PluginViewRegistry implements FrontendApplicationContribution { } } })); + + toDispose.push(this.commands.registerCommand({ + id: `${view.id}.focus`, + label: `Focus ${view.name} View` + }, { + execute: async () => { + const widget = await this.openView(view.id); + if (widget) { + this.shell.activateWidget(widget.id); + } + } + })); + return toDispose; } diff --git a/packages/plugin-ext/src/main/browser/view/tree-view-widget.tsx b/packages/plugin-ext/src/main/browser/view/tree-view-widget.tsx index 0f38c621d4c04..477a4515dfd44 100644 --- a/packages/plugin-ext/src/main/browser/view/tree-view-widget.tsx +++ b/packages/plugin-ext/src/main/browser/view/tree-view-widget.tsx @@ -372,4 +372,24 @@ export class TreeViewWidget extends TreeWidget { } } } + + protected render(): React.ReactNode { + return React.createElement('div', this.createContainerAttributes(), this.renderTreeInfo(), this.renderTree(this.model)); + } + + private _message: string | undefined; + get message(): string | undefined { + return this._message; + } + + set message(message: string | undefined) { + this._message = message; + this.update(); + } + + protected renderTreeInfo(): React.ReactNode { + if (this._message) { + return
{this._message}
; + } + } } diff --git a/packages/plugin-ext/src/main/browser/view/tree-views-main.ts b/packages/plugin-ext/src/main/browser/view/tree-views-main.ts index 15f3eab001e35..d57b9b22f5334 100644 --- a/packages/plugin-ext/src/main/browser/view/tree-views-main.ts +++ b/packages/plugin-ext/src/main/browser/view/tree-views-main.ts @@ -108,6 +108,28 @@ export class TreeViewsMainImpl implements TreeViewsMain, Disposable { } } + async $setMessage(treeViewId: string, message: string): Promise { + const viewPanel = await this.viewRegistry.getView(treeViewId); + const widget = viewPanel && viewPanel.widgets[0]; + + if (widget instanceof TreeViewWidget) { + widget.message = message; + } else { + console.error(`Widget not found for Tree View ID: ${treeViewId}`); + } + } + + async $setTitle(treeViewId: string, title: string): Promise { + const viewPanel = await this.viewRegistry.getView(treeViewId); + const widget = viewPanel && viewPanel.widgets[0]; + + if (widget instanceof TreeViewWidget) { + widget.message = title; + } else { + console.error(`Widget not found for Tree View ID: ${treeViewId}`); + } + } + protected handleTreeEvents(treeViewId: string, treeViewWidget: TreeViewWidget): void { this.toDispose.push(treeViewWidget.model.onExpansionChanged(event => { this.proxy.$setExpanded(treeViewId, event.id, event.expanded); diff --git a/packages/plugin-ext/src/plugin/command-registry.ts b/packages/plugin-ext/src/plugin/command-registry.ts index b18997e5fc224..c7e8a48c621d0 100644 --- a/packages/plugin-ext/src/plugin/command-registry.ts +++ b/packages/plugin-ext/src/plugin/command-registry.ts @@ -24,7 +24,7 @@ import { CommandRegistryExt, PLUGIN_RPC_CONTEXT as Ext, CommandRegistryMain } fr import { RPCProtocol } from '../common/rpc-protocol'; import { Disposable } from './types-impl'; import { DisposableCollection } from '@theia/core'; -import { KnownCommands } from '../common/known-commands'; +import { KnownCommands } from './known-commands'; // eslint-disable-next-line @typescript-eslint/no-explicit-any export type Handler = (...args: any[]) => T | PromiseLike; @@ -104,8 +104,20 @@ export class CommandRegistryImpl implements CommandRegistryExt { return this.executeLocalCommand(id, ...args); } else if (KnownCommands.mapped(id)) { // Using the KnownCommand exclusions, convert the commands manually - return KnownCommands.map(id, args, (mappedId: string, mappedArgs: any[] | undefined) => - this.proxy.$executeCommand(mappedId, ...mappedArgs)); + return KnownCommands.map(id, args, (mappedId: string, mappedArgs: any[] | undefined, mappedResult: KnownCommands.ConversionFunction) => { + const mr: KnownCommands.ConversionFunction = mappedResult; + return this.proxy.$executeCommand(mappedId, ...mappedArgs).then((result: any) => { + if (!Array.isArray(result) || result === undefined) { + return undefined; + } + if (!mr) { + return result; + } + + return mr(result); + }); + } + ); } else { return this.proxy.$executeCommand(id, ...args); } diff --git a/packages/plugin-ext/src/plugin/known-commands.spec.ts b/packages/plugin-ext/src/plugin/known-commands.spec.ts index fb7d1ffcde44e..f26c10c4a021c 100644 --- a/packages/plugin-ext/src/plugin/known-commands.spec.ts +++ b/packages/plugin-ext/src/plugin/known-commands.spec.ts @@ -15,7 +15,7 @@ ********************************************************************************/ import * as assert from 'assert'; -import { KnownCommands } from '../common/known-commands'; +import { KnownCommands } from './known-commands'; import URI from 'vscode-uri'; import { Position } from './types-impl'; import { fromPosition } from './type-converters'; diff --git a/packages/plugin-ext/src/common/known-commands.ts b/packages/plugin-ext/src/plugin/known-commands.ts similarity index 50% rename from packages/plugin-ext/src/common/known-commands.ts rename to packages/plugin-ext/src/plugin/known-commands.ts index 97bdbcc23f033..fc9851ea2e66e 100644 --- a/packages/plugin-ext/src/common/known-commands.ts +++ b/packages/plugin-ext/src/plugin/known-commands.ts @@ -17,9 +17,9 @@ import { Range as R, Position as P, Location as L } from 'vscode-languageserver-types'; import URI from 'vscode-uri'; import * as theia from '@theia/plugin'; -import { cloneAndChange } from './objects'; -import { Position, Range, Location } from '../plugin/types-impl'; -import { fromPosition, fromRange, fromLocation } from '../plugin/type-converters'; +import { cloneAndChange } from '../common/objects'; +import { Position, Range, Location } from './types-impl'; +import { fromPosition, fromRange, fromLocation, isModelLocation, toLocation } from './type-converters'; // Here is a mapping of VSCode commands to monaco commands with their conversions export namespace KnownCommands { @@ -29,11 +29,12 @@ export namespace KnownCommands { * Would be useful in the case where theia provides some command and you need to provide custom conversions */ // eslint-disable-next-line @typescript-eslint/no-explicit-any - const mappings: { [id: string]: [string, (args: any[] | undefined) => any[] | undefined] } = {}; + const mappings: { [id: string]: [string, (args: any[] | undefined) => any[] | undefined, ((results: any[] | undefined) => any[] | undefined)?] } = {}; mappings['editor.action.showReferences'] = ['textEditor.commands.showReferences', createConversionFunction( (uri: URI) => uri.toString(), fromPositionToP, - toArrayConversion(fromLocationToL))]; + toArrayConversion(fromLocationToL)), + createConversionFunction()]; /** * Mapping of all editor.action commands to their conversion function. @@ -42,221 +43,240 @@ export namespace KnownCommands { */ // eslint-disable-next-line @typescript-eslint/no-explicit-any - const MONACO_CONVERSION_IDENTITY = (args: any[] | undefined) => { + const CONVERT_VSCODE_TO_MONACO = (args: any[] | undefined) => { if (!args) { return args; } const argStack: ConversionFunction[] = []; args.forEach(_ => { // eslint-disable-next-line @typescript-eslint/no-explicit-any - argStack.push((arg: any) => monacoArgsConverter(arg)); + argStack.push((arg: any) => vscodeToMonacoArgsConverter(arg)); }); if (args) { return createConversionFunction(...argStack)(args); } }; - mappings['editor.action.select.all'] = ['editor.action.select.all', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.toggleHighContrast'] = ['editor.action.toggleHighContrast', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.moveCarretLeftAction'] = ['editor.action.moveCarretLeftAction', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.moveCarretRightAction'] = ['editor.action.moveCarretRightAction', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.transposeLetters'] = ['editor.action.transposeLetters', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.clipboardCopyWithSyntaxHighlightingAction'] = ['editor.action.clipboardCopyWithSyntaxHighlightingAction', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.commentLine'] = ['editor.action.commentLine', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.addCommentLine'] = ['editor.action.addCommentLine', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.removeCommentLine'] = ['editor.action.removeCommentLine', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.blockComment'] = ['editor.action.blockComment', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.showContextMenu'] = ['editor.action.showContextMenu', MONACO_CONVERSION_IDENTITY]; - mappings['cursorUndo'] = ['cursorUndo', MONACO_CONVERSION_IDENTITY]; - mappings['editor.unfold'] = ['editor.unfold', MONACO_CONVERSION_IDENTITY]; - mappings['editor.unfoldRecursively'] = ['editor.unfoldRecursively', MONACO_CONVERSION_IDENTITY]; - mappings['editor.fold'] = ['editor.fold', MONACO_CONVERSION_IDENTITY]; - mappings['editor.foldRecursively'] = ['editor.foldRecursively', MONACO_CONVERSION_IDENTITY]; - mappings['editor.foldAll'] = ['editor.foldAll', MONACO_CONVERSION_IDENTITY]; - mappings['editor.unfoldAll'] = ['editor.unfoldAll', MONACO_CONVERSION_IDENTITY]; - mappings['editor.foldAllBlockComments'] = ['editor.foldAllBlockComments', MONACO_CONVERSION_IDENTITY]; - mappings['editor.foldAllMarkerRegions'] = ['editor.foldAllMarkerRegions', MONACO_CONVERSION_IDENTITY]; - mappings['editor.unfoldAllMarkerRegions'] = ['editor.unfoldAllMarkerRegions', MONACO_CONVERSION_IDENTITY]; - mappings['editor.foldLevel1'] = ['editor.foldLevel1', MONACO_CONVERSION_IDENTITY]; - mappings['editor.foldLevel2'] = ['editor.foldLevel2', MONACO_CONVERSION_IDENTITY]; - mappings['editor.foldLevel3'] = ['editor.foldLevel3', MONACO_CONVERSION_IDENTITY]; - mappings['editor.foldLevel4'] = ['editor.foldLevel4', MONACO_CONVERSION_IDENTITY]; - mappings['editor.foldLevel5'] = ['editor.foldLevel5', MONACO_CONVERSION_IDENTITY]; - mappings['editor.foldLevel6'] = ['editor.foldLevel6', MONACO_CONVERSION_IDENTITY]; - mappings['editor.foldLevel7'] = ['editor.foldLevel7', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.fontZoomIn'] = ['editor.action.fontZoomIn', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.fontZoomOut'] = ['editor.action.fontZoomOut', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.fontZoomReset'] = ['editor.action.fontZoomReset', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.formatDocument'] = ['editor.action.formatDocument', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.formatSelection'] = ['editor.action.formatSelection', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.copyLinesUpAction'] = ['editor.action.copyLinesUpAction', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.copyLinesDownAction'] = ['editor.action.copyLinesDownAction', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.moveLinesUpAction'] = ['editor.action.moveLinesUpAction', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.moveLinesDownAction'] = ['editor.action.moveLinesDownAction', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.sortLinesAscending'] = ['editor.action.sortLinesAscending', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.sortLinesDescending'] = ['editor.action.sortLinesDescending', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.trimTrailingWhitespace'] = ['editor.action.trimTrailingWhitespace', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.deleteLines'] = ['editor.action.deleteLines', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.indentLines'] = ['editor.action.indentLines', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.outdentLines'] = ['editor.action.outdentLines', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.insertLineBefore'] = ['editor.action.insertLineBefore', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.insertLineAfter'] = ['editor.action.insertLineAfter', MONACO_CONVERSION_IDENTITY]; - mappings['deleteAllLeft'] = ['deleteAllLeft', MONACO_CONVERSION_IDENTITY]; - mappings['deleteAllRight'] = ['deleteAllRight', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.joinLines'] = ['editor.action.joinLines', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.transpose'] = ['editor.action.transpose', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.transformToUppercase'] = ['editor.action.transformToUppercase', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.transformToLowercase'] = ['editor.action.transformToLowercase', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.transformToTitlecase'] = ['editor.action.transformToTitlecase', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.smartSelect.expand'] = ['editor.action.smartSelect.expand', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.smartSelect.shrink'] = ['editor.action.smartSelect.shrink', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.forceRetokenize'] = ['editor.action.forceRetokenize', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.toggleTabFocusMode'] = ['editor.action.toggleTabFocusMode', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.gotoLine'] = ['editor.action.gotoLine', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.quickOutline'] = ['editor.action.quickOutline', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.inPlaceReplace.up'] = ['editor.action.inPlaceReplace.up', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.inPlaceReplace.down'] = ['editor.action.inPlaceReplace.down', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.diffReview.next'] = ['editor.action.diffReview.next', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.diffReview.prev'] = ['editor.action.diffReview.prev', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.selectToBracket'] = ['editor.action.selectToBracket', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.jumpToBracket'] = ['editor.action.jumpToBracket', MONACO_CONVERSION_IDENTITY]; - mappings['actions.findWithSelection'] = ['actions.findWithSelection', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.nextMatchFindAction'] = ['editor.action.nextMatchFindAction', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.previousMatchFindAction'] = ['editor.action.previousMatchFindAction', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.nextSelectionMatchFindAction'] = ['editor.action.nextSelectionMatchFindAction', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.previousSelectionMatchFindAction'] = ['editor.action.previousSelectionMatchFindAction', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.openLink'] = ['editor.action.openLink', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.quickFix'] = ['editor.action.quickFix', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.refactor'] = ['editor.action.refactor', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.sourceAction'] = ['editor.action.sourceAction', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.organizeImports'] = ['editor.action.organizeImports', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.autoFix'] = ['editor.action.autoFix', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.fixAll'] = ['editor.action.fixAll', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.rename'] = ['editor.action.rename', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.insertCursorAbove'] = ['editor.action.insertCursorAbove', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.insertCursorBelow'] = ['editor.action.insertCursorBelow', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.insertCursorAtEndOfEachLineSelected'] = ['editor.action.insertCursorAtEndOfEachLineSelected', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.addSelectionToNextFindMatch'] = ['editor.action.addSelectionToNextFindMatch', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.addSelectionToPreviousFindMatch'] = ['editor.action.addSelectionToPreviousFindMatch', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.moveSelectionToNextFindMatch'] = ['editor.action.moveSelectionToNextFindMatch', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.moveSelectionToPreviousFindMatch'] = ['editor.action.moveSelectionToPreviousFindMatch', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.selectHighlights'] = ['editor.action.selectHighlights', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.changeAll'] = ['editor.action.changeAll', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.addCursorsToBottom'] = ['editor.action.addCursorsToBottom', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.addCursorsToTop'] = ['editor.action.addCursorsToTop', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.triggerParameterHints'] = ['editor.action.triggerParameterHints', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.wordHighlight.next'] = ['editor.action.wordHighlight.next', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.wordHighlight.prev'] = ['editor.action.wordHighlight.prev', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.wordHighlight.trigger'] = ['editor.action.wordHighlight.trigger', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.showAccessibilityHelp'] = ['editor.action.showAccessibilityHelp', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.inspectTokens'] = ['editor.action.inspectTokens', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.marker.next'] = ['editor.action.marker.next', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.marker.prev'] = ['editor.action.marker.prev', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.marker.nextInFiles'] = ['editor.action.marker.nextInFiles', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.marker.prevInFiles'] = ['editor.action.marker.prevInFiles', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.showHover'] = ['editor.action.showHover', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.revealDefinition'] = ['editor.action.revealDefinition', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.revealDefinitionAside'] = ['editor.action.revealDefinitionAside', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.peekDefinition'] = ['editor.action.peekDefinition', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.revealDeclaration'] = ['editor.action.revealDeclaration', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.peekDeclaration'] = ['editor.action.peekDeclaration', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.goToImplementation'] = ['editor.action.goToImplementation', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.peekImplementation'] = ['editor.action.peekImplementation', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.goToTypeDefinition'] = ['editor.action.goToTypeDefinition', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.peekTypeDefinition'] = ['editor.action.peekTypeDefinition', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.referenceSearch.trigger'] = ['editor.action.referenceSearch.trigger', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.triggerSuggest'] = ['editor.action.triggerSuggest', MONACO_CONVERSION_IDENTITY]; - mappings['closeReferenceSearchEditor'] = ['closeReferenceSearchEditor', MONACO_CONVERSION_IDENTITY]; - mappings['cancelSelection'] = ['cancelSelection', MONACO_CONVERSION_IDENTITY]; - mappings['cursorBottom'] = ['cursorBottom', MONACO_CONVERSION_IDENTITY]; - mappings['cursorBottomSelect'] = ['cursorBottomSelect', MONACO_CONVERSION_IDENTITY]; - mappings['cursorDown'] = ['cursorDown', MONACO_CONVERSION_IDENTITY]; - mappings['cursorDownSelect'] = ['cursorDownSelect', MONACO_CONVERSION_IDENTITY]; - mappings['cursorEnd'] = ['cursorEnd', MONACO_CONVERSION_IDENTITY]; - mappings['cursorEndSelect'] = ['cursorEndSelect', MONACO_CONVERSION_IDENTITY]; - mappings['cursorHome'] = ['cursorHome', MONACO_CONVERSION_IDENTITY]; - mappings['cursorHomeSelect'] = ['cursorHomeSelect', MONACO_CONVERSION_IDENTITY]; - mappings['cursorLeft'] = ['cursorLeft', MONACO_CONVERSION_IDENTITY]; - mappings['cursorLeftSelect'] = ['cursorLeftSelect', MONACO_CONVERSION_IDENTITY]; - mappings['cursorPageDown'] = ['cursorPageDown', MONACO_CONVERSION_IDENTITY]; - mappings['cursorPageDownSelect'] = ['cursorPageDownSelect', MONACO_CONVERSION_IDENTITY]; - mappings['cursorPageUp'] = ['cursorPageUp', MONACO_CONVERSION_IDENTITY]; - mappings['cursorPageUpSelect'] = ['cursorPageUpSelect', MONACO_CONVERSION_IDENTITY]; - mappings['cursorRight'] = ['cursorRight', MONACO_CONVERSION_IDENTITY]; - mappings['cursorRightSelect'] = ['cursorRightSelect', MONACO_CONVERSION_IDENTITY]; - mappings['cursorTop'] = ['cursorTop', MONACO_CONVERSION_IDENTITY]; - mappings['cursorTopSelect'] = ['cursorTopSelect', MONACO_CONVERSION_IDENTITY]; - mappings['cursorUp'] = ['cursorUp', MONACO_CONVERSION_IDENTITY]; - mappings['cursorUpSelect'] = ['cursorUpSelect', MONACO_CONVERSION_IDENTITY]; - mappings['deleteLeft'] = ['deleteLeft', MONACO_CONVERSION_IDENTITY]; - mappings['deleteRight'] = ['deleteRight', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.selectAll'] = ['editor.action.selectAll', MONACO_CONVERSION_IDENTITY]; - mappings['expandLineSelection'] = ['expandLineSelection', MONACO_CONVERSION_IDENTITY]; - mappings['outdent'] = ['outdent', MONACO_CONVERSION_IDENTITY]; - mappings['scrollLineDown'] = ['scrollLineDown', MONACO_CONVERSION_IDENTITY]; - mappings['scrollLineUp'] = ['scrollLineUp', MONACO_CONVERSION_IDENTITY]; - mappings['scrollPageDown'] = ['scrollPageDown', MONACO_CONVERSION_IDENTITY]; - mappings['scrollPageUp'] = ['scrollPageUp', MONACO_CONVERSION_IDENTITY]; - mappings['tab'] = ['tab', MONACO_CONVERSION_IDENTITY]; - mappings['removeSecondaryCursors'] = ['removeSecondaryCursors', MONACO_CONVERSION_IDENTITY]; - mappings['cursorWordRight'] = ['cursorWordEndRight', MONACO_CONVERSION_IDENTITY]; - mappings['cursorWordEndRight'] = ['cursorWordEndRight', MONACO_CONVERSION_IDENTITY]; - mappings['cursorWordEndRightSelect'] = ['cursorWordEndRightSelect', MONACO_CONVERSION_IDENTITY]; - mappings['cursorWordLeft'] = ['cursorWordStartLeft', MONACO_CONVERSION_IDENTITY]; - mappings['cursorWordStartLeft'] = ['cursorWordStartLeft', MONACO_CONVERSION_IDENTITY]; - mappings['cursorWordStartLeftSelect'] = ['cursorWordStartLeftSelect', MONACO_CONVERSION_IDENTITY]; - mappings['deleteWordLeft'] = ['deleteWordLeft', MONACO_CONVERSION_IDENTITY]; - mappings['deleteWordRight'] = ['deleteWordRight', MONACO_CONVERSION_IDENTITY]; - mappings['editor.cancelOperation'] = ['editor.cancelOperation', MONACO_CONVERSION_IDENTITY]; - mappings['editor.gotoNextSymbolFromResult'] = ['editor.gotoNextSymbolFromResult', MONACO_CONVERSION_IDENTITY]; - mappings['editor.gotoNextSymbolFromResult.cancel'] = ['editor.gotoNextSymbolFromResult.cancel', MONACO_CONVERSION_IDENTITY]; - mappings['openReferenceToSide'] = ['openReferenceToSide', MONACO_CONVERSION_IDENTITY]; - mappings['toggleExplainMode'] = ['toggleExplainMode', MONACO_CONVERSION_IDENTITY]; - mappings['closeFindWidget'] = ['closeFindWidget', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.replaceAll'] = ['editor.action.replaceAll', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.replaceOne'] = ['editor.action.replaceOne', MONACO_CONVERSION_IDENTITY]; - mappings['editor.action.selectAllMatches'] = ['editor.action.selectAllMatches', MONACO_CONVERSION_IDENTITY]; - mappings['toggleFindCaseSensitive'] = ['toggleFindCaseSensitive', MONACO_CONVERSION_IDENTITY]; - mappings['toggleFindInSelection'] = ['toggleFindInSelection', MONACO_CONVERSION_IDENTITY]; - mappings['toggleFindRegex'] = ['toggleFindRegex', MONACO_CONVERSION_IDENTITY]; - mappings['toggleFindWholeWord'] = ['toggleFindWholeWord', MONACO_CONVERSION_IDENTITY]; - mappings['jumpToNextSnippetPlaceholder'] = ['jumpToNextSnippetPlaceholder', MONACO_CONVERSION_IDENTITY]; - mappings['jumpToPrevSnippetPlaceholder'] = ['jumpToPrevSnippetPlaceholder', MONACO_CONVERSION_IDENTITY]; - mappings['leaveEditorMessage'] = ['leaveEditorMessage', MONACO_CONVERSION_IDENTITY]; - mappings['leaveSnippet'] = ['leaveSnippet', MONACO_CONVERSION_IDENTITY]; - mappings['closeMarkersNavigation'] = ['closeMarkersNavigation', MONACO_CONVERSION_IDENTITY]; - mappings['goToNextReferenceFromEmbeddedEditor'] = ['goToNextReferenceFromEmbeddedEditor', MONACO_CONVERSION_IDENTITY]; - mappings['goToPreviousReferenceFromEmbeddedEditor'] = ['goToPreviousReferenceFromEmbeddedEditor', MONACO_CONVERSION_IDENTITY]; - mappings['closeParameterHints'] = ['closeParameterHints', MONACO_CONVERSION_IDENTITY]; - mappings['showNextParameterHint'] = ['showNextParameterHint', MONACO_CONVERSION_IDENTITY]; - mappings['showPrevParameterHint'] = ['showPrevParameterHint', MONACO_CONVERSION_IDENTITY]; - mappings['acceptSelectedSuggestion'] = ['acceptSelectedSuggestion', MONACO_CONVERSION_IDENTITY]; - mappings['acceptSelectedSuggestionOnEnter'] = ['acceptSelectedSuggestionOnEnter', MONACO_CONVERSION_IDENTITY]; - mappings['hideSuggestWidget'] = ['hideSuggestWidget', MONACO_CONVERSION_IDENTITY]; - mappings['insertBestCompletion'] = ['insertBestCompletion', MONACO_CONVERSION_IDENTITY]; - mappings['insertNextSuggestion'] = ['insertNextSuggestion', MONACO_CONVERSION_IDENTITY]; - mappings['insertPrevSuggestion'] = ['insertPrevSuggestion', MONACO_CONVERSION_IDENTITY]; - mappings['selectNextPageSuggestion'] = ['selectNextPageSuggestion', MONACO_CONVERSION_IDENTITY]; - mappings['selectNextSuggestion'] = ['selectNextSuggestion', MONACO_CONVERSION_IDENTITY]; - mappings['selectPrevPageSuggestion'] = ['selectPrevPageSuggestion', MONACO_CONVERSION_IDENTITY]; - mappings['selectPrevSuggestion'] = ['selectPrevSuggestion', MONACO_CONVERSION_IDENTITY]; - mappings['toggleSuggestionDetails'] = ['toggleSuggestionDetails', MONACO_CONVERSION_IDENTITY]; - mappings['toggleSuggestionFocus'] = ['toggleSuggestionFocus', MONACO_CONVERSION_IDENTITY]; - mappings['acceptRenameInput'] = ['acceptRenameInput', MONACO_CONVERSION_IDENTITY]; - mappings['cancelRenameInput'] = ['cancelRenameInput', MONACO_CONVERSION_IDENTITY]; - mappings['closeAccessibilityHelp'] = ['closeAccessibilityHelp', MONACO_CONVERSION_IDENTITY]; - mappings['history.showNext'] = ['history.showNext', MONACO_CONVERSION_IDENTITY]; - mappings['history.showPrevious'] = ['history.showPrevious', MONACO_CONVERSION_IDENTITY]; - mappings['closeReferenceSearch'] = ['closeReferenceSearch', MONACO_CONVERSION_IDENTITY]; - mappings['goToNextReference'] = ['goToNextReference', MONACO_CONVERSION_IDENTITY]; - mappings['goToPreviousReference'] = ['goToPreviousReference', MONACO_CONVERSION_IDENTITY]; + mappings['editor.action.select.all'] = ['editor.action.select.all', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.toggleHighContrast'] = ['editor.action.toggleHighContrast', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.moveCarretLeftAction'] = ['editor.action.moveCarretLeftAction', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.moveCarretRightAction'] = ['editor.action.moveCarretRightAction', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.transposeLetters'] = ['editor.action.transposeLetters', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.clipboardCopyWithSyntaxHighlightingAction'] = ['editor.action.clipboardCopyWithSyntaxHighlightingAction', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.commentLine'] = ['editor.action.commentLine', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.addCommentLine'] = ['editor.action.addCommentLine', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.removeCommentLine'] = ['editor.action.removeCommentLine', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.blockComment'] = ['editor.action.blockComment', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.showContextMenu'] = ['editor.action.showContextMenu', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorUndo'] = ['cursorUndo', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.unfold'] = ['editor.unfold', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.unfoldRecursively'] = ['editor.unfoldRecursively', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.fold'] = ['editor.fold', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.foldRecursively'] = ['editor.foldRecursively', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.foldAll'] = ['editor.foldAll', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.unfoldAll'] = ['editor.unfoldAll', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.foldAllBlockComments'] = ['editor.foldAllBlockComments', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.foldAllMarkerRegions'] = ['editor.foldAllMarkerRegions', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.unfoldAllMarkerRegions'] = ['editor.unfoldAllMarkerRegions', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.foldLevel1'] = ['editor.foldLevel1', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.foldLevel2'] = ['editor.foldLevel2', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.foldLevel3'] = ['editor.foldLevel3', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.foldLevel4'] = ['editor.foldLevel4', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.foldLevel5'] = ['editor.foldLevel5', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.foldLevel6'] = ['editor.foldLevel6', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.foldLevel7'] = ['editor.foldLevel7', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.fontZoomIn'] = ['editor.action.fontZoomIn', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.fontZoomOut'] = ['editor.action.fontZoomOut', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.fontZoomReset'] = ['editor.action.fontZoomReset', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.formatDocument'] = ['editor.action.formatDocument', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.formatSelection'] = ['editor.action.formatSelection', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.copyLinesUpAction'] = ['editor.action.copyLinesUpAction', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.copyLinesDownAction'] = ['editor.action.copyLinesDownAction', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.moveLinesUpAction'] = ['editor.action.moveLinesUpAction', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.moveLinesDownAction'] = ['editor.action.moveLinesDownAction', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.sortLinesAscending'] = ['editor.action.sortLinesAscending', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.sortLinesDescending'] = ['editor.action.sortLinesDescending', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.trimTrailingWhitespace'] = ['editor.action.trimTrailingWhitespace', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.deleteLines'] = ['editor.action.deleteLines', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.indentLines'] = ['editor.action.indentLines', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.outdentLines'] = ['editor.action.outdentLines', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.insertLineBefore'] = ['editor.action.insertLineBefore', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.insertLineAfter'] = ['editor.action.insertLineAfter', CONVERT_VSCODE_TO_MONACO]; + mappings['deleteAllLeft'] = ['deleteAllLeft', CONVERT_VSCODE_TO_MONACO]; + mappings['deleteAllRight'] = ['deleteAllRight', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.joinLines'] = ['editor.action.joinLines', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.transpose'] = ['editor.action.transpose', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.transformToUppercase'] = ['editor.action.transformToUppercase', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.transformToLowercase'] = ['editor.action.transformToLowercase', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.transformToTitlecase'] = ['editor.action.transformToTitlecase', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.smartSelect.expand'] = ['editor.action.smartSelect.expand', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.smartSelect.shrink'] = ['editor.action.smartSelect.shrink', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.forceRetokenize'] = ['editor.action.forceRetokenize', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.toggleTabFocusMode'] = ['editor.action.toggleTabFocusMode', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.gotoLine'] = ['editor.action.gotoLine', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.quickOutline'] = ['editor.action.quickOutline', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.inPlaceReplace.up'] = ['editor.action.inPlaceReplace.up', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.inPlaceReplace.down'] = ['editor.action.inPlaceReplace.down', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.diffReview.next'] = ['editor.action.diffReview.next', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.diffReview.prev'] = ['editor.action.diffReview.prev', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.selectToBracket'] = ['editor.action.selectToBracket', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.jumpToBracket'] = ['editor.action.jumpToBracket', CONVERT_VSCODE_TO_MONACO]; + mappings['actions.findWithSelection'] = ['actions.findWithSelection', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.nextMatchFindAction'] = ['editor.action.nextMatchFindAction', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.previousMatchFindAction'] = ['editor.action.previousMatchFindAction', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.nextSelectionMatchFindAction'] = ['editor.action.nextSelectionMatchFindAction', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.previousSelectionMatchFindAction'] = ['editor.action.previousSelectionMatchFindAction', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.openLink'] = ['editor.action.openLink', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.quickFix'] = ['editor.action.quickFix', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.refactor'] = ['editor.action.refactor', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.sourceAction'] = ['editor.action.sourceAction', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.organizeImports'] = ['editor.action.organizeImports', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.autoFix'] = ['editor.action.autoFix', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.fixAll'] = ['editor.action.fixAll', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.rename'] = ['editor.action.rename', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.insertCursorAbove'] = ['editor.action.insertCursorAbove', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.insertCursorBelow'] = ['editor.action.insertCursorBelow', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.insertCursorAtEndOfEachLineSelected'] = ['editor.action.insertCursorAtEndOfEachLineSelected', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.addSelectionToNextFindMatch'] = ['editor.action.addSelectionToNextFindMatch', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.addSelectionToPreviousFindMatch'] = ['editor.action.addSelectionToPreviousFindMatch', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.moveSelectionToNextFindMatch'] = ['editor.action.moveSelectionToNextFindMatch', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.moveSelectionToPreviousFindMatch'] = ['editor.action.moveSelectionToPreviousFindMatch', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.selectHighlights'] = ['editor.action.selectHighlights', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.changeAll'] = ['editor.action.changeAll', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.addCursorsToBottom'] = ['editor.action.addCursorsToBottom', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.addCursorsToTop'] = ['editor.action.addCursorsToTop', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.triggerParameterHints'] = ['editor.action.triggerParameterHints', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.wordHighlight.next'] = ['editor.action.wordHighlight.next', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.wordHighlight.prev'] = ['editor.action.wordHighlight.prev', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.wordHighlight.trigger'] = ['editor.action.wordHighlight.trigger', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.showAccessibilityHelp'] = ['editor.action.showAccessibilityHelp', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.inspectTokens'] = ['editor.action.inspectTokens', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.marker.next'] = ['editor.action.marker.next', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.marker.prev'] = ['editor.action.marker.prev', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.marker.nextInFiles'] = ['editor.action.marker.nextInFiles', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.marker.prevInFiles'] = ['editor.action.marker.prevInFiles', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.showHover'] = ['editor.action.showHover', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.revealDefinition'] = ['editor.action.revealDefinition', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.revealDefinitionAside'] = ['editor.action.revealDefinitionAside', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.peekDefinition'] = ['editor.action.peekDefinition', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.revealDeclaration'] = ['editor.action.revealDeclaration', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.peekDeclaration'] = ['editor.action.peekDeclaration', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.goToImplementation'] = ['editor.action.goToImplementation', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.peekImplementation'] = ['editor.action.peekImplementation', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.goToTypeDefinition'] = ['editor.action.goToTypeDefinition', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.peekTypeDefinition'] = ['editor.action.peekTypeDefinition', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.referenceSearch.trigger'] = ['editor.action.referenceSearch.trigger', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.triggerSuggest'] = ['editor.action.triggerSuggest', CONVERT_VSCODE_TO_MONACO]; + mappings['closeReferenceSearchEditor'] = ['closeReferenceSearchEditor', CONVERT_VSCODE_TO_MONACO]; + mappings['cancelSelection'] = ['cancelSelection', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorBottom'] = ['cursorBottom', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorBottomSelect'] = ['cursorBottomSelect', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorDown'] = ['cursorDown', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorDownSelect'] = ['cursorDownSelect', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorEnd'] = ['cursorEnd', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorEndSelect'] = ['cursorEndSelect', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorHome'] = ['cursorHome', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorHomeSelect'] = ['cursorHomeSelect', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorLeft'] = ['cursorLeft', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorLeftSelect'] = ['cursorLeftSelect', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorPageDown'] = ['cursorPageDown', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorPageDownSelect'] = ['cursorPageDownSelect', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorPageUp'] = ['cursorPageUp', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorPageUpSelect'] = ['cursorPageUpSelect', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorRight'] = ['cursorRight', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorRightSelect'] = ['cursorRightSelect', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorTop'] = ['cursorTop', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorTopSelect'] = ['cursorTopSelect', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorUp'] = ['cursorUp', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorUpSelect'] = ['cursorUpSelect', CONVERT_VSCODE_TO_MONACO]; + mappings['deleteLeft'] = ['deleteLeft', CONVERT_VSCODE_TO_MONACO]; + mappings['deleteRight'] = ['deleteRight', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.selectAll'] = ['editor.action.selectAll', CONVERT_VSCODE_TO_MONACO]; + mappings['expandLineSelection'] = ['expandLineSelection', CONVERT_VSCODE_TO_MONACO]; + mappings['outdent'] = ['outdent', CONVERT_VSCODE_TO_MONACO]; + mappings['scrollLineDown'] = ['scrollLineDown', CONVERT_VSCODE_TO_MONACO]; + mappings['scrollLineUp'] = ['scrollLineUp', CONVERT_VSCODE_TO_MONACO]; + mappings['scrollPageDown'] = ['scrollPageDown', CONVERT_VSCODE_TO_MONACO]; + mappings['scrollPageUp'] = ['scrollPageUp', CONVERT_VSCODE_TO_MONACO]; + mappings['tab'] = ['tab', CONVERT_VSCODE_TO_MONACO]; + mappings['removeSecondaryCursors'] = ['removeSecondaryCursors', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorWordRight'] = ['cursorWordEndRight', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorWordEndRight'] = ['cursorWordEndRight', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorWordEndRightSelect'] = ['cursorWordEndRightSelect', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorWordLeft'] = ['cursorWordStartLeft', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorWordStartLeft'] = ['cursorWordStartLeft', CONVERT_VSCODE_TO_MONACO]; + mappings['cursorWordStartLeftSelect'] = ['cursorWordStartLeftSelect', CONVERT_VSCODE_TO_MONACO]; + mappings['deleteWordLeft'] = ['deleteWordLeft', CONVERT_VSCODE_TO_MONACO]; + mappings['deleteWordRight'] = ['deleteWordRight', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.cancelOperation'] = ['editor.cancelOperation', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.gotoNextSymbolFromResult'] = ['editor.gotoNextSymbolFromResult', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.gotoNextSymbolFromResult.cancel'] = ['editor.gotoNextSymbolFromResult.cancel', CONVERT_VSCODE_TO_MONACO]; + mappings['openReferenceToSide'] = ['openReferenceToSide', CONVERT_VSCODE_TO_MONACO]; + mappings['toggleExplainMode'] = ['toggleExplainMode', CONVERT_VSCODE_TO_MONACO]; + mappings['closeFindWidget'] = ['closeFindWidget', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.replaceAll'] = ['editor.action.replaceAll', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.replaceOne'] = ['editor.action.replaceOne', CONVERT_VSCODE_TO_MONACO]; + mappings['editor.action.selectAllMatches'] = ['editor.action.selectAllMatches', CONVERT_VSCODE_TO_MONACO]; + mappings['toggleFindCaseSensitive'] = ['toggleFindCaseSensitive', CONVERT_VSCODE_TO_MONACO]; + mappings['toggleFindInSelection'] = ['toggleFindInSelection', CONVERT_VSCODE_TO_MONACO]; + mappings['toggleFindRegex'] = ['toggleFindRegex', CONVERT_VSCODE_TO_MONACO]; + mappings['toggleFindWholeWord'] = ['toggleFindWholeWord', CONVERT_VSCODE_TO_MONACO]; + mappings['jumpToNextSnippetPlaceholder'] = ['jumpToNextSnippetPlaceholder', CONVERT_VSCODE_TO_MONACO]; + mappings['jumpToPrevSnippetPlaceholder'] = ['jumpToPrevSnippetPlaceholder', CONVERT_VSCODE_TO_MONACO]; + mappings['leaveEditorMessage'] = ['leaveEditorMessage', CONVERT_VSCODE_TO_MONACO]; + mappings['leaveSnippet'] = ['leaveSnippet', CONVERT_VSCODE_TO_MONACO]; + mappings['closeMarkersNavigation'] = ['closeMarkersNavigation', CONVERT_VSCODE_TO_MONACO]; + mappings['goToNextReferenceFromEmbeddedEditor'] = ['goToNextReferenceFromEmbeddedEditor', CONVERT_VSCODE_TO_MONACO]; + mappings['goToPreviousReferenceFromEmbeddedEditor'] = ['goToPreviousReferenceFromEmbeddedEditor', CONVERT_VSCODE_TO_MONACO]; + mappings['closeParameterHints'] = ['closeParameterHints', CONVERT_VSCODE_TO_MONACO]; + mappings['showNextParameterHint'] = ['showNextParameterHint', CONVERT_VSCODE_TO_MONACO]; + mappings['showPrevParameterHint'] = ['showPrevParameterHint', CONVERT_VSCODE_TO_MONACO]; + mappings['acceptSelectedSuggestion'] = ['acceptSelectedSuggestion', CONVERT_VSCODE_TO_MONACO]; + mappings['acceptSelectedSuggestionOnEnter'] = ['acceptSelectedSuggestionOnEnter', CONVERT_VSCODE_TO_MONACO]; + mappings['hideSuggestWidget'] = ['hideSuggestWidget', CONVERT_VSCODE_TO_MONACO]; + mappings['insertBestCompletion'] = ['insertBestCompletion', CONVERT_VSCODE_TO_MONACO]; + mappings['insertNextSuggestion'] = ['insertNextSuggestion', CONVERT_VSCODE_TO_MONACO]; + mappings['insertPrevSuggestion'] = ['insertPrevSuggestion', CONVERT_VSCODE_TO_MONACO]; + mappings['selectNextPageSuggestion'] = ['selectNextPageSuggestion', CONVERT_VSCODE_TO_MONACO]; + mappings['selectNextSuggestion'] = ['selectNextSuggestion', CONVERT_VSCODE_TO_MONACO]; + mappings['selectPrevPageSuggestion'] = ['selectPrevPageSuggestion', CONVERT_VSCODE_TO_MONACO]; + mappings['selectPrevSuggestion'] = ['selectPrevSuggestion', CONVERT_VSCODE_TO_MONACO]; + mappings['toggleSuggestionDetails'] = ['toggleSuggestionDetails', CONVERT_VSCODE_TO_MONACO]; + mappings['toggleSuggestionFocus'] = ['toggleSuggestionFocus', CONVERT_VSCODE_TO_MONACO]; + mappings['acceptRenameInput'] = ['acceptRenameInput', CONVERT_VSCODE_TO_MONACO]; + mappings['cancelRenameInput'] = ['cancelRenameInput', CONVERT_VSCODE_TO_MONACO]; + mappings['closeAccessibilityHelp'] = ['closeAccessibilityHelp', CONVERT_VSCODE_TO_MONACO]; + mappings['history.showNext'] = ['history.showNext', CONVERT_VSCODE_TO_MONACO]; + mappings['history.showPrevious'] = ['history.showPrevious', CONVERT_VSCODE_TO_MONACO]; + mappings['closeReferenceSearch'] = ['closeReferenceSearch', CONVERT_VSCODE_TO_MONACO]; + mappings['goToNextReference'] = ['goToNextReference', CONVERT_VSCODE_TO_MONACO]; + mappings['goToPreviousReference'] = ['goToPreviousReference', CONVERT_VSCODE_TO_MONACO]; // eslint-disable-next-line @typescript-eslint/no-explicit-any - export function map(id: string, args: any[] | undefined, toDo: (mappedId: string, mappedArgs: any[] | undefined) => T): T { + const CONVERT_MONACO_TO_VSCODE = (args: any[] | undefined) => { + if (!args) { + return args; + } + const argStack: ConversionFunction[] = []; + args.forEach(_ => { + // eslint-disable-next-line @typescript-eslint/no-explicit-any + argStack.push((arg: any) => monacoToVscodeArgsConverter(arg)); + }); + if (args) { + return createConversionFunction(...argStack)(args); + } + }; + + // vscode-'executeXXX'-like commands + mappings['vscode.executeReferenceProvider'] = ['vscode.executeReferenceProvider', CONVERT_VSCODE_TO_MONACO, CONVERT_MONACO_TO_VSCODE]; + mappings['vscode.executeImplementationProvider'] = ['vscode.executeImplementationProvider', CONVERT_VSCODE_TO_MONACO, CONVERT_MONACO_TO_VSCODE]; + + // eslint-disable-next-line @typescript-eslint/no-explicit-any + export function map(id: string, args: any[] | undefined, toDo: (mappedId: string, mappedArgs: any[] | undefined, mappedResult: ConversionFunction | undefined) => T): T { if (mappings[id]) { - return toDo(mappings[id][0], mappings[id][1](args)); + return toDo(mappings[id][0], mappings[id][1](args), mappings[id][2] ? (result => mappings[id][2]!(result)) : undefined); } else { - return toDo(id, args); + return toDo(id, args, undefined); } } @@ -265,7 +285,7 @@ export namespace KnownCommands { } // eslint-disable-next-line @typescript-eslint/no-explicit-any - type ConversionFunction = ((parameter: any) => any) | undefined; + export type ConversionFunction = ((parameter: any) => any) | undefined; // eslint-disable-next-line @typescript-eslint/no-explicit-any function createConversionFunction(...conversions: ConversionFunction[]): (args: any[] | undefined) => any[] | undefined { // eslint-disable-next-line @typescript-eslint/no-explicit-any @@ -299,7 +319,7 @@ export namespace KnownCommands { } // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/tslint/config - function monacoArgsConverter(args: any[]) { + function vscodeToMonacoArgsConverter(args: any[]) { // tslint:disable-next-line:typedef return cloneAndChange(args, function (value) { if (Position.isPosition(value)) { @@ -317,6 +337,18 @@ export namespace KnownCommands { }); } + // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/tslint/config + function monacoToVscodeArgsConverter(args: any[]) { + // tslint:disable-next-line:typedef + return cloneAndChange(args, function (value) { + if (isModelLocation(value)) { + return toLocation(value); + } + if (!Array.isArray(value)) { + return value; + } + }); + } } function toArrayConversion(f: (a: T) => U): (a: T[]) => U[] { diff --git a/packages/plugin-ext/src/plugin/tree/tree-views.ts b/packages/plugin-ext/src/plugin/tree/tree-views.ts index 84cb45a238e69..cbb457aa7c7c7 100644 --- a/packages/plugin-ext/src/plugin/tree/tree-views.ts +++ b/packages/plugin-ext/src/plugin/tree/tree-views.ts @@ -30,6 +30,7 @@ import { RPCProtocol } from '../../common/rpc-protocol'; import { CommandRegistryImpl, CommandsConverter } from '../command-registry'; import { TreeViewSelection } from '../../common'; import { PluginIconPath } from '../plugin-icon-path'; +import debounce = require('lodash.debounce'); export class TreeViewsExtImpl implements TreeViewsExt { @@ -88,6 +89,22 @@ export class TreeViewsExtImpl implements TreeViewsExt { get onDidChangeVisibility() { return treeView.onDidChangeVisibility; }, + // tslint:disable-next-line:typedef + get message() { + return treeView.message; + }, + // tslint:disable-next-line:typedef + set message(message: string) { + treeView.message = message; + }, + // tslint:disable-next-line:typedef + get title() { + return treeView.title; + }, + // tslint:disable-next-line:typedef + set title(title: string) { + treeView.title = title; + }, // tslint:enable:typedef reveal: (element: T, selectionOptions: { select?: boolean }): Thenable => treeView.reveal(element, selectionOptions), @@ -159,6 +176,10 @@ class TreeViewExtImpl implements Disposable { private readonly onDidChangeVisibilityEmitter = new Emitter(); readonly onDidChangeVisibility = this.onDidChangeVisibilityEmitter.event; + protected updateMessage = debounce(() => { + this.proxy.$setMessage(this.treeViewId, this._message); + }, 200); + private readonly nodes = new Map>(); private readonly toDispose = new DisposableCollection( @@ -204,6 +225,26 @@ class TreeViewExtImpl implements Disposable { } } + private _message: string = ''; + get message(): string { + return this._message; + } + + set message(message: string) { + this._message = message; + this.updateMessage(); + } + + private _title: string = ''; + get title(): string { + return this._title; + } + + set title(title: string) { + this._title = title; + this.proxy.$setTitle(this.treeViewId, title); + } + getTreeItem(treeItemId: string): T | undefined { const element = this.nodes.get(treeItemId); return element && element.value; diff --git a/packages/plugin-ext/src/plugin/type-converters.ts b/packages/plugin-ext/src/plugin/type-converters.ts index 9d4203e68012f..cdf2972c4e5a5 100644 --- a/packages/plugin-ext/src/plugin/type-converters.ts +++ b/packages/plugin-ext/src/plugin/type-converters.ts @@ -27,6 +27,7 @@ import { LanguageFilter, LanguageSelector, RelativePattern } from '@theia/langua import { isMarkdownString, MarkdownString } from './markdown-string'; import { Item } from './quick-open'; import * as types from './types-impl'; +import { UriComponents } from '../common/uri-components'; const SIDE_GROUP = -2; const ACTIVE_GROUP = -1; @@ -585,6 +586,41 @@ export function toDocumentSymbol(symbol: model.DocumentSymbol): theia.DocumentSy }; } +// eslint-disable-next-line @typescript-eslint/no-explicit-any +export function isModelLocation(thing: any): thing is model.Location { + if (!thing) { + return false; + } + return isModelRange((thing).range) && + isUriComponents((thing).uri); +} + +// eslint-disable-next-line @typescript-eslint/no-explicit-any +export function isModelRange(thing: any): thing is model.Range { + if (!thing) { + return false; + } + return (('startLineNumber' in thing) && typeof thing.startLineNumber === 'number') && + (('startColumn' in thing) && typeof thing.startColumn === 'number') && + (('endLineNumber' in thing) && typeof thing.endLineNumber === 'number') && + (('endColumn' in thing) && typeof thing.endColumn === 'number'); +} + +// eslint-disable-next-line @typescript-eslint/no-explicit-any +export function isUriComponents(thing: any): thing is UriComponents { + if (!thing) { + return false; + } + return (('scheme' in thing) && typeof thing.scheme === 'string') && + (('path' in thing) && typeof thing.path === 'string') && + (('query' in thing) && typeof thing.query === 'string') && + (('fragment' in thing) && typeof thing.fragment === 'string'); +} + +export function toLocation(value: model.Location): types.Location { + return new types.Location(URI.revive(value.uri), toRange(value.range)); +} + export function toWorkspaceFolder(folder: model.WorkspaceFolder): theia.WorkspaceFolder { return { uri: URI.revive(folder.uri), diff --git a/packages/plugin/src/theia.d.ts b/packages/plugin/src/theia.d.ts index 840eee32a5f16..9c038975063c2 100644 --- a/packages/plugin/src/theia.d.ts +++ b/packages/plugin/src/theia.d.ts @@ -3903,6 +3903,18 @@ declare module '@theia/plugin' { */ readonly onDidChangeVisibility: Event; + /** + * An optional human-readable message that will be rendered in the view. + * Setting the message to null, undefined, or empty string will remove the message from the view. + */ + message?: string; + + /** + * The tree view title is initially taken from the extension package.json + * Changes to the title property will be properly reflected in the UI in the title of the view. + */ + title?: string; + /** * Reveal an element. By default revealed element is selected. *