fix missing entries from global go menu

pull/85384/head
Johannes Rieken 2019-11-22 12:33:22 +01:00
parent d2408cb817
commit a78363abd0
2 changed files with 32 additions and 38 deletions

View File

@ -44,8 +44,8 @@ export interface ICommandKeybindingsOptions extends IKeybindings {
}
export interface ICommandMenuOptions {
menuId: MenuId;
group?: string;
order?: number;
group: string;
order: number;
when?: ContextKeyExpr;
title: string;
}
@ -194,53 +194,42 @@ export interface IEditorActionContextMenuOptions {
group: string;
order: number;
when?: ContextKeyExpr;
menuId?: MenuId;
}
export interface IActionOptions {
id: string;
export interface IActionOptions extends ICommandOptions {
label: string;
alias: string;
description?: ICommandHandlerDescription;
precondition: ContextKeyExpr | undefined;
kbOpts?: ICommandKeybindingsOptions;
contextMenuOpts?: IEditorActionContextMenuOptions;
menuOpts?: Partial<ICommandMenuOptions> | Partial<ICommandMenuOptions[]>;
contextMenuOpts?: IEditorActionContextMenuOptions | IEditorActionContextMenuOptions[];
}
export abstract class EditorAction extends EditorCommand {
private static convertOptions(opts: IActionOptions): ICommandOptions {
function patch(menu: Partial<ICommandMenuOptions>): ICommandMenuOptions {
if (!menu.title) {
menu.title = opts.label;
}
if (!menu.menuId) {
menu.menuId = MenuId.EditorContext;
}
if (!menu.when) {
menu.when = opts.precondition;
}
return <ICommandMenuOptions>menu;
}
let menuOpts: ICommandMenuOptions[];
if (Array.isArray(opts.menuOpts)) {
menuOpts = opts.menuOpts.map(m => patch(m!));
menuOpts = opts.menuOpts;
} else if (opts.menuOpts) {
menuOpts = [patch(opts.menuOpts)];
menuOpts = [opts.menuOpts];
} else {
menuOpts = [];
}
if (opts.contextMenuOpts) {
const contextMenuItem = {
title: opts.label,
when: ContextKeyExpr.and(opts.precondition, opts.contextMenuOpts.when),
menuId: MenuId.EditorContext,
group: opts.contextMenuOpts.group,
order: opts.contextMenuOpts.order
};
menuOpts.push(contextMenuItem);
function withDefaults(item: Partial<ICommandMenuOptions>): ICommandMenuOptions {
if (!item.menuId) {
item.menuId = MenuId.EditorContext;
}
if (!item.title) {
item.title = opts.label;
}
item.when = ContextKeyExpr.and(opts.precondition, item.when);
return <ICommandMenuOptions>item;
}
if (Array.isArray(opts.contextMenuOpts)) {
menuOpts.push(...opts.contextMenuOpts.map(withDefaults));
} else if (opts.contextMenuOpts) {
menuOpts.push(withDefaults(opts.contextMenuOpts));
}
opts.menuOpts = menuOpts;

View File

@ -309,8 +309,9 @@ registerEditorAction(class PeekDefinitionAction extends DefinitionAction {
linux: { primary: KeyMod.CtrlCmd | KeyMod.Shift | KeyCode.F10 },
weight: KeybindingWeight.EditorContrib
},
menuOpts: {
contextMenuOpts: {
menuId: MenuId.EditorContextPeek,
group: 'peek',
order: 2
}
});
@ -395,8 +396,9 @@ registerEditorAction(class PeekDeclarationAction extends DeclarationAction {
PeekContext.notInPeekEditor,
EditorContextKeys.isInEmbeddedEditor.toNegated()
),
menuOpts: {
contextMenuOpts: {
menuId: MenuId.EditorContextPeek,
group: 'peek',
order: 3
}
});
@ -481,8 +483,9 @@ registerEditorAction(class PeekTypeDefinitionAction extends TypeDefinitionAction
PeekContext.notInPeekEditor,
EditorContextKeys.isInEmbeddedEditor.toNegated()
),
menuOpts: {
contextMenuOpts: {
menuId: MenuId.EditorContextPeek,
group: 'peek',
order: 4
}
});
@ -572,8 +575,9 @@ registerEditorAction(class PeekImplementationAction extends ImplementationAction
primary: KeyMod.CtrlCmd | KeyMod.Shift | KeyCode.F12,
weight: KeybindingWeight.EditorContrib
},
menuOpts: {
contextMenuOpts: {
menuId: MenuId.EditorContextPeek,
group: 'peek',
order: 5
}
});
@ -656,8 +660,9 @@ registerEditorAction(class PeekReferencesAction extends ReferencesAction {
PeekContext.notInPeekEditor,
EditorContextKeys.isInEmbeddedEditor.toNegated()
),
menuOpts: {
contextMenuOpts: {
menuId: MenuId.EditorContextPeek,
group: 'peek',
order: 6
}
});