From 0c505a4ea64fb1ffc99eaabfd67aa2d8a689a511 Mon Sep 17 00:00:00 2001 From: FernandoAscencio Date: Wed, 22 Feb 2023 10:37:40 -0500 Subject: [PATCH] QuickInput: First Element Fallback on Enter This is the first solution step. Might be scrapped. Signed-off-by: FernandoAScencio --- .../src/browser/monaco-quick-input-service.ts | 21 ++++++++++--------- 1 file changed, 11 insertions(+), 10 deletions(-) diff --git a/packages/monaco/src/browser/monaco-quick-input-service.ts b/packages/monaco/src/browser/monaco-quick-input-service.ts index f4550707cc710..cd5ae03346eeb 100644 --- a/packages/monaco/src/browser/monaco-quick-input-service.ts +++ b/packages/monaco/src/browser/monaco-quick-input-service.ts @@ -196,7 +196,7 @@ export class MonacoQuickInputImplementation implements IQuickInputService { container: this.container, styles: { widget: {}, list: {}, inputBox: {}, countBadge: {}, button: {}, progressBar: {}, keybindingLabel: {}, }, ignoreFocusOut: () => false, - isScreenReaderOptimized: () => true, + isScreenReaderOptimized: () => false, // TODO change to true once support is added. backKeybindingLabel: () => undefined, setContextKey: (id?: string) => this.setContextKey(id), returnFocus: () => this.container.focus(), @@ -322,8 +322,7 @@ export class MonacoQuickInputService implements QuickInputService { showQuickPick(items: Array, options?: QuickPickOptions): Promise { return new Promise((resolve, reject) => { - const quickPick = this.monacoService.createQuickPick>(); - const wrapped = this.wrapQuickPick(quickPick); + const wrapped = this.createQuickPick(); wrapped.items = items; if (options) { @@ -557,26 +556,28 @@ class MonacoQuickPick extends MonacoQuickInput implemen return this.wrapped.items.map(item => QuickPickSeparator.is(item) ? item : item.item); } - set items(itms: readonly (T | QuickPickSeparator)[]) { + set items(itemList: readonly (T | QuickPickSeparator)[]) { // We need to store and apply the currently selected active items. // Since monaco compares these items by reference equality, creating new wrapped items will unmark any active items. // Assigning the `activeItems` again will restore all active items even after the items array has changed. // See also the `findMonacoItemReferences` method. const active = this.activeItems; - this.wrapped.items = itms.map(item => QuickPickSeparator.is(item) ? item : new MonacoQuickPickItem(item, this.keybindingRegistry)); - this.activeItems = active; + this.wrapped.items = itemList.map(item => QuickPickSeparator.is(item) ? item : new MonacoQuickPickItem(item, this.keybindingRegistry)); + if (active.length !== 0) { + this.activeItems = active; // If this is done with an empty activeItems array, then it will undo first item focus on quick menus. + } } - set activeItems(itms: readonly T[]) { - this.wrapped.activeItems = this.findMonacoItemReferences(this.wrapped.items, itms); + set activeItems(itemList: readonly T[]) { + this.wrapped.activeItems = this.findMonacoItemReferences(this.wrapped.items, itemList); } get activeItems(): readonly (T)[] { return this.wrapped.activeItems.map(item => item.item); } - set selectedItems(itms: readonly T[]) { - this.wrapped.selectedItems = this.findMonacoItemReferences(this.wrapped.items, itms); + set selectedItems(itemList: readonly T[]) { + this.wrapped.selectedItems = this.findMonacoItemReferences(this.wrapped.items, itemList); } get selectedItems(): readonly (T)[] {