From 5b7729870ec93db8e776b4dd46b4a1f9e9e2a8cc Mon Sep 17 00:00:00 2001 From: Eric Amodio Date: Sat, 14 Sep 2019 02:25:12 -0400 Subject: [PATCH] Adds keyboard nav support to Git commands Adds left arrow to go back if there is no text value --- src/commands/gitCommands.ts | 61 ++++++++++++++++++++++++++++++++++++++++---- src/commands/quickCommand.ts | 3 +++ 2 files changed, 59 insertions(+), 5 deletions(-) diff --git a/src/commands/gitCommands.ts b/src/commands/gitCommands.ts index 3567a34..fedf968 100644 --- a/src/commands/gitCommands.ts +++ b/src/commands/gitCommands.ts @@ -132,7 +132,30 @@ export class GitCommandsCommand extends Command { try { return await new Promise(resolve => { + const goBack = async () => { + input.value = ''; + if (commandsStep.command !== undefined) { + input.busy = true; + resolve((await commandsStep.command.previous()) || commandsStep); + } + }; + + const scope = Container.keyboard.createScope({ + left: { onDidPressKey: goBack }, + right: { + onDidPressKey: key => step.onDidPressKey && step.onDidPressKey(input, key) + }, + 'ctrl+right': { + onDidPressKey: key => step.onDidPressKey && step.onDidPressKey(input, key) + }, + 'alt+right': { + onDidPressKey: key => step.onDidPressKey && step.onDidPressKey(input, key) + } + }); + scope.start(); + disposables.push( + scope, input.onDidHide(() => resolve()), input.onDidTriggerButton(async e => { if (e === QuickInputButtons.Back) { @@ -203,17 +226,36 @@ export class GitCommandsCommand extends Command { try { return await new Promise(resolve => { + const goBack = async () => { + quickpick.value = ''; + if (commandsStep.command !== undefined) { + quickpick.busy = true; + resolve((await commandsStep.command.previous()) || commandsStep); + } + }; + + const scope = Container.keyboard.createScope({ + left: { onDidPressKey: goBack }, + right: { + onDidPressKey: key => step.onDidPressKey && step.onDidPressKey(quickpick, key) + }, + 'ctrl+right': { + onDidPressKey: key => step.onDidPressKey && step.onDidPressKey(quickpick, key) + }, + 'alt+right': { + onDidPressKey: key => step.onDidPressKey && step.onDidPressKey(quickpick, key) + } + }); + scope.start(); + let overrideItems = false; disposables.push( + scope, quickpick.onDidHide(() => resolve()), quickpick.onDidTriggerButton(async e => { if (e === QuickInputButtons.Back) { - quickpick.value = ''; - if (commandsStep.command !== undefined) { - quickpick.busy = true; - resolve((await commandsStep.command.previous()) || commandsStep); - } + goBack(); return; } @@ -250,6 +292,15 @@ export class GitCommandsCommand extends Command { } }), quickpick.onDidChangeValue(async e => { + if (scope !== undefined) { + // Pause the left/right keyboard commands if there is a value, otherwise the left/right arrows won't work in the input properly + if (e.length !== 0) { + await scope.pause(['left', 'right']); + } else { + await scope.resume(); + } + } + if (step.onDidChangeValue !== undefined) { const cancel = await step.onDidChangeValue(quickpick); if (cancel) return; diff --git a/src/commands/quickCommand.ts b/src/commands/quickCommand.ts index a1151b3..2a921c7 100644 --- a/src/commands/quickCommand.ts +++ b/src/commands/quickCommand.ts @@ -2,6 +2,7 @@ import { InputBox, QuickInputButton, QuickPick, QuickPickItem } from 'vscode'; import { Directive, DirectiveQuickPickItem } from '../quickpicks'; import { Container } from '../container'; +import { Keys } from '../keyboard'; export * from './quickCommand.helpers'; @@ -19,6 +20,7 @@ export interface QuickInputStep { value?: string; onDidClickButton?(input: InputBox, button: QuickInputButton): void; + onDidPressKey?(quickpick: InputBox, key: Keys): void | Promise; validate?(value: string | undefined): [boolean, string | undefined] | Promise<[boolean, string | undefined]>; } @@ -41,6 +43,7 @@ export interface QuickPickStep { onDidAccept?(quickpick: QuickPick): boolean | Promise; onDidChangeValue?(quickpick: QuickPick): boolean | Promise; onDidClickButton?(quickpick: QuickPick, button: QuickInputButton): void; + onDidPressKey?(quickpick: QuickPick, key: Keys): void | Promise; onValidateValue?(quickpick: QuickPick, value: string, items: T[]): boolean | Promise; validate?(selection: T[]): boolean; }