@shareai-lab/kode 1.1.14 → 1.1.16-dev.2

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 (289) hide show
  1. package/cli.js +77 -82
  2. package/dist/entrypoints/cli.js +59 -38
  3. package/dist/entrypoints/cli.js.map +3 -3
  4. package/dist/index.js +5 -26
  5. package/dist/package.json +4 -1
  6. package/package.json +11 -104
  7. package/dist/test/testAdapters.js +0 -88
  8. package/dist/test/testAdapters.js.map +0 -1
  9. package/src/ProjectOnboarding.tsx +0 -198
  10. package/src/Tool.ts +0 -83
  11. package/src/commands/agents.tsx +0 -3416
  12. package/src/commands/approvedTools.ts +0 -53
  13. package/src/commands/bug.tsx +0 -20
  14. package/src/commands/clear.ts +0 -43
  15. package/src/commands/compact.ts +0 -120
  16. package/src/commands/config.tsx +0 -19
  17. package/src/commands/cost.ts +0 -18
  18. package/src/commands/ctx_viz.ts +0 -209
  19. package/src/commands/doctor.ts +0 -24
  20. package/src/commands/help.tsx +0 -19
  21. package/src/commands/init.ts +0 -37
  22. package/src/commands/listen.ts +0 -42
  23. package/src/commands/login.tsx +0 -51
  24. package/src/commands/logout.tsx +0 -40
  25. package/src/commands/mcp.ts +0 -41
  26. package/src/commands/model.tsx +0 -40
  27. package/src/commands/modelstatus.tsx +0 -20
  28. package/src/commands/onboarding.tsx +0 -34
  29. package/src/commands/pr_comments.ts +0 -59
  30. package/src/commands/refreshCommands.ts +0 -54
  31. package/src/commands/release-notes.ts +0 -34
  32. package/src/commands/resume.tsx +0 -31
  33. package/src/commands/review.ts +0 -49
  34. package/src/commands/terminalSetup.ts +0 -221
  35. package/src/commands.ts +0 -139
  36. package/src/components/ApproveApiKey.tsx +0 -93
  37. package/src/components/AsciiLogo.tsx +0 -13
  38. package/src/components/AutoUpdater.tsx +0 -148
  39. package/src/components/Bug.tsx +0 -367
  40. package/src/components/Config.tsx +0 -293
  41. package/src/components/ConsoleOAuthFlow.tsx +0 -327
  42. package/src/components/Cost.tsx +0 -23
  43. package/src/components/CostThresholdDialog.tsx +0 -46
  44. package/src/components/CustomSelect/option-map.ts +0 -42
  45. package/src/components/CustomSelect/select-option.tsx +0 -78
  46. package/src/components/CustomSelect/select.tsx +0 -152
  47. package/src/components/CustomSelect/theme.ts +0 -45
  48. package/src/components/CustomSelect/use-select-state.ts +0 -414
  49. package/src/components/CustomSelect/use-select.ts +0 -35
  50. package/src/components/FallbackToolUseRejectedMessage.tsx +0 -15
  51. package/src/components/FileEditToolUpdatedMessage.tsx +0 -66
  52. package/src/components/Help.tsx +0 -215
  53. package/src/components/HighlightedCode.tsx +0 -33
  54. package/src/components/InvalidConfigDialog.tsx +0 -113
  55. package/src/components/Link.tsx +0 -32
  56. package/src/components/LogSelector.tsx +0 -86
  57. package/src/components/Logo.tsx +0 -170
  58. package/src/components/MCPServerApprovalDialog.tsx +0 -100
  59. package/src/components/MCPServerDialogCopy.tsx +0 -25
  60. package/src/components/MCPServerMultiselectDialog.tsx +0 -109
  61. package/src/components/Message.tsx +0 -221
  62. package/src/components/MessageResponse.tsx +0 -15
  63. package/src/components/MessageSelector.tsx +0 -211
  64. package/src/components/ModeIndicator.tsx +0 -88
  65. package/src/components/ModelConfig.tsx +0 -301
  66. package/src/components/ModelListManager.tsx +0 -227
  67. package/src/components/ModelSelector.tsx +0 -3387
  68. package/src/components/ModelStatusDisplay.tsx +0 -230
  69. package/src/components/Onboarding.tsx +0 -274
  70. package/src/components/PressEnterToContinue.tsx +0 -11
  71. package/src/components/PromptInput.tsx +0 -760
  72. package/src/components/SentryErrorBoundary.ts +0 -39
  73. package/src/components/Spinner.tsx +0 -129
  74. package/src/components/StickerRequestForm.tsx +0 -16
  75. package/src/components/StructuredDiff.tsx +0 -191
  76. package/src/components/TextInput.tsx +0 -259
  77. package/src/components/TodoItem.tsx +0 -47
  78. package/src/components/TokenWarning.tsx +0 -31
  79. package/src/components/ToolUseLoader.tsx +0 -40
  80. package/src/components/TrustDialog.tsx +0 -106
  81. package/src/components/binary-feedback/BinaryFeedback.tsx +0 -63
  82. package/src/components/binary-feedback/BinaryFeedbackOption.tsx +0 -111
  83. package/src/components/binary-feedback/BinaryFeedbackView.tsx +0 -172
  84. package/src/components/binary-feedback/utils.ts +0 -220
  85. package/src/components/messages/AssistantBashOutputMessage.tsx +0 -22
  86. package/src/components/messages/AssistantLocalCommandOutputMessage.tsx +0 -49
  87. package/src/components/messages/AssistantRedactedThinkingMessage.tsx +0 -19
  88. package/src/components/messages/AssistantTextMessage.tsx +0 -144
  89. package/src/components/messages/AssistantThinkingMessage.tsx +0 -40
  90. package/src/components/messages/AssistantToolUseMessage.tsx +0 -132
  91. package/src/components/messages/TaskProgressMessage.tsx +0 -32
  92. package/src/components/messages/TaskToolMessage.tsx +0 -58
  93. package/src/components/messages/UserBashInputMessage.tsx +0 -28
  94. package/src/components/messages/UserCommandMessage.tsx +0 -30
  95. package/src/components/messages/UserKodingInputMessage.tsx +0 -28
  96. package/src/components/messages/UserPromptMessage.tsx +0 -35
  97. package/src/components/messages/UserTextMessage.tsx +0 -39
  98. package/src/components/messages/UserToolResultMessage/UserToolCanceledMessage.tsx +0 -12
  99. package/src/components/messages/UserToolResultMessage/UserToolErrorMessage.tsx +0 -36
  100. package/src/components/messages/UserToolResultMessage/UserToolRejectMessage.tsx +0 -31
  101. package/src/components/messages/UserToolResultMessage/UserToolResultMessage.tsx +0 -57
  102. package/src/components/messages/UserToolResultMessage/UserToolSuccessMessage.tsx +0 -35
  103. package/src/components/messages/UserToolResultMessage/utils.tsx +0 -56
  104. package/src/components/permissions/BashPermissionRequest/BashPermissionRequest.tsx +0 -121
  105. package/src/components/permissions/FallbackPermissionRequest.tsx +0 -153
  106. package/src/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.tsx +0 -182
  107. package/src/components/permissions/FileEditPermissionRequest/FileEditToolDiff.tsx +0 -77
  108. package/src/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.tsx +0 -164
  109. package/src/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.tsx +0 -83
  110. package/src/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.tsx +0 -240
  111. package/src/components/permissions/PermissionRequest.tsx +0 -101
  112. package/src/components/permissions/PermissionRequestTitle.tsx +0 -69
  113. package/src/components/permissions/hooks.ts +0 -44
  114. package/src/components/permissions/toolUseOptions.ts +0 -59
  115. package/src/components/permissions/utils.ts +0 -23
  116. package/src/constants/betas.ts +0 -5
  117. package/src/constants/claude-asterisk-ascii-art.tsx +0 -238
  118. package/src/constants/figures.ts +0 -4
  119. package/src/constants/keys.ts +0 -3
  120. package/src/constants/macros.ts +0 -11
  121. package/src/constants/modelCapabilities.ts +0 -179
  122. package/src/constants/models.ts +0 -1025
  123. package/src/constants/oauth.ts +0 -18
  124. package/src/constants/product.ts +0 -17
  125. package/src/constants/prompts.ts +0 -168
  126. package/src/constants/releaseNotes.ts +0 -7
  127. package/src/context/PermissionContext.tsx +0 -149
  128. package/src/context.ts +0 -278
  129. package/src/cost-tracker.ts +0 -84
  130. package/src/entrypoints/cli.tsx +0 -1561
  131. package/src/entrypoints/mcp.ts +0 -175
  132. package/src/history.ts +0 -25
  133. package/src/hooks/useApiKeyVerification.ts +0 -59
  134. package/src/hooks/useArrowKeyHistory.ts +0 -55
  135. package/src/hooks/useCanUseTool.ts +0 -138
  136. package/src/hooks/useCancelRequest.ts +0 -39
  137. package/src/hooks/useDoublePress.ts +0 -41
  138. package/src/hooks/useExitOnCtrlCD.ts +0 -31
  139. package/src/hooks/useInterval.ts +0 -25
  140. package/src/hooks/useLogMessages.ts +0 -16
  141. package/src/hooks/useLogStartupTime.ts +0 -12
  142. package/src/hooks/useNotifyAfterTimeout.ts +0 -65
  143. package/src/hooks/usePermissionRequestLogging.ts +0 -44
  144. package/src/hooks/useTerminalSize.ts +0 -49
  145. package/src/hooks/useTextInput.ts +0 -317
  146. package/src/hooks/useUnifiedCompletion.ts +0 -1405
  147. package/src/index.ts +0 -34
  148. package/src/messages.ts +0 -38
  149. package/src/permissions.ts +0 -268
  150. package/src/query.ts +0 -720
  151. package/src/screens/ConfigureNpmPrefix.tsx +0 -197
  152. package/src/screens/Doctor.tsx +0 -219
  153. package/src/screens/LogList.tsx +0 -68
  154. package/src/screens/REPL.tsx +0 -813
  155. package/src/screens/ResumeConversation.tsx +0 -68
  156. package/src/services/adapters/base.ts +0 -38
  157. package/src/services/adapters/chatCompletions.ts +0 -90
  158. package/src/services/adapters/responsesAPI.ts +0 -170
  159. package/src/services/browserMocks.ts +0 -66
  160. package/src/services/claude.ts +0 -2197
  161. package/src/services/customCommands.ts +0 -704
  162. package/src/services/fileFreshness.ts +0 -377
  163. package/src/services/gpt5ConnectionTest.ts +0 -340
  164. package/src/services/mcpClient.ts +0 -564
  165. package/src/services/mcpServerApproval.tsx +0 -50
  166. package/src/services/mentionProcessor.ts +0 -273
  167. package/src/services/modelAdapterFactory.ts +0 -69
  168. package/src/services/notifier.ts +0 -40
  169. package/src/services/oauth.ts +0 -357
  170. package/src/services/openai.ts +0 -1359
  171. package/src/services/responseStateManager.ts +0 -90
  172. package/src/services/sentry.ts +0 -3
  173. package/src/services/statsig.ts +0 -172
  174. package/src/services/statsigStorage.ts +0 -86
  175. package/src/services/systemReminder.ts +0 -507
  176. package/src/services/vcr.ts +0 -161
  177. package/src/test/testAdapters.ts +0 -96
  178. package/src/tools/ArchitectTool/ArchitectTool.tsx +0 -135
  179. package/src/tools/ArchitectTool/prompt.ts +0 -15
  180. package/src/tools/AskExpertModelTool/AskExpertModelTool.tsx +0 -576
  181. package/src/tools/BashTool/BashTool.tsx +0 -243
  182. package/src/tools/BashTool/BashToolResultMessage.tsx +0 -38
  183. package/src/tools/BashTool/OutputLine.tsx +0 -49
  184. package/src/tools/BashTool/prompt.ts +0 -174
  185. package/src/tools/BashTool/utils.ts +0 -56
  186. package/src/tools/FileEditTool/FileEditTool.tsx +0 -319
  187. package/src/tools/FileEditTool/prompt.ts +0 -51
  188. package/src/tools/FileEditTool/utils.ts +0 -58
  189. package/src/tools/FileReadTool/FileReadTool.tsx +0 -404
  190. package/src/tools/FileReadTool/prompt.ts +0 -7
  191. package/src/tools/FileWriteTool/FileWriteTool.tsx +0 -301
  192. package/src/tools/FileWriteTool/prompt.ts +0 -10
  193. package/src/tools/GlobTool/GlobTool.tsx +0 -119
  194. package/src/tools/GlobTool/prompt.ts +0 -8
  195. package/src/tools/GrepTool/GrepTool.tsx +0 -147
  196. package/src/tools/GrepTool/prompt.ts +0 -11
  197. package/src/tools/MCPTool/MCPTool.tsx +0 -107
  198. package/src/tools/MCPTool/prompt.ts +0 -3
  199. package/src/tools/MemoryReadTool/MemoryReadTool.tsx +0 -127
  200. package/src/tools/MemoryReadTool/prompt.ts +0 -3
  201. package/src/tools/MemoryWriteTool/MemoryWriteTool.tsx +0 -89
  202. package/src/tools/MemoryWriteTool/prompt.ts +0 -3
  203. package/src/tools/MultiEditTool/MultiEditTool.tsx +0 -388
  204. package/src/tools/MultiEditTool/prompt.ts +0 -45
  205. package/src/tools/NotebookEditTool/NotebookEditTool.tsx +0 -298
  206. package/src/tools/NotebookEditTool/prompt.ts +0 -3
  207. package/src/tools/NotebookReadTool/NotebookReadTool.tsx +0 -258
  208. package/src/tools/NotebookReadTool/prompt.ts +0 -3
  209. package/src/tools/StickerRequestTool/StickerRequestTool.tsx +0 -107
  210. package/src/tools/StickerRequestTool/prompt.ts +0 -19
  211. package/src/tools/TaskTool/TaskTool.tsx +0 -438
  212. package/src/tools/TaskTool/constants.ts +0 -1
  213. package/src/tools/TaskTool/prompt.ts +0 -92
  214. package/src/tools/ThinkTool/ThinkTool.tsx +0 -54
  215. package/src/tools/ThinkTool/prompt.ts +0 -12
  216. package/src/tools/TodoWriteTool/TodoWriteTool.tsx +0 -313
  217. package/src/tools/TodoWriteTool/prompt.ts +0 -63
  218. package/src/tools/URLFetcherTool/URLFetcherTool.tsx +0 -178
  219. package/src/tools/URLFetcherTool/cache.ts +0 -55
  220. package/src/tools/URLFetcherTool/htmlToMarkdown.ts +0 -55
  221. package/src/tools/URLFetcherTool/prompt.ts +0 -17
  222. package/src/tools/WebSearchTool/WebSearchTool.tsx +0 -103
  223. package/src/tools/WebSearchTool/prompt.ts +0 -13
  224. package/src/tools/WebSearchTool/searchProviders.ts +0 -66
  225. package/src/tools/lsTool/lsTool.tsx +0 -272
  226. package/src/tools/lsTool/prompt.ts +0 -2
  227. package/src/tools.ts +0 -67
  228. package/src/types/PermissionMode.ts +0 -120
  229. package/src/types/RequestContext.ts +0 -72
  230. package/src/types/common.d.ts +0 -2
  231. package/src/types/conversation.ts +0 -51
  232. package/src/types/logs.ts +0 -58
  233. package/src/types/modelCapabilities.ts +0 -64
  234. package/src/types/notebook.ts +0 -87
  235. package/src/utils/Cursor.ts +0 -436
  236. package/src/utils/PersistentShell.ts +0 -552
  237. package/src/utils/advancedFuzzyMatcher.ts +0 -290
  238. package/src/utils/agentLoader.ts +0 -278
  239. package/src/utils/agentStorage.ts +0 -97
  240. package/src/utils/array.ts +0 -3
  241. package/src/utils/ask.tsx +0 -99
  242. package/src/utils/auth.ts +0 -13
  243. package/src/utils/autoCompactCore.ts +0 -223
  244. package/src/utils/autoUpdater.ts +0 -458
  245. package/src/utils/betas.ts +0 -20
  246. package/src/utils/browser.ts +0 -14
  247. package/src/utils/cleanup.ts +0 -72
  248. package/src/utils/commands.ts +0 -261
  249. package/src/utils/commonUnixCommands.ts +0 -161
  250. package/src/utils/config.ts +0 -945
  251. package/src/utils/conversationRecovery.ts +0 -55
  252. package/src/utils/debugLogger.ts +0 -1235
  253. package/src/utils/diff.ts +0 -42
  254. package/src/utils/env.ts +0 -57
  255. package/src/utils/errors.ts +0 -21
  256. package/src/utils/exampleCommands.ts +0 -109
  257. package/src/utils/execFileNoThrow.ts +0 -51
  258. package/src/utils/expertChatStorage.ts +0 -136
  259. package/src/utils/file.ts +0 -405
  260. package/src/utils/fileRecoveryCore.ts +0 -71
  261. package/src/utils/format.tsx +0 -44
  262. package/src/utils/fuzzyMatcher.ts +0 -328
  263. package/src/utils/generators.ts +0 -62
  264. package/src/utils/git.ts +0 -92
  265. package/src/utils/globalLogger.ts +0 -77
  266. package/src/utils/http.ts +0 -10
  267. package/src/utils/imagePaste.ts +0 -38
  268. package/src/utils/json.ts +0 -13
  269. package/src/utils/log.ts +0 -382
  270. package/src/utils/markdown.ts +0 -213
  271. package/src/utils/messageContextManager.ts +0 -294
  272. package/src/utils/messages.tsx +0 -945
  273. package/src/utils/model.ts +0 -914
  274. package/src/utils/permissions/filesystem.ts +0 -127
  275. package/src/utils/responseState.ts +0 -23
  276. package/src/utils/ripgrep.ts +0 -167
  277. package/src/utils/secureFile.ts +0 -564
  278. package/src/utils/sessionState.ts +0 -49
  279. package/src/utils/state.ts +0 -25
  280. package/src/utils/style.ts +0 -29
  281. package/src/utils/terminal.ts +0 -50
  282. package/src/utils/theme.ts +0 -127
  283. package/src/utils/thinking.ts +0 -144
  284. package/src/utils/todoStorage.ts +0 -431
  285. package/src/utils/tokens.ts +0 -43
  286. package/src/utils/toolExecutionController.ts +0 -163
  287. package/src/utils/unaryLogging.ts +0 -26
  288. package/src/utils/user.ts +0 -37
  289. package/src/utils/validate.ts +0 -165
@@ -1,230 +0,0 @@
1
- import React from 'react'
2
- import { Text, Box } from 'ink'
3
- import { getModelManager } from '../utils/model'
4
- import { getGlobalConfig } from '../utils/config'
5
- import { useExitOnCtrlCD } from '../hooks/useExitOnCtrlCD'
6
- import { getTheme } from '../utils/theme'
7
-
8
- type Props = {
9
- onClose: () => void
10
- }
11
-
12
- export function ModelStatusDisplay({ onClose }: Props): React.ReactNode {
13
- const theme = getTheme()
14
- const exitState = useExitOnCtrlCD(onClose)
15
-
16
- try {
17
- const modelManager = getModelManager()
18
- const config = getGlobalConfig()
19
-
20
- // 显示所有模型指针的当前状态
21
- const pointers = ['main', 'task', 'reasoning', 'quick'] as const
22
-
23
- return (
24
- <Box
25
- flexDirection="column"
26
- borderStyle="round"
27
- borderColor={theme.secondaryBorder}
28
- paddingX={2}
29
- paddingY={1}
30
- >
31
- <Text bold>
32
- 📊 Current Model Status{' '}
33
- {exitState.pending
34
- ? `(press ${exitState.keyName} again to exit)`
35
- : ''}
36
- </Text>
37
- <Text> </Text>
38
-
39
- {pointers.map(pointer => {
40
- try {
41
- const model = modelManager.getModel(pointer)
42
- if (model && model.name && model.provider) {
43
- return (
44
- <Box key={pointer} flexDirection="column" marginBottom={1}>
45
- <Text>
46
- 🎯{' '}
47
- <Text bold color={theme.kode}>
48
- {pointer.toUpperCase()}
49
- </Text>{' '}
50
- → {model.name}
51
- </Text>
52
- <Text color={theme.secondaryText}>
53
- {' '}
54
- Provider: {model.provider}
55
- </Text>
56
- <Text color={theme.secondaryText}>
57
- {' '}
58
- Model: {model.modelName || 'unknown'}
59
- </Text>
60
- <Text color={theme.secondaryText}>
61
- {' '}
62
- Context:{' '}
63
- {model.contextLength
64
- ? Math.round(model.contextLength / 1000)
65
- : 'unknown'}
66
- k tokens
67
- </Text>
68
- <Text color={theme.secondaryText}>
69
- {' '}
70
- Active: {model.isActive ? '✅' : '❌'}
71
- </Text>
72
- </Box>
73
- )
74
- } else {
75
- return (
76
- <Box key={pointer} flexDirection="column" marginBottom={1}>
77
- <Text>
78
- 🎯{' '}
79
- <Text bold color={theme.kode}>
80
- {pointer.toUpperCase()}
81
- </Text>{' '}
82
- → <Text color={theme.error}>❌ Not configured</Text>
83
- </Text>
84
- </Box>
85
- )
86
- }
87
- } catch (pointerError) {
88
- return (
89
- <Box key={pointer} flexDirection="column" marginBottom={1}>
90
- <Text>
91
- 🎯{' '}
92
- <Text bold color={theme.kode}>
93
- {pointer.toUpperCase()}
94
- </Text>{' '}
95
- →{' '}
96
- <Text color={theme.error}>
97
- ❌ Error: {String(pointerError)}
98
- </Text>
99
- </Text>
100
- </Box>
101
- )
102
- }
103
- })}
104
-
105
- <Text> </Text>
106
- <Text bold>📚 Available Models:</Text>
107
-
108
- {(() => {
109
- try {
110
- const availableModels = modelManager.getAvailableModels() || []
111
-
112
- if (availableModels.length === 0) {
113
- return (
114
- <Text color={theme.secondaryText}> No models configured</Text>
115
- )
116
- }
117
-
118
- return availableModels.map((model, index) => {
119
- try {
120
- const isInUse = pointers.some(p => {
121
- try {
122
- return (
123
- modelManager.getModel(p)?.modelName === model.modelName
124
- )
125
- } catch {
126
- return false
127
- }
128
- })
129
-
130
- return (
131
- <Box key={index} flexDirection="column" marginBottom={1}>
132
- <Text>
133
- {' '}
134
- {isInUse ? '🔄' : '💤'} {model.name || 'Unnamed'}{' '}
135
- <Text color={theme.secondaryText}>
136
- ({model.provider || 'unknown'})
137
- </Text>
138
- </Text>
139
- <Text color={theme.secondaryText}>
140
- {' '}
141
- Model: {model.modelName || 'unknown'}
142
- </Text>
143
- <Text color={theme.secondaryText}>
144
- {' '}
145
- Context:{' '}
146
- {model.contextLength
147
- ? Math.round(model.contextLength / 1000)
148
- : 'unknown'}
149
- k tokens
150
- </Text>
151
- {model.lastUsed && (
152
- <Text color={theme.secondaryText}>
153
- {' '}
154
- Last used: {new Date(model.lastUsed).toLocaleString()}
155
- </Text>
156
- )}
157
- </Box>
158
- )
159
- } catch (modelError) {
160
- return (
161
- <Box key={index} flexDirection="column" marginBottom={1}>
162
- <Text color={theme.error}>
163
- {' '}
164
- ❌ Model error: {String(modelError)}
165
- </Text>
166
- </Box>
167
- )
168
- }
169
- })
170
- } catch (availableModelsError) {
171
- return (
172
- <Text color={theme.error}>
173
- ❌ Error loading available models:{' '}
174
- {String(availableModelsError)}
175
- </Text>
176
- )
177
- }
178
- })()}
179
-
180
- <Text> </Text>
181
- <Text bold>🔧 Debug Info:</Text>
182
- <Text color={theme.secondaryText}>
183
- {' '}
184
- ModelProfiles: {config.modelProfiles?.length || 0} configured
185
- </Text>
186
- <Text color={theme.secondaryText}>
187
- {' '}
188
- DefaultModelId: {(config as any).defaultModelId || 'not set'}
189
- </Text>
190
- {config.modelPointers && (
191
- <>
192
- <Text color={theme.secondaryText}>
193
- {' '}
194
- ModelPointers configured:{' '}
195
- {Object.keys(config.modelPointers).length > 0 ? 'Yes' : 'No'}
196
- </Text>
197
- {Object.entries(config.modelPointers).map(([pointer, modelId]) => (
198
- <React.Fragment key={pointer}>
199
- <Text color={theme.secondaryText}>
200
- {' '}
201
- {pointer}: {modelId || 'not set'}
202
- </Text>
203
- </React.Fragment>
204
- ))}
205
- </>
206
- )}
207
- </Box>
208
- )
209
- } catch (error) {
210
- return (
211
- <Box
212
- flexDirection="column"
213
- borderStyle="round"
214
- borderColor={theme.error}
215
- paddingX={2}
216
- paddingY={1}
217
- >
218
- <Text bold>
219
- 📊 Model Status Error{' '}
220
- {exitState.pending
221
- ? `(press ${exitState.keyName} again to exit)`
222
- : ''}
223
- </Text>
224
- <Text color={theme.error}>
225
- ❌ Error reading model status: {String(error)}
226
- </Text>
227
- </Box>
228
- )
229
- }
230
- }
@@ -1,274 +0,0 @@
1
- import React, { useState } from 'react'
2
- import { PRODUCT_NAME } from '../constants/product'
3
- import { Box, Newline, Text, useInput } from 'ink'
4
- import {
5
- getGlobalConfig,
6
- saveGlobalConfig,
7
- DEFAULT_GLOBAL_CONFIG,
8
- ProviderType,
9
- } from '../utils/config.js'
10
- import { OrderedList } from '@inkjs/ui'
11
- import { useExitOnCtrlCD } from '../hooks/useExitOnCtrlCD'
12
- import { MIN_LOGO_WIDTH } from './Logo'
13
- import { Select } from './CustomSelect/select'
14
- import { StructuredDiff } from './StructuredDiff'
15
- import { getTheme, type ThemeNames } from '../utils/theme'
16
- import { clearTerminal } from '../utils/terminal'
17
- import { PressEnterToContinue } from './PressEnterToContinue'
18
- import { ModelSelector } from './ModelSelector'
19
- type StepId = 'theme' | 'usage' | 'providers' | 'model'
20
-
21
- interface OnboardingStep {
22
- id: StepId
23
- component: React.ReactNode
24
- }
25
-
26
- type Props = {
27
- onDone(): void
28
- }
29
-
30
- export function Onboarding({ onDone }: Props): React.ReactNode {
31
- const [currentStepIndex, setCurrentStepIndex] = useState(0)
32
- const [showModelSelector, setShowModelSelector] = useState(false)
33
- const config = getGlobalConfig()
34
-
35
- const [selectedTheme, setSelectedTheme] = useState(
36
- DEFAULT_GLOBAL_CONFIG.theme,
37
- )
38
- const theme = getTheme()
39
- function goToNextStep() {
40
- if (currentStepIndex < steps.length - 1) {
41
- const nextIndex = currentStepIndex + 1
42
- setCurrentStepIndex(nextIndex)
43
- }
44
- }
45
-
46
- function handleThemeSelection(newTheme: string) {
47
- saveGlobalConfig({
48
- ...config,
49
- theme: newTheme as ThemeNames,
50
- })
51
- goToNextStep()
52
- }
53
-
54
- function handleThemePreview(newTheme: string) {
55
- setSelectedTheme(newTheme as ThemeNames)
56
- }
57
-
58
- function handleProviderSelectionDone() {
59
- // After model selection is done, go to the next step
60
- goToNextStep()
61
- }
62
-
63
- function handleModelSelectionDone() {
64
- // After final model selection is done, complete onboarding
65
- onDone()
66
- }
67
-
68
- const exitState = useExitOnCtrlCD(() => process.exit(0))
69
-
70
- useInput(async (_, key) => {
71
- const currentStep = steps[currentStepIndex]
72
- if (
73
- key.return &&
74
- currentStep &&
75
- ['usage', 'providers', 'model'].includes(currentStep.id)
76
- ) {
77
- if (currentStep.id === 'model') {
78
- // Navigate to ModelSelector component
79
- setShowModelSelector(true)
80
- } else if (currentStepIndex === steps.length - 1) {
81
- onDone()
82
- } else {
83
- // HACK: for some reason there's now a jump here otherwise :(
84
- await clearTerminal()
85
- goToNextStep()
86
- }
87
- }
88
- })
89
-
90
- // Define all onboarding steps
91
- const themeStep = (
92
- <Box flexDirection="column" gap={1} paddingLeft={1}>
93
- <Text>Let&apos;s get started.</Text>
94
- <Box flexDirection="column">
95
- <Text bold>Choose the option that looks best when you select it:</Text>
96
- <Text dimColor>To change this later, run /config</Text>
97
- </Box>
98
- <Select
99
- options={[
100
- { label: 'Light text', value: 'dark' },
101
- { label: 'Dark text', value: 'light' },
102
- {
103
- label: 'Light text (colorblind-friendly)',
104
- value: 'dark-daltonized',
105
- },
106
- {
107
- label: 'Dark text (colorblind-friendly)',
108
- value: 'light-daltonized',
109
- },
110
- ]}
111
- onFocus={handleThemePreview}
112
- onChange={handleThemeSelection}
113
- />
114
- <Box flexDirection="column">
115
- <Box
116
- paddingLeft={1}
117
- marginRight={1}
118
- borderStyle="round"
119
- borderColor="gray"
120
- flexDirection="column"
121
- >
122
- <StructuredDiff
123
- patch={{
124
- oldStart: 1,
125
- newStart: 1,
126
- oldLines: 3,
127
- newLines: 3,
128
- lines: [
129
- 'function greet() {',
130
- '- console.log("Hello, World!");',
131
- '+ console.log("Hello, anon!");',
132
- '}',
133
- ],
134
- }}
135
- dim={false}
136
- width={40}
137
- overrideTheme={selectedTheme}
138
- />
139
- </Box>
140
- </Box>
141
- </Box>
142
- )
143
-
144
- const providersStep = (
145
- <Box flexDirection="column" gap={1} paddingLeft={1}>
146
- <Box flexDirection="column" width={70}>
147
- <Text color={theme.secondaryText}>
148
- Next, let's select your preferred AI provider and model.
149
- </Text>
150
- </Box>
151
- <ModelSelector
152
- onDone={handleProviderSelectionDone}
153
- skipModelType={true}
154
- isOnboarding={true}
155
- />
156
- </Box>
157
- )
158
-
159
- const usageStep = (
160
- <Box flexDirection="column" gap={1} paddingLeft={1}>
161
- <Text bold>Using {PRODUCT_NAME} effectively:</Text>
162
- <Box flexDirection="column" width={70}>
163
- <OrderedList children={[]}>
164
- <OrderedList.Item children={[]}>
165
- <Text>
166
- Start in your project directory
167
- <Newline />
168
- <Text color={theme.secondaryText}>
169
- Files are automatically added to context when needed.
170
- </Text>
171
- <Newline />
172
- </Text>
173
- </OrderedList.Item>
174
- <OrderedList.Item children={[]}>
175
- <Text>
176
- Use {PRODUCT_NAME} as a development partner
177
- <Newline />
178
- <Text color={theme.secondaryText}>
179
- Get help with file analysis, editing, bash commands,
180
- <Newline />
181
- and git history.
182
- <Newline />
183
- </Text>
184
- </Text>
185
- </OrderedList.Item>
186
- <OrderedList.Item children={[]}>
187
- <Text>
188
- Provide clear context
189
- <Newline />
190
- <Text color={theme.secondaryText}>
191
- Be as specific as you would with another engineer. <Newline />
192
- The better the context, the better the results. <Newline />
193
- </Text>
194
- </Text>
195
- </OrderedList.Item>
196
- </OrderedList>
197
- </Box>
198
- <PressEnterToContinue />
199
- </Box>
200
- )
201
-
202
- const modelStep = (
203
- <Box flexDirection="column" gap={1} paddingLeft={1}>
204
- <Text bold>Configure your models:</Text>
205
- <Box flexDirection="column" width={70}>
206
- <Text>
207
- You can customize which models {PRODUCT_NAME} uses for different
208
- tasks.
209
- <Newline />
210
- <Text color={theme.secondaryText}>
211
- Let's set up your preferred models for large and small tasks.
212
- </Text>
213
- </Text>
214
- <Box marginTop={1}>
215
- <Text>
216
- Press <Text color={theme.suggestion}>Enter</Text> to continue to the
217
- model selection screen.
218
- </Text>
219
- </Box>
220
- </Box>
221
- <PressEnterToContinue />
222
- </Box>
223
- )
224
-
225
- const steps: OnboardingStep[] = []
226
- steps.push({ id: 'theme', component: themeStep })
227
- steps.push({ id: 'usage', component: usageStep })
228
-
229
- steps.push({ id: 'model', component: modelStep })
230
-
231
- // If we're showing the model selector screen, render it directly
232
- if (showModelSelector) {
233
- return (
234
- <ModelSelector
235
- onDone={handleModelSelectionDone}
236
- skipModelType={true}
237
- isOnboarding={true}
238
- />
239
- )
240
- }
241
-
242
- return (
243
- <Box flexDirection="column" gap={1}>
244
- <>
245
- <Box flexDirection="column" gap={1}>
246
- <Text bold>
247
- {PRODUCT_NAME}{' '}
248
- {exitState.pending
249
- ? `(press ${exitState.keyName} again to exit)`
250
- : ''}
251
- </Text>
252
- {steps[currentStepIndex]?.component}
253
- </Box>
254
- </>
255
- </Box>
256
- )
257
- }
258
-
259
- export function WelcomeBox(): React.ReactNode {
260
- const theme = getTheme()
261
- return (
262
- <Box
263
- borderColor={theme.kode}
264
- borderStyle="round"
265
- paddingX={1}
266
- width={MIN_LOGO_WIDTH}
267
- >
268
- <Text>
269
- <Text color={theme.kode}>✻</Text> Welcome to{' '}
270
- <Text bold>{PRODUCT_NAME}</Text> research preview!
271
- </Text>
272
- </Box>
273
- )
274
- }
@@ -1,11 +0,0 @@
1
- import * as React from 'react'
2
- import { getTheme } from '../utils/theme'
3
- import { Text } from 'ink'
4
-
5
- export function PressEnterToContinue(): React.ReactNode {
6
- return (
7
- <Text color={getTheme().permission}>
8
- Press <Text bold>Enter</Text> to continue…
9
- </Text>
10
- )
11
- }