summaryrefslogtreecommitdiff
path: root/packages/cli/src/ui/commands
diff options
context:
space:
mode:
Diffstat (limited to 'packages/cli/src/ui/commands')
-rw-r--r--packages/cli/src/ui/commands/themeCommand.test.ts38
-rw-r--r--packages/cli/src/ui/commands/themeCommand.ts16
-rw-r--r--packages/cli/src/ui/commands/types.ts2
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 =