chat command center polish (#229674)
* mark `chat.commandCenter.enabled` as EXP setting, change default * render keybindings * order in buckets of panel, inline, and quick chatpull/229680/head
parent
66b38fc2e2
commit
b80272842e
|
@ -170,5 +170,5 @@
|
|||
},
|
||||
"css.format.spaceAroundSelectorSeparator": true,
|
||||
"typescript.enablePromptUseWorkspaceTsdk": true,
|
||||
"inlineChat.experimental.onlyZoneWidget": true
|
||||
"chat.commandCenter.enabled": true
|
||||
}
|
||||
|
|
|
@ -61,7 +61,7 @@ export class DropdownWithPrimaryActionViewItem extends BaseActionViewItem {
|
|||
menuAsChild: _options?.menuAsChild ?? true,
|
||||
classNames: className ? ['codicon', 'codicon-chevron-down', className] : ['codicon', 'codicon-chevron-down'],
|
||||
actionRunner: this._options?.actionRunner,
|
||||
keybindingProvider: this._options?.getKeyBinding,
|
||||
keybindingProvider: this._options?.getKeyBinding ?? (action => _keybindingService.lookupKeybinding(action.id)),
|
||||
hoverDelegate: _options?.hoverDelegate
|
||||
});
|
||||
}
|
||||
|
|
|
@ -88,8 +88,8 @@ class OpenChatGlobalAction extends Action2 {
|
|||
},
|
||||
menu: {
|
||||
id: MenuId.ChatCommandCenter,
|
||||
group: 'open',
|
||||
order: 1
|
||||
group: 'a_chat',
|
||||
order: 10
|
||||
}
|
||||
});
|
||||
}
|
||||
|
|
|
@ -116,7 +116,7 @@ class AttachFileAction extends Action2 {
|
|||
precondition: ActiveEditorContext.isEqualTo('workbench.editors.files.textFileEditor'),
|
||||
menu: {
|
||||
id: MenuId.ChatCommandCenter,
|
||||
group: 'attach',
|
||||
group: 'a_chat',
|
||||
order: 1,
|
||||
}
|
||||
});
|
||||
|
@ -146,7 +146,7 @@ class AttachSelectionAction extends Action2 {
|
|||
precondition: ActiveEditorContext.isEqualTo('workbench.editors.files.textFileEditor'),
|
||||
menu: {
|
||||
id: MenuId.ChatCommandCenter,
|
||||
group: 'attach',
|
||||
group: 'a_chat',
|
||||
order: 2,
|
||||
}
|
||||
});
|
||||
|
|
|
@ -116,7 +116,7 @@ class QuickChatGlobalAction extends Action2 {
|
|||
},
|
||||
menu: {
|
||||
id: MenuId.ChatCommandCenter,
|
||||
group: 'open',
|
||||
group: 'c_quickChat',
|
||||
order: 5
|
||||
},
|
||||
metadata: {
|
||||
|
|
|
@ -103,8 +103,9 @@ configurationRegistry.registerConfiguration({
|
|||
},
|
||||
'chat.commandCenter.enabled': {
|
||||
type: 'boolean',
|
||||
tags: ['experimental'],
|
||||
markdownDescription: nls.localize('chat.commandCenter.enabled', "Controls whether the command center shows a menu for chat actions (requires {0}).", '`#window.commandCenter#`'),
|
||||
default: true
|
||||
default: false
|
||||
},
|
||||
'chat.experimental.implicitContext': {
|
||||
type: 'boolean',
|
||||
|
|
|
@ -13,7 +13,7 @@ import { EditorContextKeys } from '../../../../editor/common/editorContextKeys.j
|
|||
import { InlineChatController, InlineChatRunOptions } from './inlineChatController.js';
|
||||
import { ACTION_ACCEPT_CHANGES, CTX_INLINE_CHAT_HAS_AGENT, CTX_INLINE_CHAT_HAS_STASHED_SESSION, CTX_INLINE_CHAT_FOCUSED, CTX_INLINE_CHAT_INNER_CURSOR_FIRST, CTX_INLINE_CHAT_INNER_CURSOR_LAST, CTX_INLINE_CHAT_VISIBLE, CTX_INLINE_CHAT_OUTER_CURSOR_POSITION, CTX_INLINE_CHAT_USER_DID_EDIT, CTX_INLINE_CHAT_DOCUMENT_CHANGED, CTX_INLINE_CHAT_EDIT_MODE, EditMode, MENU_INLINE_CHAT_WIDGET_STATUS, CTX_INLINE_CHAT_REQUEST_IN_PROGRESS, CTX_INLINE_CHAT_RESPONSE_TYPE, InlineChatResponseType, ACTION_REGENERATE_RESPONSE, ACTION_VIEW_IN_CHAT, ACTION_TOGGLE_DIFF, CTX_INLINE_CHAT_CHANGE_HAS_DIFF, CTX_INLINE_CHAT_CHANGE_SHOWS_DIFF, MENU_INLINE_CHAT_ZONE, ACTION_DISCARD_CHANGES } from '../common/inlineChat.js';
|
||||
import { localize, localize2 } from '../../../../nls.js';
|
||||
import { Action2, IAction2Options } from '../../../../platform/actions/common/actions.js';
|
||||
import { Action2, IAction2Options, MenuId } from '../../../../platform/actions/common/actions.js';
|
||||
import { ContextKeyExpr } from '../../../../platform/contextkey/common/contextkey.js';
|
||||
import { IInstantiationService, ServicesAccessor } from '../../../../platform/instantiation/common/instantiation.js';
|
||||
import { KeybindingWeight } from '../../../../platform/keybinding/common/keybindingsRegistry.js';
|
||||
|
@ -27,6 +27,7 @@ import { ILogService } from '../../../../platform/log/common/log.js';
|
|||
import { IChatService } from '../../chat/common/chatService.js';
|
||||
import { CONTEXT_CHAT_INPUT_HAS_TEXT, CONTEXT_IN_CHAT_INPUT } from '../../chat/common/chatContextKeys.js';
|
||||
import { HunkInformation } from './inlineChatSession.js';
|
||||
import { ActiveEditorContext } from '../../../common/contextkeys.js';
|
||||
|
||||
CommandsRegistry.registerCommandAlias('interactiveEditor.start', 'inlineChat.start');
|
||||
CommandsRegistry.registerCommandAlias('interactive.acceptChanges', ACTION_ACCEPT_CHANGES);
|
||||
|
@ -49,17 +50,22 @@ export class StartSessionAction extends EditorAction2 {
|
|||
constructor() {
|
||||
super({
|
||||
id: 'inlineChat.start',
|
||||
title: localize2('run', 'Editor Chat'),
|
||||
title: localize2('run', 'Editor Inline Chat'),
|
||||
category: AbstractInlineChatAction.category,
|
||||
f1: true,
|
||||
precondition: ContextKeyExpr.and(CTX_INLINE_CHAT_HAS_AGENT, EditorContextKeys.writable),
|
||||
precondition: ContextKeyExpr.and(CTX_INLINE_CHAT_HAS_AGENT, ActiveEditorContext.isEqualTo('workbench.editors.files.textFileEditor')),
|
||||
keybinding: {
|
||||
when: EditorContextKeys.focus,
|
||||
when: ContextKeyExpr.and(EditorContextKeys.focus, EditorContextKeys.writable),
|
||||
weight: KeybindingWeight.WorkbenchContrib,
|
||||
primary: KeyMod.CtrlCmd | KeyCode.KeyI,
|
||||
secondary: [KeyChord(KeyMod.CtrlCmd | KeyCode.KeyK, KeyCode.KeyI)],
|
||||
},
|
||||
icon: START_INLINE_CHAT
|
||||
icon: START_INLINE_CHAT,
|
||||
menu: {
|
||||
id: MenuId.ChatCommandCenter,
|
||||
group: 'b_inlineChat',
|
||||
order: 10,
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue