mirror of
https://github.com/microsoft/vscode.git
synced 2026-05-15 12:51:00 +01:00
3a8b7e4276
* Highlight label should not create extra empty dom nodes I noticed that the `HighlightedLabel` class creates extra `span` elements for text ranges. These should not be needed. Using text children directly should be faster for creation and also reduce the number of nodes in the document I also related the conditional spread with a longer version that uses a simple call to push. This is worth doing since `HighlightedLabel` is so widely used in the editor * Update tests * Update smoke test selector * Update css
59 lines
2.4 KiB
TypeScript
59 lines
2.4 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
import { Code } from './code';
|
|
|
|
export class QuickInput {
|
|
|
|
private static QUICK_INPUT = '.quick-input-widget';
|
|
private static QUICK_INPUT_INPUT = `${QuickInput.QUICK_INPUT} .quick-input-box input`;
|
|
private static QUICK_INPUT_ROW = `${QuickInput.QUICK_INPUT} .quick-input-list .monaco-list-row`;
|
|
private static QUICK_INPUT_FOCUSED_ELEMENT = `${QuickInput.QUICK_INPUT_ROW}.focused .monaco-highlighted-label`;
|
|
private static QUICK_INPUT_ENTRY_LABEL = `${QuickInput.QUICK_INPUT_ROW} .label-name`;
|
|
private static QUICK_INPUT_ENTRY_LABEL_SPAN = `${QuickInput.QUICK_INPUT_ROW} .monaco-highlighted-label`;
|
|
|
|
constructor(private code: Code) { }
|
|
|
|
async waitForQuickInputOpened(retryCount?: number): Promise<void> {
|
|
await this.code.waitForActiveElement(QuickInput.QUICK_INPUT_INPUT, retryCount);
|
|
}
|
|
|
|
async type(value: string): Promise<void> {
|
|
await this.code.waitForSetValue(QuickInput.QUICK_INPUT_INPUT, value);
|
|
}
|
|
|
|
async waitForQuickInputElementFocused(): Promise<void> {
|
|
await this.code.waitForTextContent(QuickInput.QUICK_INPUT_FOCUSED_ELEMENT);
|
|
}
|
|
|
|
async waitForQuickInputElementText(): Promise<string> {
|
|
return this.code.waitForTextContent(QuickInput.QUICK_INPUT_ENTRY_LABEL_SPAN);
|
|
}
|
|
|
|
async closeQuickInput(): Promise<void> {
|
|
await this.code.dispatchKeybinding('escape');
|
|
await this.waitForQuickInputClosed();
|
|
}
|
|
|
|
async waitForQuickInputElements(accept: (names: string[]) => boolean): Promise<void> {
|
|
await this.code.waitForElements(QuickInput.QUICK_INPUT_ENTRY_LABEL, false, els => accept(els.map(e => e.textContent)));
|
|
}
|
|
|
|
async waitForQuickInputClosed(): Promise<void> {
|
|
await this.code.waitForElement(QuickInput.QUICK_INPUT, r => !!r && r.attributes.style.indexOf('display: none;') !== -1);
|
|
}
|
|
|
|
async selectQuickInputElement(index: number, keepOpen?: boolean): Promise<void> {
|
|
await this.waitForQuickInputOpened();
|
|
for (let from = 0; from < index; from++) {
|
|
await this.code.dispatchKeybinding('down');
|
|
}
|
|
await this.code.dispatchKeybinding('enter');
|
|
if (!keepOpen) {
|
|
await this.waitForQuickInputClosed();
|
|
}
|
|
}
|
|
}
|