diff options
| author | haroldmciver-go <[email protected]> | 2025-07-11 16:01:28 -0400 |
|---|---|---|
| committer | GitHub <[email protected]> | 2025-07-11 20:01:28 +0000 |
| commit | 4197f3027857f1f6e83aedacb7e47a07690e2095 (patch) | |
| tree | d2d568850fb8dce11e383f8252fe59330791ff7d /packages/cli/src/ui/hooks | |
| parent | 2826c7a1c60bc09d256d7a7c11bdd98f65316cb7 (diff) | |
update /theme to new slash command arch (#3791)
Co-authored-by: matt korwel <[email protected]>
Co-authored-by: Abhi <[email protected]>
Diffstat (limited to 'packages/cli/src/ui/hooks')
| -rw-r--r-- | packages/cli/src/ui/hooks/slashCommandProcessor.test.ts | 26 | ||||
| -rw-r--r-- | packages/cli/src/ui/hooks/slashCommandProcessor.ts | 12 |
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, ], ); |
