Skip to content

Commit

Permalink
Documentation (#45589)
Browse files Browse the repository at this point in the history
  • Loading branch information
chrmarti committed Mar 26, 2018
1 parent 5467271 commit 33dce47
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 3 deletions.
3 changes: 3 additions & 0 deletions src/vs/platform/quickOpen/common/quickOpen.ts
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,9 @@ export interface IPickOptions {
*/
contextKey?: string;

/**
* an optional flag to make this picker multi-select (honoured by extension API)
*/
multiSelect?: boolean;
}

Expand Down
13 changes: 11 additions & 2 deletions src/vs/vscode.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1554,6 +1554,9 @@ declare module 'vscode' {
*/
ignoreFocusOut?: boolean;

/**
* An optional flag to make the picker multi-select, if true the result is an array of picks.
*/
multiSelect?: boolean;

/**
Expand All @@ -1562,10 +1565,16 @@ declare module 'vscode' {
onDidSelectItem?(item: QuickPickItem | string): any;
}

/**
* Represents an item that can be selected in a multi-select quick pick UI.
*/
export interface MultiSelectQuickPickItem extends QuickPickItem {
selected?: boolean;
}

/**
* Options to configure the behavior of the multi-select quick pick UI. (Marker type.)
*/
export interface MultiSelectQuickPickOptions extends QuickPickOptions {
multiSelect: true;
}
Expand Down Expand Up @@ -5077,7 +5086,7 @@ declare module 'vscode' {
* @param items An array of strings, or a promise that resolves to an array of strings.
* @param options Configures the behavior of the selection list.
* @param token A token that can be used to signal cancellation.
* @return A promise that resolves to the selection or `undefined`.
* @return A promise that resolves to the selected item(s) or `undefined`.
*/
export function showQuickPick(items: string[] | Thenable<string[]>, options: MultiSelectQuickPickOptions, token?: CancellationToken): Thenable<string[] | undefined>;
export function showQuickPick(items: string[] | Thenable<string[]>, options?: QuickPickOptions, token?: CancellationToken): Thenable<string | undefined>;
Expand All @@ -5088,7 +5097,7 @@ declare module 'vscode' {
* @param items An array of items, or a promise that resolves to an array of items.
* @param options Configures the behavior of the selection list.
* @param token A token that can be used to signal cancellation.
* @return A promise that resolves to the selected item or `undefined`.
* @return A promise that resolves to the selected item(s) or `undefined`.
*/
export function showQuickPick<T extends MultiSelectQuickPickItem>(items: T[] | Thenable<T[]>, options: MultiSelectQuickPickOptions, token?: CancellationToken): Thenable<T[] | undefined>;
export function showQuickPick<T extends QuickPickItem>(items: T[] | Thenable<T[]>, options?: QuickPickOptions, token?: CancellationToken): Thenable<T | undefined>;
Expand Down
4 changes: 3 additions & 1 deletion src/vs/workbench/browser/parts/quickinput/quickInput.ts
Original file line number Diff line number Diff line change
Expand Up @@ -143,9 +143,11 @@ export class QuickInputService extends Component implements IQuickInputService {
this.resolve();
}

// TODO: Listen on cancellation token.

this.inputBox.setValue('');
// TODO: Localize shortcut.
this.inputBox.setPlaceholder(options.placeHolder ? localize('quickInput.ctrlSpaceToSelectWithPlaceholder', "{1} ({0} to toggle)", 'Cmd+Space', options.placeHolder) : localize('quickInput.ctrlSpaceToSelect', "{0} to toggle", 'Cmd+Space'));
this.inputBox.setPlaceholder(options.placeHolder ? localize('quickInput.ctrlSpaceToSelectWithPlaceholder', "{1} ({0} to toggle)", 'Ctrl+Space', options.placeHolder) : localize('quickInput.ctrlSpaceToSelect', "{0} to toggle", 'Ctrl+Space'));
// TODO: Progress indication.
this.checkboxList.setElements(await picks);

Expand Down

0 comments on commit 33dce47

Please sign in to comment.