diff options
Diffstat (limited to 'packages/cli/src/ui/commands')
| -rw-r--r-- | packages/cli/src/ui/commands/themeCommand.test.ts | 38 | ||||
| -rw-r--r-- | packages/cli/src/ui/commands/themeCommand.ts | 16 | ||||
| -rw-r--r-- | packages/cli/src/ui/commands/types.ts | 2 |
3 files changed, 55 insertions, 1 deletions
diff --git a/packages/cli/src/ui/commands/themeCommand.test.ts b/packages/cli/src/ui/commands/themeCommand.test.ts new file mode 100644 index 00000000..2a537bcc --- /dev/null +++ b/packages/cli/src/ui/commands/themeCommand.test.ts @@ -0,0 +1,38 @@ +/** + * @license + * Copyright 2025 Google LLC + * SPDX-License-Identifier: Apache-2.0 + */ + +import { describe, it, expect, beforeEach } from 'vitest'; +import { themeCommand } from './themeCommand.js'; +import { type CommandContext } from './types.js'; +import { createMockCommandContext } from '../../test-utils/mockCommandContext.js'; + +describe('themeCommand', () => { + let mockContext: CommandContext; + + beforeEach(() => { + mockContext = createMockCommandContext(); + }); + + it('should return a dialog action to open the theme dialog', () => { + // Ensure the command has an action to test. + if (!themeCommand.action) { + throw new Error('The theme command must have an action.'); + } + + const result = themeCommand.action(mockContext, ''); + + // Assert that the action returns the correct object to trigger the theme dialog. + expect(result).toEqual({ + type: 'dialog', + dialog: 'theme', + }); + }); + + it('should have the correct name and description', () => { + expect(themeCommand.name).toBe('theme'); + expect(themeCommand.description).toBe('change the theme'); + }); +}); diff --git a/packages/cli/src/ui/commands/themeCommand.ts b/packages/cli/src/ui/commands/themeCommand.ts new file mode 100644 index 00000000..29e9a491 --- /dev/null +++ b/packages/cli/src/ui/commands/themeCommand.ts @@ -0,0 +1,16 @@ +/** + * @license + * Copyright 2025 Google LLC + * SPDX-License-Identifier: Apache-2.0 + */ + +import { OpenDialogActionReturn, SlashCommand } from './types.js'; + +export const themeCommand: SlashCommand = { + name: 'theme', + description: 'change the theme', + action: (_context, _args): OpenDialogActionReturn => ({ + type: 'dialog', + dialog: 'theme', + }), +}; diff --git a/packages/cli/src/ui/commands/types.ts b/packages/cli/src/ui/commands/types.ts index 09682d7a..9aad3399 100644 --- a/packages/cli/src/ui/commands/types.ts +++ b/packages/cli/src/ui/commands/types.ts @@ -66,7 +66,7 @@ export interface MessageActionReturn { export interface OpenDialogActionReturn { type: 'dialog'; // TODO: Add 'theme' | 'auth' | 'editor' | 'privacy' as migration happens. - dialog: 'help'; + dialog: 'help' | 'theme'; } export type SlashCommandActionReturn = |
