summaryrefslogtreecommitdiff
path: root/packages/cli/src/ui/hooks
diff options
context:
space:
mode:
Diffstat (limited to 'packages/cli/src/ui/hooks')
-rw-r--r--packages/cli/src/ui/hooks/slashCommandProcessor.test.ts26
-rw-r--r--packages/cli/src/ui/hooks/slashCommandProcessor.ts12
2 files changed, 30 insertions, 8 deletions
diff --git a/packages/cli/src/ui/hooks/slashCommandProcessor.test.ts b/packages/cli/src/ui/hooks/slashCommandProcessor.test.ts
index 45f52074..563092a2 100644
--- a/packages/cli/src/ui/hooks/slashCommandProcessor.test.ts
+++ b/packages/cli/src/ui/hooks/slashCommandProcessor.test.ts
@@ -507,6 +507,32 @@ describe('useSlashCommandProcessor', () => {
expect(commandResult).toEqual({ type: 'handled' });
});
+ it('should open the theme dialog when a new command returns a theme dialog action', async () => {
+ const mockAction = vi.fn().mockResolvedValue({
+ type: 'dialog',
+ dialog: 'theme',
+ });
+ const newCommand: SlashCommand = { name: 'test', action: mockAction };
+ const mockLoader = async () => [newCommand];
+ const commandServiceInstance = new ActualCommandService(mockLoader);
+ vi.mocked(CommandService).mockImplementation(
+ () => commandServiceInstance,
+ );
+
+ const { result } = getProcessorHook();
+ await vi.waitFor(() => {
+ expect(
+ result.current.slashCommands.some((c) => c.name === 'test'),
+ ).toBe(true);
+ });
+
+ const commandResult = await result.current.handleSlashCommand('/test');
+
+ expect(mockAction).toHaveBeenCalledTimes(1);
+ expect(mockOpenThemeDialog).toHaveBeenCalledWith();
+ expect(commandResult).toEqual({ type: 'handled' });
+ });
+
it('should show help for a parent command with no action', async () => {
const parentCommand: SlashCommand = {
name: 'parent',
diff --git a/packages/cli/src/ui/hooks/slashCommandProcessor.ts b/packages/cli/src/ui/hooks/slashCommandProcessor.ts
index f53bdc12..59f748bf 100644
--- a/packages/cli/src/ui/hooks/slashCommandProcessor.ts
+++ b/packages/cli/src/ui/hooks/slashCommandProcessor.ts
@@ -243,13 +243,6 @@ export const useSlashCommandProcessor = (
},
},
{
- name: 'theme',
- description: 'change the theme',
- action: (_mainCommand, _subCommand, _args) => {
- openThemeDialog();
- },
- },
- {
name: 'auth',
description: 'change the auth method',
action: (_mainCommand, _subCommand, _args) => openAuthDialog(),
@@ -1034,7 +1027,6 @@ export const useSlashCommandProcessor = (
return commands;
}, [
addMessage,
- openThemeDialog,
openAuthDialog,
openEditorDialog,
openPrivacyNotice,
@@ -1133,6 +1125,9 @@ export const useSlashCommandProcessor = (
case 'help':
setShowHelp(true);
return { type: 'handled' };
+ case 'theme':
+ openThemeDialog();
+ return { type: 'handled' };
default: {
const unhandled: never = result.dialog;
throw new Error(
@@ -1214,6 +1209,7 @@ export const useSlashCommandProcessor = (
legacyCommands,
commandContext,
addMessage,
+ openThemeDialog,
],
);