@shareai-lab/kode 1.1.13 → 1.1.16-dev.1

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 (288) hide show
  1. package/dist/entrypoints/cli.js +59 -38
  2. package/dist/entrypoints/cli.js.map +3 -3
  3. package/dist/index.js +5 -26
  4. package/dist/package.json +4 -1
  5. package/package.json +11 -104
  6. package/dist/test/testAdapters.js +0 -88
  7. package/dist/test/testAdapters.js.map +0 -1
  8. package/src/ProjectOnboarding.tsx +0 -198
  9. package/src/Tool.ts +0 -83
  10. package/src/commands/agents.tsx +0 -3416
  11. package/src/commands/approvedTools.ts +0 -53
  12. package/src/commands/bug.tsx +0 -20
  13. package/src/commands/clear.ts +0 -43
  14. package/src/commands/compact.ts +0 -120
  15. package/src/commands/config.tsx +0 -19
  16. package/src/commands/cost.ts +0 -18
  17. package/src/commands/ctx_viz.ts +0 -209
  18. package/src/commands/doctor.ts +0 -24
  19. package/src/commands/help.tsx +0 -19
  20. package/src/commands/init.ts +0 -37
  21. package/src/commands/listen.ts +0 -42
  22. package/src/commands/login.tsx +0 -51
  23. package/src/commands/logout.tsx +0 -40
  24. package/src/commands/mcp.ts +0 -41
  25. package/src/commands/model.tsx +0 -40
  26. package/src/commands/modelstatus.tsx +0 -20
  27. package/src/commands/onboarding.tsx +0 -34
  28. package/src/commands/pr_comments.ts +0 -59
  29. package/src/commands/refreshCommands.ts +0 -54
  30. package/src/commands/release-notes.ts +0 -34
  31. package/src/commands/resume.tsx +0 -31
  32. package/src/commands/review.ts +0 -49
  33. package/src/commands/terminalSetup.ts +0 -221
  34. package/src/commands.ts +0 -139
  35. package/src/components/ApproveApiKey.tsx +0 -93
  36. package/src/components/AsciiLogo.tsx +0 -13
  37. package/src/components/AutoUpdater.tsx +0 -148
  38. package/src/components/Bug.tsx +0 -367
  39. package/src/components/Config.tsx +0 -293
  40. package/src/components/ConsoleOAuthFlow.tsx +0 -327
  41. package/src/components/Cost.tsx +0 -23
  42. package/src/components/CostThresholdDialog.tsx +0 -46
  43. package/src/components/CustomSelect/option-map.ts +0 -42
  44. package/src/components/CustomSelect/select-option.tsx +0 -78
  45. package/src/components/CustomSelect/select.tsx +0 -152
  46. package/src/components/CustomSelect/theme.ts +0 -45
  47. package/src/components/CustomSelect/use-select-state.ts +0 -414
  48. package/src/components/CustomSelect/use-select.ts +0 -35
  49. package/src/components/FallbackToolUseRejectedMessage.tsx +0 -15
  50. package/src/components/FileEditToolUpdatedMessage.tsx +0 -66
  51. package/src/components/Help.tsx +0 -215
  52. package/src/components/HighlightedCode.tsx +0 -33
  53. package/src/components/InvalidConfigDialog.tsx +0 -113
  54. package/src/components/Link.tsx +0 -32
  55. package/src/components/LogSelector.tsx +0 -86
  56. package/src/components/Logo.tsx +0 -170
  57. package/src/components/MCPServerApprovalDialog.tsx +0 -100
  58. package/src/components/MCPServerDialogCopy.tsx +0 -25
  59. package/src/components/MCPServerMultiselectDialog.tsx +0 -109
  60. package/src/components/Message.tsx +0 -221
  61. package/src/components/MessageResponse.tsx +0 -15
  62. package/src/components/MessageSelector.tsx +0 -211
  63. package/src/components/ModeIndicator.tsx +0 -88
  64. package/src/components/ModelConfig.tsx +0 -301
  65. package/src/components/ModelListManager.tsx +0 -227
  66. package/src/components/ModelSelector.tsx +0 -3387
  67. package/src/components/ModelStatusDisplay.tsx +0 -230
  68. package/src/components/Onboarding.tsx +0 -274
  69. package/src/components/PressEnterToContinue.tsx +0 -11
  70. package/src/components/PromptInput.tsx +0 -760
  71. package/src/components/SentryErrorBoundary.ts +0 -39
  72. package/src/components/Spinner.tsx +0 -129
  73. package/src/components/StickerRequestForm.tsx +0 -16
  74. package/src/components/StructuredDiff.tsx +0 -191
  75. package/src/components/TextInput.tsx +0 -259
  76. package/src/components/TodoItem.tsx +0 -47
  77. package/src/components/TokenWarning.tsx +0 -31
  78. package/src/components/ToolUseLoader.tsx +0 -40
  79. package/src/components/TrustDialog.tsx +0 -106
  80. package/src/components/binary-feedback/BinaryFeedback.tsx +0 -63
  81. package/src/components/binary-feedback/BinaryFeedbackOption.tsx +0 -111
  82. package/src/components/binary-feedback/BinaryFeedbackView.tsx +0 -172
  83. package/src/components/binary-feedback/utils.ts +0 -220
  84. package/src/components/messages/AssistantBashOutputMessage.tsx +0 -22
  85. package/src/components/messages/AssistantLocalCommandOutputMessage.tsx +0 -49
  86. package/src/components/messages/AssistantRedactedThinkingMessage.tsx +0 -19
  87. package/src/components/messages/AssistantTextMessage.tsx +0 -144
  88. package/src/components/messages/AssistantThinkingMessage.tsx +0 -40
  89. package/src/components/messages/AssistantToolUseMessage.tsx +0 -132
  90. package/src/components/messages/TaskProgressMessage.tsx +0 -32
  91. package/src/components/messages/TaskToolMessage.tsx +0 -58
  92. package/src/components/messages/UserBashInputMessage.tsx +0 -28
  93. package/src/components/messages/UserCommandMessage.tsx +0 -30
  94. package/src/components/messages/UserKodingInputMessage.tsx +0 -28
  95. package/src/components/messages/UserPromptMessage.tsx +0 -35
  96. package/src/components/messages/UserTextMessage.tsx +0 -39
  97. package/src/components/messages/UserToolResultMessage/UserToolCanceledMessage.tsx +0 -12
  98. package/src/components/messages/UserToolResultMessage/UserToolErrorMessage.tsx +0 -36
  99. package/src/components/messages/UserToolResultMessage/UserToolRejectMessage.tsx +0 -31
  100. package/src/components/messages/UserToolResultMessage/UserToolResultMessage.tsx +0 -57
  101. package/src/components/messages/UserToolResultMessage/UserToolSuccessMessage.tsx +0 -35
  102. package/src/components/messages/UserToolResultMessage/utils.tsx +0 -56
  103. package/src/components/permissions/BashPermissionRequest/BashPermissionRequest.tsx +0 -121
  104. package/src/components/permissions/FallbackPermissionRequest.tsx +0 -153
  105. package/src/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.tsx +0 -182
  106. package/src/components/permissions/FileEditPermissionRequest/FileEditToolDiff.tsx +0 -77
  107. package/src/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.tsx +0 -164
  108. package/src/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.tsx +0 -83
  109. package/src/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.tsx +0 -240
  110. package/src/components/permissions/PermissionRequest.tsx +0 -101
  111. package/src/components/permissions/PermissionRequestTitle.tsx +0 -69
  112. package/src/components/permissions/hooks.ts +0 -44
  113. package/src/components/permissions/toolUseOptions.ts +0 -59
  114. package/src/components/permissions/utils.ts +0 -23
  115. package/src/constants/betas.ts +0 -5
  116. package/src/constants/claude-asterisk-ascii-art.tsx +0 -238
  117. package/src/constants/figures.ts +0 -4
  118. package/src/constants/keys.ts +0 -3
  119. package/src/constants/macros.ts +0 -11
  120. package/src/constants/modelCapabilities.ts +0 -179
  121. package/src/constants/models.ts +0 -1025
  122. package/src/constants/oauth.ts +0 -18
  123. package/src/constants/product.ts +0 -17
  124. package/src/constants/prompts.ts +0 -168
  125. package/src/constants/releaseNotes.ts +0 -7
  126. package/src/context/PermissionContext.tsx +0 -149
  127. package/src/context.ts +0 -278
  128. package/src/cost-tracker.ts +0 -84
  129. package/src/entrypoints/cli.tsx +0 -1561
  130. package/src/entrypoints/mcp.ts +0 -175
  131. package/src/history.ts +0 -25
  132. package/src/hooks/useApiKeyVerification.ts +0 -59
  133. package/src/hooks/useArrowKeyHistory.ts +0 -55
  134. package/src/hooks/useCanUseTool.ts +0 -138
  135. package/src/hooks/useCancelRequest.ts +0 -39
  136. package/src/hooks/useDoublePress.ts +0 -41
  137. package/src/hooks/useExitOnCtrlCD.ts +0 -31
  138. package/src/hooks/useInterval.ts +0 -25
  139. package/src/hooks/useLogMessages.ts +0 -16
  140. package/src/hooks/useLogStartupTime.ts +0 -12
  141. package/src/hooks/useNotifyAfterTimeout.ts +0 -65
  142. package/src/hooks/usePermissionRequestLogging.ts +0 -44
  143. package/src/hooks/useTerminalSize.ts +0 -49
  144. package/src/hooks/useTextInput.ts +0 -317
  145. package/src/hooks/useUnifiedCompletion.ts +0 -1405
  146. package/src/index.ts +0 -34
  147. package/src/messages.ts +0 -38
  148. package/src/permissions.ts +0 -268
  149. package/src/query.ts +0 -720
  150. package/src/screens/ConfigureNpmPrefix.tsx +0 -197
  151. package/src/screens/Doctor.tsx +0 -219
  152. package/src/screens/LogList.tsx +0 -68
  153. package/src/screens/REPL.tsx +0 -813
  154. package/src/screens/ResumeConversation.tsx +0 -68
  155. package/src/services/adapters/base.ts +0 -38
  156. package/src/services/adapters/chatCompletions.ts +0 -90
  157. package/src/services/adapters/responsesAPI.ts +0 -170
  158. package/src/services/browserMocks.ts +0 -66
  159. package/src/services/claude.ts +0 -2197
  160. package/src/services/customCommands.ts +0 -704
  161. package/src/services/fileFreshness.ts +0 -377
  162. package/src/services/gpt5ConnectionTest.ts +0 -340
  163. package/src/services/mcpClient.ts +0 -564
  164. package/src/services/mcpServerApproval.tsx +0 -50
  165. package/src/services/mentionProcessor.ts +0 -273
  166. package/src/services/modelAdapterFactory.ts +0 -69
  167. package/src/services/notifier.ts +0 -40
  168. package/src/services/oauth.ts +0 -357
  169. package/src/services/openai.ts +0 -1359
  170. package/src/services/responseStateManager.ts +0 -90
  171. package/src/services/sentry.ts +0 -3
  172. package/src/services/statsig.ts +0 -172
  173. package/src/services/statsigStorage.ts +0 -86
  174. package/src/services/systemReminder.ts +0 -507
  175. package/src/services/vcr.ts +0 -161
  176. package/src/test/testAdapters.ts +0 -96
  177. package/src/tools/ArchitectTool/ArchitectTool.tsx +0 -135
  178. package/src/tools/ArchitectTool/prompt.ts +0 -15
  179. package/src/tools/AskExpertModelTool/AskExpertModelTool.tsx +0 -576
  180. package/src/tools/BashTool/BashTool.tsx +0 -243
  181. package/src/tools/BashTool/BashToolResultMessage.tsx +0 -38
  182. package/src/tools/BashTool/OutputLine.tsx +0 -49
  183. package/src/tools/BashTool/prompt.ts +0 -174
  184. package/src/tools/BashTool/utils.ts +0 -56
  185. package/src/tools/FileEditTool/FileEditTool.tsx +0 -319
  186. package/src/tools/FileEditTool/prompt.ts +0 -51
  187. package/src/tools/FileEditTool/utils.ts +0 -58
  188. package/src/tools/FileReadTool/FileReadTool.tsx +0 -404
  189. package/src/tools/FileReadTool/prompt.ts +0 -7
  190. package/src/tools/FileWriteTool/FileWriteTool.tsx +0 -301
  191. package/src/tools/FileWriteTool/prompt.ts +0 -10
  192. package/src/tools/GlobTool/GlobTool.tsx +0 -119
  193. package/src/tools/GlobTool/prompt.ts +0 -8
  194. package/src/tools/GrepTool/GrepTool.tsx +0 -147
  195. package/src/tools/GrepTool/prompt.ts +0 -11
  196. package/src/tools/MCPTool/MCPTool.tsx +0 -107
  197. package/src/tools/MCPTool/prompt.ts +0 -3
  198. package/src/tools/MemoryReadTool/MemoryReadTool.tsx +0 -127
  199. package/src/tools/MemoryReadTool/prompt.ts +0 -3
  200. package/src/tools/MemoryWriteTool/MemoryWriteTool.tsx +0 -89
  201. package/src/tools/MemoryWriteTool/prompt.ts +0 -3
  202. package/src/tools/MultiEditTool/MultiEditTool.tsx +0 -388
  203. package/src/tools/MultiEditTool/prompt.ts +0 -45
  204. package/src/tools/NotebookEditTool/NotebookEditTool.tsx +0 -298
  205. package/src/tools/NotebookEditTool/prompt.ts +0 -3
  206. package/src/tools/NotebookReadTool/NotebookReadTool.tsx +0 -258
  207. package/src/tools/NotebookReadTool/prompt.ts +0 -3
  208. package/src/tools/StickerRequestTool/StickerRequestTool.tsx +0 -107
  209. package/src/tools/StickerRequestTool/prompt.ts +0 -19
  210. package/src/tools/TaskTool/TaskTool.tsx +0 -438
  211. package/src/tools/TaskTool/constants.ts +0 -1
  212. package/src/tools/TaskTool/prompt.ts +0 -92
  213. package/src/tools/ThinkTool/ThinkTool.tsx +0 -54
  214. package/src/tools/ThinkTool/prompt.ts +0 -12
  215. package/src/tools/TodoWriteTool/TodoWriteTool.tsx +0 -313
  216. package/src/tools/TodoWriteTool/prompt.ts +0 -63
  217. package/src/tools/URLFetcherTool/URLFetcherTool.tsx +0 -178
  218. package/src/tools/URLFetcherTool/cache.ts +0 -55
  219. package/src/tools/URLFetcherTool/htmlToMarkdown.ts +0 -55
  220. package/src/tools/URLFetcherTool/prompt.ts +0 -17
  221. package/src/tools/WebSearchTool/WebSearchTool.tsx +0 -103
  222. package/src/tools/WebSearchTool/prompt.ts +0 -13
  223. package/src/tools/WebSearchTool/searchProviders.ts +0 -66
  224. package/src/tools/lsTool/lsTool.tsx +0 -272
  225. package/src/tools/lsTool/prompt.ts +0 -2
  226. package/src/tools.ts +0 -67
  227. package/src/types/PermissionMode.ts +0 -120
  228. package/src/types/RequestContext.ts +0 -72
  229. package/src/types/common.d.ts +0 -2
  230. package/src/types/conversation.ts +0 -51
  231. package/src/types/logs.ts +0 -58
  232. package/src/types/modelCapabilities.ts +0 -64
  233. package/src/types/notebook.ts +0 -87
  234. package/src/utils/Cursor.ts +0 -436
  235. package/src/utils/PersistentShell.ts +0 -552
  236. package/src/utils/advancedFuzzyMatcher.ts +0 -290
  237. package/src/utils/agentLoader.ts +0 -278
  238. package/src/utils/agentStorage.ts +0 -97
  239. package/src/utils/array.ts +0 -3
  240. package/src/utils/ask.tsx +0 -99
  241. package/src/utils/auth.ts +0 -13
  242. package/src/utils/autoCompactCore.ts +0 -223
  243. package/src/utils/autoUpdater.ts +0 -458
  244. package/src/utils/betas.ts +0 -20
  245. package/src/utils/browser.ts +0 -14
  246. package/src/utils/cleanup.ts +0 -72
  247. package/src/utils/commands.ts +0 -261
  248. package/src/utils/commonUnixCommands.ts +0 -161
  249. package/src/utils/config.ts +0 -945
  250. package/src/utils/conversationRecovery.ts +0 -55
  251. package/src/utils/debugLogger.ts +0 -1235
  252. package/src/utils/diff.ts +0 -42
  253. package/src/utils/env.ts +0 -57
  254. package/src/utils/errors.ts +0 -21
  255. package/src/utils/exampleCommands.ts +0 -109
  256. package/src/utils/execFileNoThrow.ts +0 -51
  257. package/src/utils/expertChatStorage.ts +0 -136
  258. package/src/utils/file.ts +0 -405
  259. package/src/utils/fileRecoveryCore.ts +0 -71
  260. package/src/utils/format.tsx +0 -44
  261. package/src/utils/fuzzyMatcher.ts +0 -328
  262. package/src/utils/generators.ts +0 -62
  263. package/src/utils/git.ts +0 -92
  264. package/src/utils/globalLogger.ts +0 -77
  265. package/src/utils/http.ts +0 -10
  266. package/src/utils/imagePaste.ts +0 -38
  267. package/src/utils/json.ts +0 -13
  268. package/src/utils/log.ts +0 -382
  269. package/src/utils/markdown.ts +0 -213
  270. package/src/utils/messageContextManager.ts +0 -294
  271. package/src/utils/messages.tsx +0 -945
  272. package/src/utils/model.ts +0 -914
  273. package/src/utils/permissions/filesystem.ts +0 -127
  274. package/src/utils/responseState.ts +0 -23
  275. package/src/utils/ripgrep.ts +0 -167
  276. package/src/utils/secureFile.ts +0 -564
  277. package/src/utils/sessionState.ts +0 -49
  278. package/src/utils/state.ts +0 -25
  279. package/src/utils/style.ts +0 -29
  280. package/src/utils/terminal.ts +0 -50
  281. package/src/utils/theme.ts +0 -127
  282. package/src/utils/thinking.ts +0 -144
  283. package/src/utils/todoStorage.ts +0 -431
  284. package/src/utils/tokens.ts +0 -43
  285. package/src/utils/toolExecutionController.ts +0 -163
  286. package/src/utils/unaryLogging.ts +0 -26
  287. package/src/utils/user.ts +0 -37
  288. 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
- }