dexto 1.4.0 → 1.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (223) hide show
  1. package/README.md +62 -7
  2. package/dist/agents/agent-template.yml +2 -2
  3. package/dist/agents/coding-agent/coding-agent.yml +22 -16
  4. package/dist/agents/database-agent/database-agent.yml +2 -2
  5. package/dist/agents/default-agent.yml +7 -5
  6. package/dist/agents/github-agent/github-agent.yml +2 -2
  7. package/dist/agents/product-name-researcher/product-name-researcher.yml +2 -2
  8. package/dist/agents/talk2pdf-agent/talk2pdf-agent.yml +2 -2
  9. package/dist/analytics/events.d.ts +13 -6
  10. package/dist/analytics/events.d.ts.map +1 -1
  11. package/dist/analytics/index.d.ts +1 -1
  12. package/dist/analytics/index.d.ts.map +1 -1
  13. package/dist/analytics/index.js +6 -2
  14. package/dist/api/server-hono.d.ts.map +1 -1
  15. package/dist/api/server-hono.js +27 -5
  16. package/dist/cli/cli-subscriber.d.ts +4 -0
  17. package/dist/cli/cli-subscriber.d.ts.map +1 -1
  18. package/dist/cli/cli-subscriber.js +40 -2
  19. package/dist/cli/commands/create-app.d.ts +16 -14
  20. package/dist/cli/commands/create-app.d.ts.map +1 -1
  21. package/dist/cli/commands/create-app.js +626 -102
  22. package/dist/cli/commands/create-image.d.ts +7 -0
  23. package/dist/cli/commands/create-image.d.ts.map +1 -0
  24. package/dist/cli/commands/create-image.js +201 -0
  25. package/dist/cli/commands/helpers/formatters.js +7 -7
  26. package/dist/cli/commands/index.d.ts +2 -1
  27. package/dist/cli/commands/index.d.ts.map +1 -1
  28. package/dist/cli/commands/index.js +2 -1
  29. package/dist/cli/commands/init-app.js +7 -7
  30. package/dist/cli/commands/install.d.ts +0 -3
  31. package/dist/cli/commands/install.d.ts.map +1 -1
  32. package/dist/cli/commands/install.js +10 -35
  33. package/dist/cli/commands/interactive-commands/command-parser.js +7 -7
  34. package/dist/cli/commands/interactive-commands/general-commands.js +1 -1
  35. package/dist/cli/commands/interactive-commands/prompt-commands.js +11 -11
  36. package/dist/cli/commands/interactive-commands/system/system-commands.js +3 -3
  37. package/dist/cli/commands/list-agents.js +2 -2
  38. package/dist/cli/commands/session-commands.js +16 -16
  39. package/dist/cli/commands/setup.d.ts +13 -5
  40. package/dist/cli/commands/setup.d.ts.map +1 -1
  41. package/dist/cli/commands/setup.js +860 -65
  42. package/dist/cli/commands/which.js +1 -1
  43. package/dist/cli/ink-cli/components/ApprovalPrompt.d.ts +2 -0
  44. package/dist/cli/ink-cli/components/ApprovalPrompt.d.ts.map +1 -1
  45. package/dist/cli/ink-cli/components/ApprovalPrompt.js +29 -7
  46. package/dist/cli/ink-cli/components/CustomInput.js +1 -1
  47. package/dist/cli/ink-cli/components/EditableMultiLineInput.js +4 -4
  48. package/dist/cli/ink-cli/components/ElicitationForm.d.ts.map +1 -1
  49. package/dist/cli/ink-cli/components/ElicitationForm.js +6 -6
  50. package/dist/cli/ink-cli/components/ErrorBoundary.d.ts.map +1 -1
  51. package/dist/cli/ink-cli/components/ErrorBoundary.js +1 -1
  52. package/dist/cli/ink-cli/components/Footer.d.ts.map +1 -1
  53. package/dist/cli/ink-cli/components/Footer.js +1 -1
  54. package/dist/cli/ink-cli/components/HistorySearchBar.d.ts.map +1 -1
  55. package/dist/cli/ink-cli/components/HistorySearchBar.js +1 -1
  56. package/dist/cli/ink-cli/components/MultiLineInput.d.ts.map +1 -1
  57. package/dist/cli/ink-cli/components/MultiLineInput.js +3 -3
  58. package/dist/cli/ink-cli/components/ResourceAutocomplete.d.ts.map +1 -1
  59. package/dist/cli/ink-cli/components/ResourceAutocomplete.js +4 -4
  60. package/dist/cli/ink-cli/components/SlashCommandAutocomplete.js +3 -3
  61. package/dist/cli/ink-cli/components/StatusBar.d.ts.map +1 -1
  62. package/dist/cli/ink-cli/components/StatusBar.js +7 -5
  63. package/dist/cli/ink-cli/components/TextBufferInput.d.ts.map +1 -1
  64. package/dist/cli/ink-cli/components/TextBufferInput.js +6 -6
  65. package/dist/cli/ink-cli/components/base/BaseAutocomplete.js +4 -4
  66. package/dist/cli/ink-cli/components/base/BaseSelector.js +2 -2
  67. package/dist/cli/ink-cli/components/chat/Footer.js +1 -1
  68. package/dist/cli/ink-cli/components/chat/Header.d.ts.map +1 -1
  69. package/dist/cli/ink-cli/components/chat/Header.js +2 -4
  70. package/dist/cli/ink-cli/components/chat/MessageItem.d.ts.map +1 -1
  71. package/dist/cli/ink-cli/components/chat/MessageItem.js +5 -5
  72. package/dist/cli/ink-cli/components/chat/MessageList.js +1 -1
  73. package/dist/cli/ink-cli/components/chat/QueuedMessagesDisplay.js +1 -1
  74. package/dist/cli/ink-cli/components/chat/ToolIcon.d.ts +1 -1
  75. package/dist/cli/ink-cli/components/chat/ToolIcon.js +4 -4
  76. package/dist/cli/ink-cli/components/chat/styled-boxes/ConfigBox.js +1 -1
  77. package/dist/cli/ink-cli/components/chat/styled-boxes/HelpBox.js +1 -1
  78. package/dist/cli/ink-cli/components/chat/styled-boxes/LogConfigBox.js +2 -2
  79. package/dist/cli/ink-cli/components/chat/styled-boxes/SessionHistoryBox.js +5 -5
  80. package/dist/cli/ink-cli/components/chat/styled-boxes/SessionListBox.js +2 -2
  81. package/dist/cli/ink-cli/components/chat/styled-boxes/ShortcutsBox.js +1 -1
  82. package/dist/cli/ink-cli/components/chat/styled-boxes/StatsBox.js +1 -1
  83. package/dist/cli/ink-cli/components/chat/styled-boxes/StyledBox.js +2 -2
  84. package/dist/cli/ink-cli/components/modes/AlternateBufferCLI.d.ts.map +1 -1
  85. package/dist/cli/ink-cli/components/modes/AlternateBufferCLI.js +1 -1
  86. package/dist/cli/ink-cli/components/modes/StaticCLI.d.ts.map +1 -1
  87. package/dist/cli/ink-cli/components/modes/StaticCLI.js +1 -1
  88. package/dist/cli/ink-cli/components/overlays/ApiKeyInput.js +1 -1
  89. package/dist/cli/ink-cli/components/overlays/CustomModelWizard.d.ts +10 -2
  90. package/dist/cli/ink-cli/components/overlays/CustomModelWizard.d.ts.map +1 -1
  91. package/dist/cli/ink-cli/components/overlays/CustomModelWizard.js +198 -89
  92. package/dist/cli/ink-cli/components/overlays/LogLevelSelector.d.ts.map +1 -1
  93. package/dist/cli/ink-cli/components/overlays/LogLevelSelector.js +2 -2
  94. package/dist/cli/ink-cli/components/overlays/McpAddChoice.d.ts.map +1 -1
  95. package/dist/cli/ink-cli/components/overlays/McpAddChoice.js +1 -1
  96. package/dist/cli/ink-cli/components/overlays/McpAddSelector.js +1 -1
  97. package/dist/cli/ink-cli/components/overlays/McpCustomTypeSelector.d.ts.map +1 -1
  98. package/dist/cli/ink-cli/components/overlays/McpCustomTypeSelector.js +2 -2
  99. package/dist/cli/ink-cli/components/overlays/McpCustomWizard.js +1 -1
  100. package/dist/cli/ink-cli/components/overlays/McpRemoveSelector.d.ts.map +1 -1
  101. package/dist/cli/ink-cli/components/overlays/McpRemoveSelector.js +1 -1
  102. package/dist/cli/ink-cli/components/overlays/McpSelector.d.ts.map +1 -1
  103. package/dist/cli/ink-cli/components/overlays/McpSelector.js +1 -1
  104. package/dist/cli/ink-cli/components/overlays/McpServerActions.d.ts.map +1 -1
  105. package/dist/cli/ink-cli/components/overlays/McpServerActions.js +2 -2
  106. package/dist/cli/ink-cli/components/overlays/McpServerList.d.ts.map +1 -1
  107. package/dist/cli/ink-cli/components/overlays/McpServerList.js +1 -1
  108. package/dist/cli/ink-cli/components/overlays/ModelSelectorRefactored.d.ts +5 -5
  109. package/dist/cli/ink-cli/components/overlays/ModelSelectorRefactored.d.ts.map +1 -1
  110. package/dist/cli/ink-cli/components/overlays/ModelSelectorRefactored.js +222 -68
  111. package/dist/cli/ink-cli/components/overlays/PromptAddChoice.d.ts.map +1 -1
  112. package/dist/cli/ink-cli/components/overlays/PromptAddChoice.js +2 -2
  113. package/dist/cli/ink-cli/components/overlays/PromptAddWizard.js +1 -1
  114. package/dist/cli/ink-cli/components/overlays/PromptDeleteSelector.d.ts.map +1 -1
  115. package/dist/cli/ink-cli/components/overlays/PromptDeleteSelector.js +2 -2
  116. package/dist/cli/ink-cli/components/overlays/PromptList.d.ts.map +1 -1
  117. package/dist/cli/ink-cli/components/overlays/PromptList.js +2 -2
  118. package/dist/cli/ink-cli/components/overlays/SearchOverlay.d.ts.map +1 -1
  119. package/dist/cli/ink-cli/components/overlays/SearchOverlay.js +4 -4
  120. package/dist/cli/ink-cli/components/overlays/SessionSubcommandSelector.d.ts.map +1 -1
  121. package/dist/cli/ink-cli/components/overlays/SessionSubcommandSelector.js +1 -1
  122. package/dist/cli/ink-cli/components/overlays/StreamSelector.d.ts.map +1 -1
  123. package/dist/cli/ink-cli/components/overlays/StreamSelector.js +1 -1
  124. package/dist/cli/ink-cli/components/overlays/ToolBrowser.js +12 -12
  125. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/LocalModelWizard.d.ts +25 -0
  126. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/LocalModelWizard.d.ts.map +1 -0
  127. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/LocalModelWizard.js +609 -0
  128. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/index.d.ts +15 -0
  129. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/index.d.ts.map +1 -0
  130. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/index.js +14 -0
  131. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/provider-config.d.ts +33 -0
  132. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/provider-config.d.ts.map +1 -0
  133. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/provider-config.js +419 -0
  134. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/shared/ApiKeyStep.d.ts +25 -0
  135. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/shared/ApiKeyStep.d.ts.map +1 -0
  136. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/shared/ApiKeyStep.js +29 -0
  137. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/shared/ProviderSelector.d.ts +17 -0
  138. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/shared/ProviderSelector.d.ts.map +1 -0
  139. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/shared/ProviderSelector.js +11 -0
  140. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/shared/SetupInfoBanner.d.ts +20 -0
  141. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/shared/SetupInfoBanner.d.ts.map +1 -0
  142. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/shared/SetupInfoBanner.js +10 -0
  143. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/shared/WizardStepInput.d.ts +30 -0
  144. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/shared/WizardStepInput.d.ts.map +1 -0
  145. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/shared/WizardStepInput.js +13 -0
  146. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/shared/index.d.ts +8 -0
  147. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/shared/index.d.ts.map +1 -0
  148. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/shared/index.js +7 -0
  149. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/types.d.ts +79 -0
  150. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/types.d.ts.map +1 -0
  151. package/dist/cli/ink-cli/components/overlays/custom-model-wizard/types.js +38 -0
  152. package/dist/cli/ink-cli/components/renderers/DiffRenderer.js +2 -2
  153. package/dist/cli/ink-cli/components/renderers/FilePreviewRenderer.js +1 -1
  154. package/dist/cli/ink-cli/components/renderers/FileRenderer.js +4 -4
  155. package/dist/cli/ink-cli/components/renderers/GenericRenderer.js +2 -2
  156. package/dist/cli/ink-cli/components/renderers/SearchRenderer.js +1 -1
  157. package/dist/cli/ink-cli/components/renderers/ShellRenderer.js +3 -3
  158. package/dist/cli/ink-cli/components/renderers/diff-shared.js +1 -1
  159. package/dist/cli/ink-cli/components/shared/MarkdownText.d.ts.map +1 -1
  160. package/dist/cli/ink-cli/components/shared/MarkdownText.js +8 -6
  161. package/dist/cli/ink-cli/containers/InputContainer.d.ts.map +1 -1
  162. package/dist/cli/ink-cli/containers/InputContainer.js +23 -1
  163. package/dist/cli/ink-cli/containers/OverlayContainer.d.ts.map +1 -1
  164. package/dist/cli/ink-cli/containers/OverlayContainer.js +80 -24
  165. package/dist/cli/ink-cli/hooks/useAgentEvents.d.ts +1 -1
  166. package/dist/cli/ink-cli/hooks/useAgentEvents.d.ts.map +1 -1
  167. package/dist/cli/ink-cli/hooks/useAgentEvents.js +5 -1
  168. package/dist/cli/ink-cli/hooks/useCLIState.d.ts +1 -1
  169. package/dist/cli/ink-cli/hooks/useCLIState.d.ts.map +1 -1
  170. package/dist/cli/ink-cli/hooks/useCLIState.js +4 -2
  171. package/dist/cli/ink-cli/services/processStream.d.ts.map +1 -1
  172. package/dist/cli/ink-cli/services/processStream.js +77 -9
  173. package/dist/cli/ink-cli/state/types.d.ts +3 -2
  174. package/dist/cli/ink-cli/state/types.d.ts.map +1 -1
  175. package/dist/cli/ink-cli/utils/messageFormatting.d.ts +5 -0
  176. package/dist/cli/ink-cli/utils/messageFormatting.d.ts.map +1 -1
  177. package/dist/cli/ink-cli/utils/messageFormatting.js +59 -1
  178. package/dist/cli/ink-cli/utils/toolUtils.d.ts.map +1 -1
  179. package/dist/cli/ink-cli/utils/toolUtils.js +2 -0
  180. package/dist/cli/utils/api-key-setup.d.ts +54 -4
  181. package/dist/cli/utils/api-key-setup.d.ts.map +1 -1
  182. package/dist/cli/utils/api-key-setup.js +433 -107
  183. package/dist/cli/utils/api-key-verification.d.ts +17 -0
  184. package/dist/cli/utils/api-key-verification.d.ts.map +1 -0
  185. package/dist/cli/utils/api-key-verification.js +211 -0
  186. package/dist/cli/utils/config-validation.d.ts +22 -2
  187. package/dist/cli/utils/config-validation.d.ts.map +1 -1
  188. package/dist/cli/utils/config-validation.js +354 -25
  189. package/dist/cli/utils/local-model-setup.d.ts +46 -0
  190. package/dist/cli/utils/local-model-setup.d.ts.map +1 -0
  191. package/dist/cli/utils/local-model-setup.js +662 -0
  192. package/dist/cli/utils/options.js +1 -1
  193. package/dist/cli/utils/prompt-helpers.d.ts +47 -0
  194. package/dist/cli/utils/prompt-helpers.d.ts.map +1 -0
  195. package/dist/cli/utils/prompt-helpers.js +66 -0
  196. package/dist/cli/utils/provider-setup.d.ts +66 -8
  197. package/dist/cli/utils/provider-setup.d.ts.map +1 -1
  198. package/dist/cli/utils/provider-setup.js +324 -84
  199. package/dist/cli/utils/scaffolding-utils.d.ts +76 -0
  200. package/dist/cli/utils/scaffolding-utils.d.ts.map +1 -0
  201. package/dist/cli/utils/scaffolding-utils.js +246 -0
  202. package/dist/cli/utils/setup-utils.d.ts +16 -0
  203. package/dist/cli/utils/setup-utils.d.ts.map +1 -1
  204. package/dist/cli/utils/setup-utils.js +72 -21
  205. package/dist/cli/utils/template-engine.d.ts +65 -0
  206. package/dist/cli/utils/template-engine.d.ts.map +1 -0
  207. package/dist/cli/utils/template-engine.js +1089 -0
  208. package/dist/config/cli-overrides.d.ts +44 -1
  209. package/dist/config/cli-overrides.d.ts.map +1 -1
  210. package/dist/config/cli-overrides.js +102 -0
  211. package/dist/index.js +315 -53
  212. package/dist/webui/assets/index-8j-KMkX1.js +2054 -0
  213. package/dist/webui/assets/index-c_AX24V4.css +1 -0
  214. package/dist/webui/index.html +3 -9
  215. package/dist/webui/logos/aws-color.svg +1 -0
  216. package/dist/webui/logos/dexto/dexto_logo.svg +1 -1
  217. package/dist/webui/logos/dexto/dexto_logo_light.svg +6 -6
  218. package/dist/webui/logos/glama.svg +7 -0
  219. package/dist/webui/logos/litellm.svg +7 -0
  220. package/dist/webui/logos/openrouter.svg +1 -0
  221. package/package.json +8 -7
  222. package/dist/webui/assets/index-BkwPkZpd.css +0 -1
  223. package/dist/webui/assets/index-D9u1XfyH.js +0 -2025
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Creates a Dexto image project - a distributable agent harness package
3
+ * @param name - Optional name of the image project
4
+ * @returns The absolute path to the created project directory
5
+ */
6
+ export declare function createImage(name?: string): Promise<string>;
7
+ //# sourceMappingURL=create-image.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create-image.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/create-image.ts"],"names":[],"mappings":"AAsBA;;;;GAIG;AACH,wBAAsB,WAAW,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAkPhE"}
@@ -0,0 +1,201 @@
1
+ import path from 'path';
2
+ import * as p from '@clack/prompts';
3
+ import chalk from 'chalk';
4
+ import { selectOrExit, textOrExit, confirmOrExit } from '../utils/prompt-helpers.js';
5
+ import { promptForProjectName, createProjectDirectory, setupGitRepo, createGitignore, initPackageJson, createTsconfigForImage, installDependencies, ensureDirectory, } from '../utils/scaffolding-utils.js';
6
+ import { generateDextoImageFile, generateImageReadme, generateExampleTool, } from '../utils/template-engine.js';
7
+ import fs from 'fs-extra';
8
+ import { getExecutionContext } from '@dexto/agent-management';
9
+ /**
10
+ * Creates a Dexto image project - a distributable agent harness package
11
+ * @param name - Optional name of the image project
12
+ * @returns The absolute path to the created project directory
13
+ */
14
+ export async function createImage(name) {
15
+ console.log(chalk.blue('šŸŽØ Creating a Dexto image - a distributable agent harness package\n'));
16
+ // Step 1: Get project name
17
+ const projectName = name
18
+ ? name
19
+ : await promptForProjectName('my-dexto-image', 'What do you want to name your image?');
20
+ // Step 2: Get description
21
+ const description = await textOrExit({
22
+ message: 'Describe your image:',
23
+ placeholder: 'Custom agent harness for my organization',
24
+ defaultValue: 'Custom agent harness for my organization',
25
+ }, 'Image creation cancelled');
26
+ // Step 3: Starting point - new base or extend existing
27
+ const startingPoint = await selectOrExit({
28
+ message: 'Starting point:',
29
+ options: [
30
+ { value: 'base', label: 'New base image (build from scratch)' },
31
+ { value: 'extend', label: 'Extend existing image (add providers to base)' },
32
+ ],
33
+ }, 'Image creation cancelled');
34
+ let baseImage;
35
+ if (startingPoint === 'extend') {
36
+ // Step 4: Which image to extend?
37
+ const baseImageChoice = await selectOrExit({
38
+ message: 'Which image to extend?',
39
+ options: [
40
+ {
41
+ value: '@dexto/image-local',
42
+ label: '@dexto/image-local (local development)',
43
+ },
44
+ { value: '@dexto/image-cloud', label: '@dexto/image-cloud (cloud production)' },
45
+ { value: '@dexto/image-edge', label: '@dexto/image-edge (edge/serverless)' },
46
+ { value: 'custom', label: 'Custom npm package...' },
47
+ ],
48
+ }, 'Image creation cancelled');
49
+ if (baseImageChoice === 'custom') {
50
+ const customBase = await textOrExit({
51
+ message: 'Enter the npm package name:',
52
+ placeholder: '@myorg/image-base',
53
+ validate: (value) => {
54
+ if (!value || value.trim() === '') {
55
+ return 'Package name is required';
56
+ }
57
+ return undefined;
58
+ },
59
+ }, 'Image creation cancelled');
60
+ baseImage = customBase;
61
+ }
62
+ else {
63
+ baseImage = baseImageChoice;
64
+ }
65
+ }
66
+ // Step 5: Target environment
67
+ const target = await selectOrExit({
68
+ message: 'Target environment:',
69
+ options: [
70
+ { value: 'local-development', label: 'Local development' },
71
+ { value: 'cloud-production', label: 'Cloud production' },
72
+ { value: 'edge-serverless', label: 'Edge/serverless' },
73
+ { value: 'custom', label: 'Custom' },
74
+ ],
75
+ }, 'Image creation cancelled');
76
+ // Step 6: Include example providers?
77
+ const includeExamples = await confirmOrExit({
78
+ message: 'Include example tool provider?',
79
+ initialValue: true,
80
+ }, 'Image creation cancelled');
81
+ // Start scaffolding
82
+ const spinner = p.spinner();
83
+ let projectPath;
84
+ try {
85
+ // Save original cwd before changing directories (for resolving relative paths)
86
+ const originalCwd = process.cwd();
87
+ // Create project directory
88
+ projectPath = await createProjectDirectory(projectName, spinner);
89
+ // Change to project directory
90
+ process.chdir(projectPath);
91
+ spinner.start('Setting up project structure...');
92
+ // Create convention-based folders
93
+ await ensureDirectory('tools');
94
+ await ensureDirectory('blob-store');
95
+ await ensureDirectory('compression');
96
+ await ensureDirectory('plugins');
97
+ // Create .gitkeep files for empty directories
98
+ await fs.writeFile('blob-store/.gitkeep', '');
99
+ await fs.writeFile('compression/.gitkeep', '');
100
+ await fs.writeFile('plugins/.gitkeep', '');
101
+ // Create example tool if requested
102
+ if (includeExamples) {
103
+ await ensureDirectory('tools/example-tool');
104
+ const exampleToolCode = generateExampleTool('example-tool');
105
+ await fs.writeFile('tools/example-tool/index.ts', exampleToolCode);
106
+ }
107
+ else {
108
+ await fs.writeFile('tools/.gitkeep', '');
109
+ }
110
+ spinner.message('Generating configuration files...');
111
+ // Create dexto.image.ts
112
+ const dextoImageContent = generateDextoImageFile({
113
+ projectName,
114
+ packageName: projectName,
115
+ description,
116
+ imageName: projectName,
117
+ ...(baseImage ? { baseImage } : {}),
118
+ target,
119
+ });
120
+ await fs.writeFile('dexto.image.ts', dextoImageContent);
121
+ // Create package.json
122
+ await initPackageJson(projectPath, projectName, 'image');
123
+ // Update package.json with build script
124
+ const packageJsonPath = path.join(projectPath, 'package.json');
125
+ const packageJson = JSON.parse(await fs.readFile(packageJsonPath, 'utf8'));
126
+ packageJson.scripts = {
127
+ build: 'dexto-bundle build',
128
+ typecheck: 'tsc --noEmit',
129
+ ...packageJson.scripts,
130
+ };
131
+ await fs.writeFile(packageJsonPath, JSON.stringify(packageJson, null, 2));
132
+ // Create tsconfig.json
133
+ await createTsconfigForImage(projectPath);
134
+ // Create README
135
+ const readmeContent = generateImageReadme({
136
+ projectName,
137
+ packageName: projectName,
138
+ description,
139
+ imageName: projectName,
140
+ ...(baseImage ? { baseImage } : {}),
141
+ });
142
+ await fs.writeFile('README.md', readmeContent);
143
+ // Create .gitignore
144
+ await createGitignore(projectPath, ['*.tsbuildinfo']);
145
+ // Initialize git
146
+ spinner.message('Initializing git repository...');
147
+ await setupGitRepo(projectPath);
148
+ spinner.message('Installing dependencies...');
149
+ // Detect if we're in dexto source - use workspace protocol for local development
150
+ const executionContext = getExecutionContext();
151
+ const isDextoSource = executionContext === 'dexto-source';
152
+ const coreVersion = isDextoSource ? 'workspace:*' : '^1.3.0';
153
+ const bundlerVersion = isDextoSource ? 'workspace:*' : '^1.3.0';
154
+ // Determine dependencies based on whether extending
155
+ const dependencies = [`@dexto/core@${coreVersion}`, 'zod'];
156
+ const devDependencies = [
157
+ 'typescript@^5.0.0',
158
+ '@types/node@^20.0.0',
159
+ `@dexto/image-bundler@${bundlerVersion}`,
160
+ ];
161
+ if (baseImage) {
162
+ // Resolve base image path if we're in dexto source
163
+ let resolvedBaseImage = baseImage;
164
+ if (isDextoSource && baseImage.startsWith('@dexto/image-')) {
165
+ // In dexto source, resolve official images to local workspace packages
166
+ // e.g., @dexto/image-local -> packages/image-local
167
+ const imagePkgName = baseImage.replace('@dexto/', '');
168
+ const imagePkgPath = path.resolve(originalCwd, 'packages', imagePkgName);
169
+ if (await fs.pathExists(imagePkgPath)) {
170
+ resolvedBaseImage = imagePkgPath;
171
+ }
172
+ }
173
+ dependencies.push(resolvedBaseImage);
174
+ }
175
+ // Install dependencies (use pnpm in dexto source for workspace protocol support)
176
+ await installDependencies(projectPath, {
177
+ dependencies,
178
+ devDependencies,
179
+ }, isDextoSource ? 'pnpm' : undefined);
180
+ spinner.stop(chalk.green(`āœ“ Successfully created image: ${projectName}`));
181
+ console.log(`\n${chalk.cyan('Next steps:')}`);
182
+ console.log(` ${chalk.gray('$')} cd ${projectName}`);
183
+ console.log(` ${chalk.gray('$')} pnpm run build`);
184
+ console.log(`\n${chalk.gray('Add your custom providers to the convention-based folders:')}`);
185
+ console.log(` ${chalk.gray('tools/')} - Custom tool providers`);
186
+ console.log(` ${chalk.gray('blob-store/')} - Blob storage providers`);
187
+ console.log(` ${chalk.gray('compression/')} - Compression strategies`);
188
+ console.log(` ${chalk.gray('plugins/')} - Plugin providers`);
189
+ console.log(`\n${chalk.gray('Learn more:')} https://docs.dexto.ai/docs/guides/images\n`);
190
+ }
191
+ catch (error) {
192
+ if (spinner) {
193
+ spinner.stop(chalk.red('āœ— Failed to create image'));
194
+ }
195
+ throw error;
196
+ }
197
+ if (!projectPath) {
198
+ throw new Error('Failed to create project directory');
199
+ }
200
+ return projectPath;
201
+ }
@@ -18,9 +18,9 @@ export function formatSessionInfo(sessionId, metadata, isCurrent = false) {
18
18
  const activity = metadata.lastActivity && metadata.lastActivity > 0
19
19
  ? new Date(metadata.lastActivity).toLocaleString()
20
20
  : 'Never';
21
- info += chalk.dim(` (${messages} messages, last: ${activity})`);
21
+ info += chalk.gray(` (${messages} messages, last: ${activity})`);
22
22
  if (isCurrent) {
23
- info += chalk.yellow(' [ACTIVE]');
23
+ info += chalk.rgb(255, 165, 0)(' [ACTIVE]');
24
24
  }
25
25
  }
26
26
  return info;
@@ -32,7 +32,7 @@ export function formatHistoryMessage(message, index) {
32
32
  const timestamp = message.timestamp
33
33
  ? new Date(message.timestamp).toLocaleTimeString()
34
34
  : `#${index + 1}`;
35
- let roleColor = chalk.dim;
35
+ let roleColor = chalk.gray;
36
36
  let displayLabel = message.role;
37
37
  switch (message.role) {
38
38
  case 'user':
@@ -44,11 +44,11 @@ export function formatHistoryMessage(message, index) {
44
44
  displayLabel = 'Assistant';
45
45
  break;
46
46
  case 'system':
47
- roleColor = chalk.yellow;
47
+ roleColor = chalk.rgb(255, 165, 0);
48
48
  displayLabel = 'System';
49
49
  break;
50
50
  case 'tool':
51
- roleColor = chalk.magenta;
51
+ roleColor = chalk.green;
52
52
  displayLabel = 'Tool';
53
53
  break;
54
54
  }
@@ -87,7 +87,7 @@ export function formatHistoryMessage(message, index) {
87
87
  const toolNames = message.toolCalls
88
88
  .map((tc) => tc.function?.name || 'unknown')
89
89
  .join(', ');
90
- toolInfo = chalk.dim(` [Tools: ${toolNames}]`);
90
+ toolInfo = chalk.gray(` [Tools: ${toolNames}]`);
91
91
  }
92
- return ` ${chalk.dim(timestamp)} ${roleColor.bold(displayLabel)}: ${content}${toolInfo}`;
92
+ return ` ${chalk.gray(timestamp)} ${roleColor.bold(displayLabel)}: ${content}${toolInfo}`;
93
93
  }
@@ -1,4 +1,5 @@
1
- export { createDextoProject, createTsconfigJson, addDextoScriptsToPackageJson, postCreateDexto, } from './create-app.js';
1
+ export { createDextoProject, type CreateAppOptions } from './create-app.js';
2
+ export { createImage } from './create-image.js';
2
3
  export { getUserInputToInitDextoApp, initDexto, postInitDexto } from './init-app.js';
3
4
  export { handleSetupCommand, type CLISetupOptions, type CLISetupOptionsInput } from './setup.js';
4
5
  export { handleInstallCommand, type InstallCommandOptions } from './install.js';
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/index.ts"],"names":[],"mappings":"AAGA,OAAO,EACH,kBAAkB,EAClB,kBAAkB,EAClB,4BAA4B,EAC5B,eAAe,GAClB,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EAAE,0BAA0B,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAErF,OAAO,EAAE,kBAAkB,EAAE,KAAK,eAAe,EAAE,KAAK,oBAAoB,EAAE,MAAM,YAAY,CAAC;AACjG,OAAO,EAAE,oBAAoB,EAAE,KAAK,qBAAqB,EAAE,MAAM,cAAc,CAAC;AAChF,OAAO,EAAE,sBAAsB,EAAE,KAAK,uBAAuB,EAAE,MAAM,gBAAgB,CAAC;AACtF,OAAO,EACH,uBAAuB,EACvB,KAAK,wBAAwB,EAC7B,KAAK,6BAA6B,GACrC,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,kBAAkB,EAAE,KAAK,mBAAmB,EAAE,MAAM,YAAY,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/index.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,kBAAkB,EAAE,KAAK,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAE5E,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,OAAO,EAAE,0BAA0B,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;AAErF,OAAO,EAAE,kBAAkB,EAAE,KAAK,eAAe,EAAE,KAAK,oBAAoB,EAAE,MAAM,YAAY,CAAC;AACjG,OAAO,EAAE,oBAAoB,EAAE,KAAK,qBAAqB,EAAE,MAAM,cAAc,CAAC;AAChF,OAAO,EAAE,sBAAsB,EAAE,KAAK,uBAAuB,EAAE,MAAM,gBAAgB,CAAC;AACtF,OAAO,EACH,uBAAuB,EACvB,KAAK,wBAAwB,EAC7B,KAAK,6BAA6B,GACrC,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,kBAAkB,EAAE,KAAK,mBAAmB,EAAE,MAAM,YAAY,CAAC"}
@@ -1,6 +1,7 @@
1
1
  // packages/cli/src/cli/commands/index.ts
2
2
  // Project setup commands
3
- export { createDextoProject, createTsconfigJson, addDextoScriptsToPackageJson, postCreateDexto, } from './create-app.js';
3
+ export { createDextoProject } from './create-app.js';
4
+ export { createImage } from './create-image.js';
4
5
  export { getUserInputToInitDextoApp, initDexto, postInitDexto } from './init-app.js';
5
6
  export { handleSetupCommand } from './setup.js';
6
7
  export { handleInstallCommand } from './install.js';
@@ -103,7 +103,7 @@ export async function initDexto(directory, createExampleFile = true, llmProvider
103
103
  installError instanceof Error &&
104
104
  /\bERR_PNPM_ADDING_TO_ROOT\b/.test(installError.message)) {
105
105
  spinner.stop(chalk.red('Error: Cannot install in pnpm workspace root'));
106
- p.note('You are initializing dexto in a pnpm workspace root. Go to a specific workspace package and run "pnpm add @dexto/core" there.', chalk.yellow('Workspace Error'));
106
+ p.note('You are initializing dexto in a pnpm workspace root. Go to a specific workspace package and run "pnpm add @dexto/core" there.', chalk.rgb(255, 165, 0)('Workspace Error'));
107
107
  process.exit(1);
108
108
  }
109
109
  throw installError; // Re-throw other errors
@@ -135,7 +135,7 @@ export async function initDexto(directory, createExampleFile = true, llmProvider
135
135
  catch (configError) {
136
136
  spinner.stop(chalk.red('Failed to create agent config file'));
137
137
  logger.error(`Config creation error: ${configError}`);
138
- throw new Error(`Failed to create default-agent.yml: ${configError instanceof Error ? configError.message : String(configError)}`);
138
+ throw new Error(`Failed to create coding-agent.yml: ${configError instanceof Error ? configError.message : String(configError)}`);
139
139
  }
140
140
  // update dexto config file based on llmProvider
141
141
  if (llmProvider) {
@@ -168,11 +168,11 @@ export async function postInitDexto(directory) {
168
168
  const nextSteps = [
169
169
  `1. Run the example: ${chalk.cyan(`node --loader ts-node/esm ${path.join(directory, 'dexto', 'dexto-example.ts')}`)}`,
170
170
  `2. Add/update your API key(s) in ${chalk.cyan('.env')}`,
171
- `3. Check out the agent configuration file ${chalk.cyan(path.join(directory, 'dexto', 'agents', 'default-agent.yml'))}`,
172
- `4. Try out different LLMs and MCP servers in the default-agent.yml file`,
171
+ `3. Check out the agent configuration file ${chalk.cyan(path.join(directory, 'dexto', 'agents', 'coding-agent.yml'))}`,
172
+ `4. Try out different LLMs and MCP servers in the coding-agent.yml file`,
173
173
  `5. Read more about Dexto: ${chalk.cyan('https://github.com/truffle-ai/dexto')}`,
174
174
  ].join('\n');
175
- p.note(nextSteps, chalk.yellow('Next steps:'));
175
+ p.note(nextSteps, chalk.rgb(255, 165, 0)('Next steps:'));
176
176
  }
177
177
  /**
178
178
  * Creates the dexto directories (dexto, dexto/agents) in the given directory.
@@ -215,7 +215,7 @@ export async function createDextoConfigFile(directory) {
215
215
  throw new Error(`Template file not found at: ${templateConfigSrc}. This indicates a build issue - the template should be included in the package.`);
216
216
  }
217
217
  // Path to the destination config file
218
- const destConfigPath = path.join(directory, 'default-agent.yml');
218
+ const destConfigPath = path.join(directory, 'coding-agent.yml');
219
219
  logger.debug(`Copying template to: ${destConfigPath}`);
220
220
  // Copy the config file from the Dexto package
221
221
  await fsExtra.copy(templateConfigSrc, destConfigPath);
@@ -235,7 +235,7 @@ export async function createDextoConfigFile(directory) {
235
235
  export async function createDextoExampleFile(directory) {
236
236
  // Extract the base directory from the given path (e.g., "src" from "src/dexto")
237
237
  const baseDir = path.dirname(directory);
238
- const configPath = `./${path.posix.join(baseDir, 'dexto/agents/default-agent.yml')}`;
238
+ const configPath = `./${path.posix.join(baseDir, 'dexto/agents/coding-agent.yml')}`;
239
239
  const indexTsLines = [
240
240
  "import 'dotenv/config';",
241
241
  "import { DextoAgent, loadAgentConfig } from '@dexto/core';",
@@ -2,18 +2,15 @@ import { z } from 'zod';
2
2
  declare const InstallCommandSchema: z.ZodObject<{
3
3
  agents: z.ZodArray<z.ZodString, "many">;
4
4
  all: z.ZodDefault<z.ZodBoolean>;
5
- injectPreferences: z.ZodDefault<z.ZodBoolean>;
6
5
  force: z.ZodDefault<z.ZodBoolean>;
7
6
  }, "strict", z.ZodTypeAny, {
8
7
  all: boolean;
9
8
  agents: string[];
10
9
  force: boolean;
11
- injectPreferences: boolean;
12
10
  }, {
13
11
  agents: string[];
14
12
  all?: boolean | undefined;
15
13
  force?: boolean | undefined;
16
- injectPreferences?: boolean | undefined;
17
14
  }>;
18
15
  export type InstallCommandOptions = z.output<typeof InstallCommandSchema>;
19
16
  export declare function handleInstallCommand(agents: string[], options: Partial<InstallCommandOptions>): Promise<void>;
@@ -1 +1 @@
1
- {"version":3,"file":"install.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/install.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAOxB,QAAA,MAAM,oBAAoB;;;;;;;;;;;;;;;EAOb,CAAC;AAEd,MAAM,MAAM,qBAAqB,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,oBAAoB,CAAC,CAAC;AAgL1E,wBAAsB,oBAAoB,CACtC,MAAM,EAAE,MAAM,EAAE,EAChB,OAAO,EAAE,OAAO,CAAC,qBAAqB,CAAC,GACxC,OAAO,CAAC,IAAI,CAAC,CAqLf"}
1
+ {"version":3,"file":"install.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/install.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAQxB,QAAA,MAAM,oBAAoB;;;;;;;;;;;;EAMb,CAAC;AAEd,MAAM,MAAM,qBAAqB,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,oBAAoB,CAAC,CAAC;AAwK1E,wBAAsB,oBAAoB,CACtC,MAAM,EAAE,MAAM,EAAE,EAChB,OAAO,EAAE,OAAO,CAAC,qBAAqB,CAAC,GACxC,OAAO,CAAC,IAAI,CAAC,CAuKf"}
@@ -4,6 +4,7 @@ import path from 'path';
4
4
  import { z } from 'zod';
5
5
  import * as p from '@clack/prompts';
6
6
  import { getDextoGlobalPath, loadBundledRegistryAgents } from '@dexto/agent-management';
7
+ import { textOrExit } from '../utils/prompt-helpers.js';
7
8
  import { installBundledAgent, installCustomAgent } from '../../utils/agent-helpers.js';
8
9
  import { capture } from '../../analytics/index.js';
9
10
  // Zod schema for install command validation
@@ -11,7 +12,6 @@ const InstallCommandSchema = z
11
12
  .object({
12
13
  agents: z.array(z.string().min(1, 'Agent name cannot be empty')),
13
14
  all: z.boolean().default(false),
14
- injectPreferences: z.boolean().default(true),
15
15
  force: z.boolean().default(false),
16
16
  })
17
17
  .strict();
@@ -54,7 +54,7 @@ function extractAgentNameFromPath(filePath) {
54
54
  */
55
55
  async function promptForMetadata(suggestedName) {
56
56
  p.intro('šŸ“ Custom Agent Installation');
57
- const agentName = (await p.text({
57
+ const agentName = await textOrExit({
58
58
  message: 'Agent name:',
59
59
  placeholder: suggestedName,
60
60
  defaultValue: suggestedName,
@@ -67,12 +67,8 @@ async function promptForMetadata(suggestedName) {
67
67
  }
68
68
  return undefined;
69
69
  },
70
- }));
71
- if (p.isCancel(agentName)) {
72
- p.cancel('Installation cancelled');
73
- process.exit(0);
74
- }
75
- const description = (await p.text({
70
+ }, 'Installation cancelled');
71
+ const description = await textOrExit({
76
72
  message: 'Description:',
77
73
  placeholder: 'A custom agent for...',
78
74
  validate: (value) => {
@@ -81,12 +77,8 @@ async function promptForMetadata(suggestedName) {
81
77
  }
82
78
  return undefined;
83
79
  },
84
- }));
85
- if (p.isCancel(description)) {
86
- p.cancel('Installation cancelled');
87
- process.exit(0);
88
- }
89
- const author = (await p.text({
80
+ }, 'Installation cancelled');
81
+ const author = await textOrExit({
90
82
  message: 'Author:',
91
83
  placeholder: 'Your Name',
92
84
  validate: (value) => {
@@ -95,20 +87,12 @@ async function promptForMetadata(suggestedName) {
95
87
  }
96
88
  return undefined;
97
89
  },
98
- }));
99
- if (p.isCancel(author)) {
100
- p.cancel('Installation cancelled');
101
- process.exit(0);
102
- }
103
- const tagsInput = (await p.text({
90
+ }, 'Installation cancelled');
91
+ const tagsInput = await textOrExit({
104
92
  message: 'Tags (comma-separated):',
105
93
  placeholder: 'custom, coding, productivity',
106
94
  defaultValue: 'custom',
107
- }));
108
- if (p.isCancel(tagsInput)) {
109
- p.cancel('Installation cancelled');
110
- process.exit(0);
111
- }
95
+ }, 'Installation cancelled');
112
96
  const tags = tagsInput
113
97
  .split(',')
114
98
  .map((tag) => tag.trim())
@@ -201,7 +185,6 @@ export async function handleInstallCommand(agents, options) {
201
185
  status: 'skipped',
202
186
  reason: 'already_installed',
203
187
  force: validated.force,
204
- injectPreferences: validated.injectPreferences,
205
188
  });
206
189
  continue;
207
190
  }
@@ -211,8 +194,6 @@ export async function handleInstallCommand(agents, options) {
211
194
  description: metadata.description,
212
195
  author: metadata.author,
213
196
  tags: metadata.tags,
214
- }, {
215
- injectPreferences: validated.injectPreferences,
216
197
  });
217
198
  successCount++;
218
199
  console.log(`āœ… ${metadata.agentName} installed successfully`);
@@ -222,7 +203,6 @@ export async function handleInstallCommand(agents, options) {
222
203
  agent: metadata.agentName,
223
204
  status: 'installed',
224
205
  force: validated.force,
225
- injectPreferences: validated.injectPreferences,
226
206
  });
227
207
  }
228
208
  else {
@@ -239,13 +219,10 @@ export async function handleInstallCommand(agents, options) {
239
219
  status: 'skipped',
240
220
  reason: 'already_installed',
241
221
  force: validated.force,
242
- injectPreferences: validated.injectPreferences,
243
222
  });
244
223
  continue;
245
224
  }
246
- await installBundledAgent(agentInput, {
247
- injectPreferences: validated.injectPreferences,
248
- });
225
+ await installBundledAgent(agentInput);
249
226
  successCount++;
250
227
  console.log(`āœ… ${agentInput} installed successfully`);
251
228
  installed.push(agentInput);
@@ -253,7 +230,6 @@ export async function handleInstallCommand(agents, options) {
253
230
  agent: agentInput,
254
231
  status: 'installed',
255
232
  force: validated.force,
256
- injectPreferences: validated.injectPreferences,
257
233
  });
258
234
  }
259
235
  }
@@ -270,7 +246,6 @@ export async function handleInstallCommand(agents, options) {
270
246
  status: 'failed',
271
247
  error_message: error instanceof Error ? error.message : String(error),
272
248
  force: validated.force,
273
- injectPreferences: validated.injectPreferences,
274
249
  });
275
250
  }
276
251
  }
@@ -90,12 +90,12 @@ export function getCommandSuggestions(partial, commands) {
90
90
  export function formatCommandHelp(cmd, detailed = false) {
91
91
  let help = chalk.cyan(`/${cmd.name}`) + ' - ' + cmd.description;
92
92
  if (detailed) {
93
- help += '\n' + chalk.dim(`Usage: ${cmd.usage}`);
93
+ help += '\n' + chalk.gray(`Usage: ${cmd.usage}`);
94
94
  if (cmd.aliases && cmd.aliases.length > 0) {
95
- help += '\n' + chalk.dim(`Aliases: ${cmd.aliases.map((a) => `/${a}`).join(', ')}`);
95
+ help += '\n' + chalk.gray(`Aliases: ${cmd.aliases.map((a) => `/${a}`).join(', ')}`);
96
96
  }
97
97
  if (cmd.subcommands && cmd.subcommands.length > 0) {
98
- help += '\n' + chalk.dim('Subcommands:');
98
+ help += '\n' + chalk.gray('Subcommands:');
99
99
  for (const sub of cmd.subcommands) {
100
100
  help += '\n ' + chalk.cyan(`/${cmd.name} ${sub.name}`) + ' - ' + sub.description;
101
101
  }
@@ -135,7 +135,7 @@ export function displayAllCommands(commands) {
135
135
  for (const category of categoryOrder) {
136
136
  const cmds = categories[category];
137
137
  if (cmds && cmds.length > 0) {
138
- console.log(chalk.bold.yellow(`${category}:`));
138
+ console.log(chalk.bold.rgb(255, 165, 0)(`${category}:`));
139
139
  for (const cmd of cmds) {
140
140
  console.log(' ' + formatCommandHelp(cmd));
141
141
  }
@@ -145,13 +145,13 @@ export function displayAllCommands(commands) {
145
145
  // Display any uncategorized commands (fallback)
146
146
  for (const [category, cmds] of Object.entries(categories)) {
147
147
  if (!categoryOrder.includes(category) && cmds.length > 0) {
148
- console.log(chalk.bold.yellow(`${category}:`));
148
+ console.log(chalk.bold.rgb(255, 165, 0)(`${category}:`));
149
149
  for (const cmd of cmds) {
150
150
  console.log(' ' + formatCommandHelp(cmd));
151
151
  }
152
152
  console.log();
153
153
  }
154
154
  }
155
- console.log(chalk.dim('šŸ’” Tip: Use /help <command> for detailed help on any command'));
156
- console.log(chalk.dim('šŸ’” Tip: Type your message normally (without /) to chat with the AI\n'));
155
+ console.log(chalk.gray('šŸ’” Tip: Use /help <command> for detailed help on any command'));
156
+ console.log(chalk.gray('šŸ’” Tip: Type your message normally (without /) to chat with the AI\n'));
157
157
  }
@@ -54,7 +54,7 @@ export const generalCommands = [
54
54
  category: 'General',
55
55
  aliases: ['quit', 'q'],
56
56
  handler: async (_args, _agent, _ctx) => {
57
- console.log(chalk.yellow('Exiting AI CLI. Goodbye!'));
57
+ console.log(chalk.rgb(255, 165, 0)('Exiting AI CLI. Goodbye!'));
58
58
  process.exit(0);
59
59
  },
60
60
  },
@@ -51,7 +51,7 @@ export const promptCommands = [
51
51
  const promptNames = Object.keys(prompts || {});
52
52
  if (promptNames.length === 0) {
53
53
  const output = '\nāš ļø No prompts available';
54
- console.log(chalk.yellow(output));
54
+ console.log(chalk.rgb(255, 165, 0)(output));
55
55
  return formatForInkCli(output);
56
56
  }
57
57
  // Build output string
@@ -132,20 +132,20 @@ export const promptCommands = [
132
132
  .map((a) => `${a.name}${a.required ? '*' : ''}`)
133
133
  .join(', ')}]`
134
134
  : '';
135
- console.log(` ${chalk.blue(displayName)}${chalk.yellow(title)}${chalk.dim(desc)}${chalk.gray(args)}`);
135
+ console.log(` ${chalk.blue(displayName)}${chalk.rgb(255, 165, 0)(title)}${chalk.gray(desc)}${chalk.gray(args)}`);
136
136
  }
137
137
  });
138
138
  console.log();
139
139
  }
140
140
  if (configPrompts.length > 0) {
141
- console.log(chalk.magenta('šŸ“‹ Config Prompts:'));
141
+ console.log(chalk.cyan('šŸ“‹ Config Prompts:'));
142
142
  configPrompts.forEach((name) => {
143
143
  const info = prompts[name];
144
144
  if (info) {
145
145
  const displayName = info.displayName || name;
146
146
  const title = info.title && info.title !== displayName ? ` (${info.title})` : '';
147
147
  const desc = info.description ? ` - ${info.description}` : '';
148
- console.log(` ${chalk.blue(displayName)}${chalk.yellow(title)}${chalk.dim(desc)}`);
148
+ console.log(` ${chalk.blue(displayName)}${chalk.rgb(255, 165, 0)(title)}${chalk.gray(desc)}`);
149
149
  }
150
150
  });
151
151
  console.log();
@@ -158,13 +158,13 @@ export const promptCommands = [
158
158
  const displayName = info.displayName || name;
159
159
  const title = info.title && info.title !== displayName ? ` (${info.title})` : '';
160
160
  const desc = info.description ? ` - ${info.description}` : '';
161
- console.log(` ${chalk.blue(displayName)}${chalk.yellow(title)}${chalk.dim(desc)}`);
161
+ console.log(` ${chalk.blue(displayName)}${chalk.rgb(255, 165, 0)(title)}${chalk.gray(desc)}`);
162
162
  }
163
163
  });
164
164
  console.log();
165
165
  }
166
- console.log(chalk.dim(`Total: ${promptNames.length} prompts`));
167
- console.log(chalk.dim('šŸ’” Use /<prompt-name> to execute a prompt directly\n'));
166
+ console.log(chalk.gray(`Total: ${promptNames.length} prompts`));
167
+ console.log(chalk.gray('šŸ’” Use /<prompt-name> to execute a prompt directly\n'));
168
168
  return formatForInkCli(output);
169
169
  }
170
170
  catch (error) {
@@ -198,15 +198,15 @@ function createPromptCommand(promptInfo, hasCollision) {
198
198
  const { argMap, context: contextString } = splitPromptArguments(args);
199
199
  if (Object.keys(argMap).length > 0) {
200
200
  console.log(chalk.cyan(`šŸ¤– Executing prompt: ${commandName}`));
201
- console.log(chalk.dim(`Explicit arguments: ${JSON.stringify(argMap)}`));
201
+ console.log(chalk.gray(`Explicit arguments: ${JSON.stringify(argMap)}`));
202
202
  }
203
203
  else if (contextString) {
204
204
  console.log(chalk.cyan(`šŸ¤– Executing prompt: ${commandName}`));
205
- console.log(chalk.dim(`Context: ${contextString} (LLM will extrapolate template variables)`));
205
+ console.log(chalk.gray(`Context: ${contextString} (LLM will extrapolate template variables)`));
206
206
  }
207
207
  else {
208
208
  console.log(chalk.cyan(`šŸ¤– Executing prompt: ${commandName}`));
209
- console.log(chalk.dim('No arguments provided - LLM will extrapolate from context'));
209
+ console.log(chalk.gray('No arguments provided - LLM will extrapolate from context'));
210
210
  }
211
211
  // Use resolvePrompt instead of getPrompt + flattenPromptResult (matches WebUI approach)
212
212
  const resolveOptions = {};
@@ -232,7 +232,7 @@ function createPromptCommand(promptInfo, hasCollision) {
232
232
  }
233
233
  else {
234
234
  const warningMsg = `āš ļø Prompt '${commandName}' returned no content`;
235
- console.log(chalk.yellow(warningMsg));
235
+ console.log(chalk.rgb(255, 165, 0)(warningMsg));
236
236
  return formatForInkCli(warningMsg);
237
237
  }
238
238
  }
@@ -36,14 +36,14 @@ export const systemCommands = [
36
36
  if (logFilePath) {
37
37
  console.log(` Log file: ${chalk.cyan(logFilePath)}`);
38
38
  }
39
- console.log(chalk.dim('\n Available levels (from least to most verbose):'));
39
+ console.log(chalk.gray('\n Available levels (from least to most verbose):'));
40
40
  validLevels.forEach((lvl) => {
41
41
  const isCurrent = lvl === currentLevel;
42
42
  const marker = isCurrent ? chalk.green('ā–¶') : ' ';
43
43
  const levelText = isCurrent ? chalk.green.bold(lvl) : chalk.gray(lvl);
44
44
  console.log(` ${marker} ${levelText}`);
45
45
  });
46
- console.log(chalk.dim('\n šŸ’” Use /log <level> to change level (e.g., /log debug)\n'));
46
+ console.log(chalk.gray('\n šŸ’” Use /log <level> to change level (e.g., /log debug)\n'));
47
47
  const output = [
48
48
  '\nšŸ“Š Logging Configuration:',
49
49
  `Current level: ${currentLevel}`,
@@ -65,7 +65,7 @@ export const systemCommands = [
65
65
  else {
66
66
  const errorMsg = `āŒ Invalid log level: ${level}\nValid levels: ${validLevels.join(', ')}`;
67
67
  console.log(chalk.red(`āŒ Invalid log level: ${chalk.bold(level)}`));
68
- console.log(chalk.dim(`Valid levels: ${validLevels.join(', ')}`));
68
+ console.log(chalk.gray(`Valid levels: ${validLevels.join(', ')}`));
69
69
  return formatForInkCli(errorMsg);
70
70
  }
71
71
  },