@shareai-lab/kode 1.1.14 → 1.1.16

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 +2 -1
  3. package/dist/entrypoints/cli.js.map +2 -2
  4. package/dist/index.js +5 -26
  5. package/dist/package.json +4 -1
  6. package/package.json +9 -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,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
- }