@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,45 +0,0 @@
1
- // Theme type definitions for CustomSelect components
2
- // Used by select.tsx and select-option.tsx
3
-
4
- import type { BoxProps, TextProps } from 'ink'
5
-
6
- /**
7
- * Theme interface for CustomSelect components
8
- * Defines the style functions used by the select components
9
- */
10
- export interface Theme {
11
- /**
12
- * Collection of style functions
13
- */
14
- styles: {
15
- /**
16
- * Container styles for the select box
17
- */
18
- container(): BoxProps
19
-
20
- /**
21
- * Styles for individual option containers
22
- */
23
- option(props: { isFocused: boolean }): BoxProps
24
-
25
- /**
26
- * Styles for the focus indicator (arrow/pointer)
27
- */
28
- focusIndicator(): TextProps
29
-
30
- /**
31
- * Styles for option labels
32
- */
33
- label(props: { isFocused: boolean; isSelected: boolean }): TextProps
34
-
35
- /**
36
- * Styles for the selected indicator (checkmark)
37
- */
38
- selectedIndicator(): TextProps
39
-
40
- /**
41
- * Styles for highlighted text in option labels
42
- */
43
- highlightedText(): TextProps
44
- }
45
- }
@@ -1,414 +0,0 @@
1
- import { isDeepStrictEqual } from 'node:util'
2
- import {
3
- useReducer,
4
- type Reducer,
5
- useCallback,
6
- useMemo,
7
- useState,
8
- useEffect,
9
- } from 'react'
10
- import OptionMap from './option-map'
11
- import { Option } from '@inkjs/ui'
12
- import type { OptionHeader, OptionSubtree } from './select'
13
-
14
- type State = {
15
- /**
16
- * Map where key is option's value and value is option's index.
17
- */
18
- optionMap: OptionMap
19
-
20
- /**
21
- * Number of visible options.
22
- */
23
- visibleOptionCount: number
24
-
25
- /**
26
- * Value of the currently focused option.
27
- */
28
- focusedValue: string | undefined
29
-
30
- /**
31
- * Index of the first visible option.
32
- */
33
- visibleFromIndex: number
34
-
35
- /**
36
- * Index of the last visible option.
37
- */
38
- visibleToIndex: number
39
-
40
- /**
41
- * Value of the previously selected option.
42
- */
43
- previousValue: string | undefined
44
-
45
- /**
46
- * Value of the selected option.
47
- */
48
- value: string | undefined
49
- }
50
-
51
- type Action =
52
- | FocusNextOptionAction
53
- | FocusPreviousOptionAction
54
- | SelectFocusedOptionAction
55
- | SetFocusAction
56
- | ResetAction
57
-
58
- type SetFocusAction = {
59
- type: 'set-focus'
60
- value: string
61
- }
62
-
63
- type FocusNextOptionAction = {
64
- type: 'focus-next-option'
65
- }
66
-
67
- type FocusPreviousOptionAction = {
68
- type: 'focus-previous-option'
69
- }
70
-
71
- type SelectFocusedOptionAction = {
72
- type: 'select-focused-option'
73
- }
74
-
75
- type ResetAction = {
76
- type: 'reset'
77
- state: State
78
- }
79
-
80
- const reducer: Reducer<State, Action> = (state, action) => {
81
- switch (action.type) {
82
- case 'focus-next-option': {
83
- if (!state.focusedValue) {
84
- return state
85
- }
86
-
87
- const item = state.optionMap.get(state.focusedValue)
88
-
89
- if (!item) {
90
- return state
91
- }
92
-
93
- let next = item.next
94
- while (next && !('value' in next)) {
95
- // Skip headers
96
- next = next.next
97
- }
98
-
99
- if (!next) {
100
- return state
101
- }
102
-
103
- const needsToScroll = next.index >= state.visibleToIndex
104
-
105
- if (!needsToScroll) {
106
- return {
107
- ...state,
108
- focusedValue: next.value,
109
- }
110
- }
111
-
112
- const nextVisibleToIndex = Math.min(
113
- state.optionMap.size,
114
- state.visibleToIndex + 1,
115
- )
116
-
117
- const nextVisibleFromIndex = nextVisibleToIndex - state.visibleOptionCount
118
-
119
- return {
120
- ...state,
121
- focusedValue: next.value,
122
- visibleFromIndex: nextVisibleFromIndex,
123
- visibleToIndex: nextVisibleToIndex,
124
- }
125
- }
126
-
127
- case 'focus-previous-option': {
128
- if (!state.focusedValue) {
129
- return state
130
- }
131
-
132
- const item = state.optionMap.get(state.focusedValue)
133
-
134
- if (!item) {
135
- return state
136
- }
137
-
138
- let previous = item.previous
139
- while (previous && !('value' in previous)) {
140
- // Skip headers
141
- previous = previous.previous
142
- }
143
-
144
- if (!previous) {
145
- return state
146
- }
147
-
148
- const needsToScroll = previous.index <= state.visibleFromIndex
149
-
150
- if (!needsToScroll) {
151
- return {
152
- ...state,
153
- focusedValue: previous.value,
154
- }
155
- }
156
-
157
- const nextVisibleFromIndex = Math.max(0, state.visibleFromIndex - 1)
158
-
159
- const nextVisibleToIndex = nextVisibleFromIndex + state.visibleOptionCount
160
-
161
- return {
162
- ...state,
163
- focusedValue: previous.value,
164
- visibleFromIndex: nextVisibleFromIndex,
165
- visibleToIndex: nextVisibleToIndex,
166
- }
167
- }
168
-
169
- case 'select-focused-option': {
170
- return {
171
- ...state,
172
- previousValue: state.value,
173
- value: state.focusedValue,
174
- }
175
- }
176
-
177
- case 'reset': {
178
- return action.state
179
- }
180
-
181
- case 'set-focus': {
182
- return {
183
- ...state,
184
- focusedValue: action.value,
185
- }
186
- }
187
- }
188
- }
189
-
190
- export type UseSelectStateProps = {
191
- /**
192
- * Number of items to display.
193
- *
194
- * @default 5
195
- */
196
- visibleOptionCount?: number
197
-
198
- /**
199
- * Options.
200
- */
201
- options: (Option | OptionSubtree)[]
202
-
203
- /**
204
- * Initially selected option's value.
205
- */
206
- defaultValue?: string
207
-
208
- /**
209
- * Callback for selecting an option.
210
- */
211
- onChange?: (value: string) => void
212
-
213
- /**
214
- * Callback for focusing an option.
215
- */
216
- onFocus?: (value: string) => void
217
-
218
- /**
219
- * Value to focus
220
- */
221
- focusValue?: string
222
- }
223
-
224
- export type SelectState = Pick<
225
- State,
226
- 'focusedValue' | 'visibleFromIndex' | 'visibleToIndex' | 'value'
227
- > & {
228
- /**
229
- * Visible options.
230
- */
231
- visibleOptions: Array<(Option | OptionHeader) & { index: number }>
232
-
233
- /**
234
- * Focus next option and scroll the list down, if needed.
235
- */
236
- focusNextOption: () => void
237
-
238
- /**
239
- * Focus previous option and scroll the list up, if needed.
240
- */
241
- focusPreviousOption: () => void
242
-
243
- /**
244
- * Select currently focused option.
245
- */
246
- selectFocusedOption: () => void
247
- }
248
-
249
- const flattenOptions = (
250
- options: (Option | OptionSubtree)[],
251
- ): (Option | OptionHeader)[] =>
252
- options.flatMap(option => {
253
- if ('options' in option) {
254
- const flatSubtree = flattenOptions(option.options)
255
- const optionValues = flatSubtree.flatMap(o =>
256
- 'value' in o ? o.value : [],
257
- )
258
- const header =
259
- option.header !== undefined
260
- ? [{ header: option.header, optionValues }]
261
- : []
262
-
263
- return [...header, ...flatSubtree]
264
- }
265
- return option
266
- })
267
-
268
- const createDefaultState = ({
269
- visibleOptionCount: customVisibleOptionCount,
270
- defaultValue,
271
- options,
272
- }: Pick<
273
- UseSelectStateProps,
274
- 'visibleOptionCount' | 'defaultValue' | 'options'
275
- >) => {
276
- const flatOptions = flattenOptions(options)
277
-
278
- const visibleOptionCount =
279
- typeof customVisibleOptionCount === 'number'
280
- ? Math.min(customVisibleOptionCount, flatOptions.length)
281
- : flatOptions.length
282
-
283
- const optionMap = new OptionMap(flatOptions)
284
- const firstOption = optionMap.first
285
-
286
- // Use defaultValue for focusedValue if it exists and is valid, otherwise use first option
287
- let focusedValue: string | undefined
288
- if (defaultValue && optionMap.get(defaultValue)) {
289
- focusedValue = defaultValue
290
- } else {
291
- focusedValue =
292
- firstOption && 'value' in firstOption ? firstOption.value : undefined
293
- }
294
-
295
- // Calculate visible range based on focused value
296
- let visibleFromIndex = 0
297
- let visibleToIndex = visibleOptionCount
298
-
299
- if (focusedValue && optionMap.get(focusedValue)) {
300
- const focusedIndex = optionMap.get(focusedValue)!.index
301
- // Center the focused option in the visible area if possible
302
- const halfVisible = Math.floor(visibleOptionCount / 2)
303
- visibleFromIndex = Math.max(0, focusedIndex - halfVisible)
304
- visibleToIndex = Math.min(
305
- flatOptions.length,
306
- visibleFromIndex + visibleOptionCount,
307
- )
308
-
309
- // Adjust if we can't show enough items at the end
310
- if (visibleToIndex - visibleFromIndex < visibleOptionCount) {
311
- visibleFromIndex = Math.max(0, visibleToIndex - visibleOptionCount)
312
- }
313
- }
314
-
315
- return {
316
- optionMap,
317
- visibleOptionCount,
318
- focusedValue,
319
- visibleFromIndex,
320
- visibleToIndex,
321
- previousValue: defaultValue,
322
- value: defaultValue,
323
- }
324
- }
325
-
326
- export const useSelectState = ({
327
- visibleOptionCount = 5,
328
- options,
329
- defaultValue,
330
- onChange,
331
- onFocus,
332
- focusValue,
333
- }: UseSelectStateProps) => {
334
- const flatOptions = flattenOptions(options)
335
-
336
- const [state, dispatch] = useReducer(
337
- reducer,
338
- { visibleOptionCount, defaultValue, options },
339
- createDefaultState,
340
- )
341
-
342
- const [lastOptions, setLastOptions] = useState(flatOptions)
343
-
344
- if (
345
- flatOptions !== lastOptions &&
346
- !isDeepStrictEqual(flatOptions, lastOptions)
347
- ) {
348
- dispatch({
349
- type: 'reset',
350
- state: createDefaultState({ visibleOptionCount, defaultValue, options }),
351
- })
352
-
353
- setLastOptions(flatOptions)
354
- }
355
-
356
- const focusNextOption = useCallback(() => {
357
- dispatch({
358
- type: 'focus-next-option',
359
- })
360
- }, [])
361
-
362
- const focusPreviousOption = useCallback(() => {
363
- dispatch({
364
- type: 'focus-previous-option',
365
- })
366
- }, [])
367
-
368
- const selectFocusedOption = useCallback(() => {
369
- dispatch({
370
- type: 'select-focused-option',
371
- })
372
- }, [])
373
-
374
- const visibleOptions = useMemo(() => {
375
- return flatOptions
376
- .map((option, index) => ({
377
- ...option,
378
- index,
379
- }))
380
- .slice(state.visibleFromIndex, state.visibleToIndex)
381
- }, [flatOptions, state.visibleFromIndex, state.visibleToIndex])
382
-
383
- useEffect(() => {
384
- if (state.value && state.previousValue !== state.value) {
385
- onChange?.(state.value)
386
- }
387
- }, [state.previousValue, state.value, options, onChange])
388
-
389
- useEffect(() => {
390
- if (state.focusedValue) {
391
- onFocus?.(state.focusedValue)
392
- }
393
- }, [state.focusedValue, onFocus])
394
-
395
- useEffect(() => {
396
- if (focusValue) {
397
- dispatch({
398
- type: 'set-focus',
399
- value: focusValue,
400
- })
401
- }
402
- }, [focusValue])
403
-
404
- return {
405
- focusedValue: state.focusedValue,
406
- visibleFromIndex: state.visibleFromIndex,
407
- visibleToIndex: state.visibleToIndex,
408
- value: state.value,
409
- visibleOptions,
410
- focusNextOption,
411
- focusPreviousOption,
412
- selectFocusedOption,
413
- }
414
- }
@@ -1,35 +0,0 @@
1
- import { useInput } from 'ink'
2
- import { type SelectState } from './use-select-state'
3
-
4
- export type UseSelectProps = {
5
- /**
6
- * When disabled, user input is ignored.
7
- *
8
- * @default false
9
- */
10
- isDisabled?: boolean
11
-
12
- /**
13
- * Select state.
14
- */
15
- state: SelectState
16
- }
17
-
18
- export const useSelect = ({ isDisabled = false, state }: UseSelectProps) => {
19
- useInput(
20
- (_input, key) => {
21
- if (key.downArrow) {
22
- state.focusNextOption()
23
- }
24
-
25
- if (key.upArrow) {
26
- state.focusPreviousOption()
27
- }
28
-
29
- if (key.return) {
30
- state.selectFocusedOption()
31
- }
32
- },
33
- { isActive: !isDisabled },
34
- )
35
- }
@@ -1,15 +0,0 @@
1
- import * as React from 'react'
2
- import { getTheme } from '../utils/theme'
3
- import { Text } from 'ink'
4
- import { PRODUCT_NAME } from '../constants/product'
5
-
6
- export function FallbackToolUseRejectedMessage(): React.ReactNode {
7
- return (
8
- <Text>
9
- &nbsp;&nbsp;⎿ &nbsp;
10
- <Text color={getTheme().error}>
11
- No (tell {PRODUCT_NAME} what to do differently)
12
- </Text>
13
- </Text>
14
- )
15
- }
@@ -1,66 +0,0 @@
1
- import { Hunk } from 'diff'
2
- import { Box, Text } from 'ink'
3
- import * as React from 'react'
4
- import { intersperse } from '../utils/array'
5
- import { StructuredDiff } from './StructuredDiff'
6
- import { getTheme } from '../utils/theme'
7
- import { getCwd } from '../utils/state'
8
- import { relative } from 'path'
9
- import { useTerminalSize } from '../hooks/useTerminalSize'
10
-
11
- type Props = {
12
- filePath: string
13
- structuredPatch: Hunk[]
14
- verbose: boolean
15
- }
16
-
17
- export function FileEditToolUpdatedMessage({
18
- filePath,
19
- structuredPatch,
20
- verbose,
21
- }: Props): React.ReactNode {
22
- const { columns } = useTerminalSize()
23
- const numAdditions = structuredPatch.reduce(
24
- (count, hunk) => count + hunk.lines.filter(_ => _.startsWith('+')).length,
25
- 0,
26
- )
27
- const numRemovals = structuredPatch.reduce(
28
- (count, hunk) => count + hunk.lines.filter(_ => _.startsWith('-')).length,
29
- 0,
30
- )
31
-
32
- return (
33
- <Box flexDirection="column">
34
- <Text>
35
- {' '}⎿ Updated{' '}
36
- <Text bold>{verbose ? filePath : relative(getCwd(), filePath)}</Text>
37
- {numAdditions > 0 || numRemovals > 0 ? ' with ' : ''}
38
- {numAdditions > 0 ? (
39
- <>
40
- <Text bold>{numAdditions}</Text>{' '}
41
- {numAdditions > 1 ? 'additions' : 'addition'}
42
- </>
43
- ) : null}
44
- {numAdditions > 0 && numRemovals > 0 ? ' and ' : null}
45
- {numRemovals > 0 ? (
46
- <>
47
- <Text bold>{numRemovals}</Text>{' '}
48
- {numRemovals > 1 ? 'removals' : 'removal'}
49
- </>
50
- ) : null}
51
- </Text>
52
- {intersperse(
53
- structuredPatch.map(_ => (
54
- <Box flexDirection="column" paddingLeft={5} key={_.newStart}>
55
- <StructuredDiff patch={_} dim={false} width={columns - 12} />
56
- </Box>
57
- )),
58
- i => (
59
- <Box paddingLeft={5} key={`ellipsis-${i}`}>
60
- <Text color={getTheme().secondaryText}>...</Text>
61
- </Box>
62
- ),
63
- )}
64
- </Box>
65
- )
66
- }