1 | import { Command, CommandRegistry } from '../command';
|
2 | import { ContributionProvider } from '../contribution-provider';
|
3 | import { Disposable } from '../disposable';
|
4 | import { Emitter, Event } from '../event';
|
5 | import { CompositeMenuNode } from './composite-menu-node';
|
6 | import { CompoundMenuNode, MenuAction, MenuNode, MenuPath, MutableCompoundMenuNode, SubMenuOptions } from './menu-types';
|
7 | export declare const MenuContribution: unique symbol;
|
8 |
|
9 |
|
10 |
|
11 |
|
12 |
|
13 |
|
14 |
|
15 |
|
16 |
|
17 |
|
18 |
|
19 |
|
20 |
|
21 |
|
22 |
|
23 |
|
24 |
|
25 |
|
26 |
|
27 |
|
28 |
|
29 |
|
30 |
|
31 |
|
32 |
|
33 |
|
34 | export interface MenuContribution {
|
35 | |
36 |
|
37 |
|
38 |
|
39 | registerMenus(menus: MenuModelRegistry): void;
|
40 | }
|
41 |
|
42 |
|
43 |
|
44 |
|
45 |
|
46 | export declare class MenuModelRegistry {
|
47 | protected readonly contributions: ContributionProvider<MenuContribution>;
|
48 | protected readonly commands: CommandRegistry;
|
49 | protected readonly root: CompositeMenuNode;
|
50 | protected readonly independentSubmenus: Map<string, MutableCompoundMenuNode>;
|
51 | protected readonly onDidChangeEmitter: Emitter<void>;
|
52 | get onDidChange(): Event<void>;
|
53 | protected isReady: boolean;
|
54 | constructor(contributions: ContributionProvider<MenuContribution>, commands: CommandRegistry);
|
55 | onStart(): void;
|
56 | /**
|
57 | * Adds the given menu action to the menu denoted by the given path.
|
58 | *
|
59 | * @returns a disposable which, when called, will remove the menu action again.
|
60 | */
|
61 | registerMenuAction(menuPath: MenuPath, item: MenuAction): Disposable;
|
62 | /**
|
63 | * Adds the given menu node to the menu denoted by the given path.
|
64 | *
|
65 | * @returns a disposable which, when called, will remove the menu node again.
|
66 | */
|
67 | registerMenuNode(menuPath: MenuPath | string, menuNode: MenuNode, group?: string): Disposable;
|
68 | getMenuNode(menuPath: MenuPath | string, group?: string): MutableCompoundMenuNode;
|
69 | /**
|
70 | * Register a new menu at the given path with the given label.
|
71 | * (If the menu already exists without a label, iconClass or order this method can be used to set them.)
|
72 | *
|
73 | * @param menuPath the path for which a new submenu shall be registered.
|
74 | * @param label the label to be used for the new submenu.
|
75 | * @param options optionally allows to set an icon class and specify the order of the new menu.
|
76 | *
|
77 | * @returns if the menu was successfully created a disposable will be returned which,
|
78 | * when called, will remove the menu again. If the menu already existed a no-op disposable
|
79 | * will be returned.
|
80 | *
|
81 | * Note that if the menu already existed and was registered with a different label an error
|
82 | * will be thrown.
|
83 | */
|
84 | registerSubmenu(menuPath: MenuPath, label: string, options?: SubMenuOptions): Disposable;
|
85 | registerIndependentSubmenu(id: string, label: string, options?: SubMenuOptions): Disposable;
|
86 | linkSubmenu(parentPath: MenuPath | string, childId: string | MenuPath, options?: SubMenuOptions, group?: string): Disposable;
|
87 | /**
|
88 | * Unregister all menu nodes with the same id as the given menu action.
|
89 | *
|
90 | * @param item the item whose id will be used.
|
91 | * @param menuPath if specified only nodes within the path will be unregistered.
|
92 | */
|
93 | unregisterMenuAction(item: MenuAction, menuPath?: MenuPath): void;
|
94 | /**
|
95 | * Unregister all menu nodes with the same id as the given command.
|
96 | *
|
97 | * @param command the command whose id will be used.
|
98 | * @param menuPath if specified only nodes within the path will be unregistered.
|
99 | */
|
100 | unregisterMenuAction(command: Command, menuPath?: MenuPath): void;
|
101 | /**
|
102 | * Unregister all menu nodes with the given id.
|
103 | *
|
104 | * @param id the id which shall be removed.
|
105 | * @param menuPath if specified only nodes within the path will be unregistered.
|
106 | */
|
107 | unregisterMenuAction(id: string, menuPath?: MenuPath): void;
|
108 | /**
|
109 | * Recurse all menus, removing any menus matching the `id`.
|
110 | *
|
111 | * @param id technical identifier of the `MenuNode`.
|
112 | */
|
113 | unregisterMenuNode(id: string): void;
|
114 | /**
|
115 | * Finds a submenu as a descendant of the `root` node.
|
116 | * See {@link MenuModelRegistry.findSubMenu findSubMenu}.
|
117 | */
|
118 | protected findGroup(menuPath: MenuPath, options?: SubMenuOptions): MutableCompoundMenuNode;
|
119 | |
120 |
|
121 |
|
122 |
|
123 | protected findSubMenu(current: MutableCompoundMenuNode, menuId: string, options?: SubMenuOptions): MutableCompoundMenuNode;
|
124 | |
125 |
|
126 |
|
127 |
|
128 |
|
129 |
|
130 |
|
131 |
|
132 | getMenu(menuPath?: MenuPath): MutableCompoundMenuNode;
|
133 | |
134 |
|
135 |
|
136 |
|
137 |
|
138 |
|
139 |
|
140 |
|
141 | removeSingleRootNode(fullMenuModel: MutableCompoundMenuNode, menuPath: MenuPath): CompoundMenuNode;
|
142 | protected allChildrenCompound(children: ReadonlyArray<MenuNode>): boolean;
|
143 | protected isEmpty(children: ReadonlyArray<MenuNode>): boolean;
|
144 | protected changeEventOnDispose(disposable: Disposable): Disposable;
|
145 | protected fireChangeEvent(): void;
|
146 | |
147 |
|
148 |
|
149 |
|
150 | getPath(node: MenuNode): MenuPath | undefined;
|
151 | }
|
152 |
|
\ | No newline at end of file |