@rdmind/rdmind 0.0.15-alpha.0 → 0.0.15-alpha.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 (774) hide show
  1. package/dist/package.json +15 -10
  2. package/dist/src/commands/extensions/disable.d.ts +2 -3
  3. package/dist/src/commands/extensions/disable.js +20 -6
  4. package/dist/src/commands/extensions/disable.js.map +1 -1
  5. package/dist/src/commands/extensions/enable.d.ts +2 -3
  6. package/dist/src/commands/extensions/enable.js +21 -10
  7. package/dist/src/commands/extensions/enable.js.map +1 -1
  8. package/dist/src/commands/extensions/examples/context/QWEN.md +8 -0
  9. package/dist/src/commands/extensions/examples/context/qwen-extension.json +4 -0
  10. package/dist/src/commands/extensions/examples/custom-commands/commands/fs/grep-code.toml +6 -0
  11. package/dist/src/commands/extensions/examples/custom-commands/qwen-extension.json +4 -0
  12. package/dist/src/commands/extensions/examples/exclude-tools/qwen-extension.json +5 -0
  13. package/dist/src/commands/extensions/examples/mcp-server/example.ts +60 -0
  14. package/dist/src/commands/extensions/examples/mcp-server/package.json +18 -0
  15. package/dist/src/commands/extensions/examples/mcp-server/qwen-extension.json +11 -0
  16. package/dist/src/commands/extensions/examples/mcp-server/tsconfig.json +13 -0
  17. package/dist/src/commands/extensions/install.d.ts +3 -2
  18. package/dist/src/commands/extensions/install.js +47 -17
  19. package/dist/src/commands/extensions/install.js.map +1 -1
  20. package/dist/src/commands/extensions/install.test.js +86 -9
  21. package/dist/src/commands/extensions/install.test.js.map +1 -1
  22. package/dist/src/commands/extensions/link.d.ts +12 -0
  23. package/dist/src/commands/extensions/link.js +37 -0
  24. package/dist/src/commands/extensions/link.js.map +1 -0
  25. package/dist/src/commands/extensions/list.js +1 -1
  26. package/dist/src/commands/extensions/list.js.map +1 -1
  27. package/dist/src/commands/extensions/new.d.ts +7 -0
  28. package/dist/src/commands/extensions/new.js +90 -0
  29. package/dist/src/commands/extensions/new.js.map +1 -0
  30. package/dist/src/commands/extensions/new.test.js +59 -0
  31. package/dist/src/commands/extensions/new.test.js.map +1 -0
  32. package/dist/src/commands/extensions/uninstall.js +1 -1
  33. package/dist/src/commands/extensions/uninstall.js.map +1 -1
  34. package/dist/src/commands/extensions/uninstall.test.js +2 -2
  35. package/dist/src/commands/extensions/uninstall.test.js.map +1 -1
  36. package/dist/src/commands/extensions/update.d.ts +2 -1
  37. package/dist/src/commands/extensions/update.js +80 -14
  38. package/dist/src/commands/extensions/update.js.map +1 -1
  39. package/dist/src/commands/extensions.js +4 -0
  40. package/dist/src/commands/extensions.js.map +1 -1
  41. package/dist/src/commands/mcp/add.js +6 -1
  42. package/dist/src/commands/mcp/add.js.map +1 -1
  43. package/dist/src/commands/mcp/list.js +4 -3
  44. package/dist/src/commands/mcp/list.js.map +1 -1
  45. package/dist/src/commands/mcp/remove.js +1 -1
  46. package/dist/src/commands/mcp/remove.js.map +1 -1
  47. package/dist/src/config/auth.d.ts +1 -1
  48. package/dist/src/config/auth.js +4 -4
  49. package/dist/src/config/auth.js.map +1 -1
  50. package/dist/src/config/auth.test.js +15 -7
  51. package/dist/src/config/auth.test.js.map +1 -1
  52. package/dist/src/config/config.d.ts +7 -2
  53. package/dist/src/config/config.js +178 -122
  54. package/dist/src/config/config.js.map +1 -1
  55. package/dist/src/config/extension.d.ts +39 -16
  56. package/dist/src/config/extension.js +349 -192
  57. package/dist/src/config/extension.js.map +1 -1
  58. package/dist/src/config/extensions/extensionEnablement.d.ts +47 -0
  59. package/dist/src/config/extensions/extensionEnablement.js +189 -0
  60. package/dist/src/config/extensions/extensionEnablement.js.map +1 -0
  61. package/dist/src/{ui/components/ModelSelectionDialog.test.d.ts → config/extensions/extensionEnablement.test.d.ts} +1 -1
  62. package/dist/src/config/extensions/extensionEnablement.test.js +333 -0
  63. package/dist/src/config/extensions/extensionEnablement.test.js.map +1 -0
  64. package/dist/src/config/extensions/github.d.ts +30 -0
  65. package/dist/src/config/extensions/github.js +322 -0
  66. package/dist/src/config/extensions/github.js.map +1 -0
  67. package/dist/src/config/extensions/github.test.d.ts +6 -0
  68. package/dist/src/config/extensions/github.test.js +334 -0
  69. package/dist/src/config/extensions/github.test.js.map +1 -0
  70. package/dist/src/config/extensions/update.d.ts +19 -0
  71. package/dist/src/config/extensions/update.js +113 -0
  72. package/dist/src/config/extensions/update.js.map +1 -0
  73. package/dist/src/config/extensions/update.test.d.ts +6 -0
  74. package/dist/src/config/extensions/update.test.js +342 -0
  75. package/dist/src/config/extensions/update.test.js.map +1 -0
  76. package/dist/src/config/extensions/variableSchema.d.ts +8 -0
  77. package/dist/src/config/extensions/variableSchema.js +4 -0
  78. package/dist/src/config/extensions/variableSchema.js.map +1 -1
  79. package/dist/src/config/keyBindings.d.ts +5 -1
  80. package/dist/src/config/keyBindings.js +14 -25
  81. package/dist/src/config/keyBindings.js.map +1 -1
  82. package/dist/src/config/settings.d.ts +8 -5
  83. package/dist/src/config/settings.js +178 -275
  84. package/dist/src/config/settings.js.map +1 -1
  85. package/dist/src/config/settingsSchema.d.ts +332 -141
  86. package/dist/src/config/settingsSchema.js +321 -153
  87. package/dist/src/config/settingsSchema.js.map +1 -1
  88. package/dist/src/config/settingsSchema.test.js +64 -57
  89. package/dist/src/config/settingsSchema.test.js.map +1 -1
  90. package/dist/src/config/trustedFolders.d.ts +23 -4
  91. package/dist/src/config/trustedFolders.js +97 -47
  92. package/dist/src/config/trustedFolders.js.map +1 -1
  93. package/dist/src/config/trustedFolders.test.js +196 -20
  94. package/dist/src/config/trustedFolders.test.js.map +1 -1
  95. package/dist/src/core/auth.d.ts +13 -0
  96. package/dist/src/core/auth.js +27 -0
  97. package/dist/src/core/auth.js.map +1 -0
  98. package/dist/src/core/initializer.d.ts +21 -0
  99. package/dist/src/core/initializer.js +33 -0
  100. package/dist/src/core/initializer.js.map +1 -0
  101. package/dist/src/core/theme.d.ts +12 -0
  102. package/dist/src/core/theme.js +20 -0
  103. package/dist/src/core/theme.js.map +1 -0
  104. package/dist/src/gemini.d.ts +3 -2
  105. package/dist/src/gemini.js +156 -128
  106. package/dist/src/gemini.js.map +1 -1
  107. package/dist/src/gemini.test.js +190 -47
  108. package/dist/src/gemini.test.js.map +1 -1
  109. package/dist/src/generated/git-commit.d.ts +2 -2
  110. package/dist/src/generated/git-commit.js +2 -2
  111. package/dist/src/nonInteractiveCli.d.ts +2 -1
  112. package/dist/src/nonInteractiveCli.js +101 -72
  113. package/dist/src/nonInteractiveCli.js.map +1 -1
  114. package/dist/src/nonInteractiveCliCommands.d.ts +17 -0
  115. package/dist/src/nonInteractiveCliCommands.js +79 -0
  116. package/dist/src/nonInteractiveCliCommands.js.map +1 -0
  117. package/dist/src/services/BuiltinCommandLoader.js +1 -1
  118. package/dist/src/services/BuiltinCommandLoader.js.map +1 -1
  119. package/dist/src/services/BuiltinCommandLoader.test.js +30 -18
  120. package/dist/src/services/BuiltinCommandLoader.test.js.map +1 -1
  121. package/dist/src/services/FileCommandLoader.d.ts +2 -0
  122. package/dist/src/services/FileCommandLoader.js +7 -0
  123. package/dist/src/services/FileCommandLoader.js.map +1 -1
  124. package/dist/src/services/McpPromptLoader.js +43 -8
  125. package/dist/src/services/McpPromptLoader.js.map +1 -1
  126. package/dist/src/services/McpPromptLoader.test.js +228 -1
  127. package/dist/src/services/McpPromptLoader.test.js.map +1 -1
  128. package/dist/src/services/prompt-processors/shellProcessor.js +8 -1
  129. package/dist/src/services/prompt-processors/shellProcessor.js.map +1 -1
  130. package/dist/src/test-utils/createExtension.d.ts +15 -0
  131. package/dist/src/test-utils/createExtension.js +25 -0
  132. package/dist/src/test-utils/createExtension.js.map +1 -0
  133. package/dist/src/test-utils/mockCommandContext.js +2 -0
  134. package/dist/src/test-utils/mockCommandContext.js.map +1 -1
  135. package/dist/src/test-utils/render.d.ts +5 -1
  136. package/dist/src/test-utils/render.js +5 -1
  137. package/dist/src/test-utils/render.js.map +1 -1
  138. package/dist/src/ui/App.d.ts +1 -10
  139. package/dist/src/ui/App.js +26 -834
  140. package/dist/src/ui/App.js.map +1 -1
  141. package/dist/src/ui/AppContainer.d.ts +17 -0
  142. package/dist/src/ui/AppContainer.js +1062 -0
  143. package/dist/src/ui/AppContainer.js.map +1 -0
  144. package/dist/src/ui/AppContainer.test.d.ts +6 -0
  145. package/dist/src/ui/AppContainer.test.js +831 -0
  146. package/dist/src/ui/AppContainer.test.js.map +1 -0
  147. package/dist/src/ui/IdeIntegrationNudge.d.ts +2 -2
  148. package/dist/src/ui/IdeIntegrationNudge.js +6 -8
  149. package/dist/src/ui/IdeIntegrationNudge.js.map +1 -1
  150. package/dist/src/ui/{components → auth}/AuthDialog.js +8 -4
  151. package/dist/src/ui/auth/AuthDialog.js.map +1 -0
  152. package/dist/src/ui/auth/AuthDialog.test.d.ts +6 -0
  153. package/dist/src/ui/{components → auth}/AuthDialog.test.js +92 -10
  154. package/dist/src/ui/auth/AuthDialog.test.js.map +1 -0
  155. package/dist/src/ui/{components → auth}/AuthInProgress.js +2 -2
  156. package/dist/src/ui/auth/AuthInProgress.js.map +1 -0
  157. package/dist/src/ui/{hooks/useAuthCommand.d.ts → auth/useAuth.d.ts} +9 -3
  158. package/dist/src/ui/{hooks/useAuthCommand.js → auth/useAuth.js} +49 -14
  159. package/dist/src/ui/auth/useAuth.js.map +1 -0
  160. package/dist/src/ui/commands/aboutCommand.js +9 -3
  161. package/dist/src/ui/commands/aboutCommand.js.map +1 -1
  162. package/dist/src/ui/commands/chatCommand.d.ts +2 -0
  163. package/dist/src/ui/commands/chatCommand.js +93 -3
  164. package/dist/src/ui/commands/chatCommand.js.map +1 -1
  165. package/dist/src/ui/commands/clearCommand.js +1 -1
  166. package/dist/src/ui/commands/clearCommand.js.map +1 -1
  167. package/dist/src/ui/commands/corgiCommand.js +1 -0
  168. package/dist/src/ui/commands/corgiCommand.js.map +1 -1
  169. package/dist/src/ui/commands/directoryCommand.d.ts +1 -0
  170. package/dist/src/ui/commands/directoryCommand.js +156 -4
  171. package/dist/src/ui/commands/directoryCommand.js.map +1 -1
  172. package/dist/src/ui/commands/extensionsCommand.js +92 -15
  173. package/dist/src/ui/commands/extensionsCommand.js.map +1 -1
  174. package/dist/src/ui/commands/ideCommand.d.ts +1 -2
  175. package/dist/src/ui/commands/ideCommand.js +19 -10
  176. package/dist/src/ui/commands/ideCommand.js.map +1 -1
  177. package/dist/src/ui/commands/mcpCommand.js +88 -261
  178. package/dist/src/ui/commands/mcpCommand.js.map +1 -1
  179. package/dist/src/ui/commands/memoryCommand.js +1 -1
  180. package/dist/src/ui/commands/memoryCommand.js.map +1 -1
  181. package/dist/src/ui/commands/modelCommand.js +1 -16
  182. package/dist/src/ui/commands/modelCommand.js.map +1 -1
  183. package/dist/src/ui/commands/modelCommand.test.js +10 -11
  184. package/dist/src/ui/commands/modelCommand.test.js.map +1 -1
  185. package/dist/src/ui/commands/summaryCommand.js +1 -1
  186. package/dist/src/ui/commands/summaryCommand.js.map +1 -1
  187. package/dist/src/ui/commands/toolsCommand.js +10 -24
  188. package/dist/src/ui/commands/toolsCommand.js.map +1 -1
  189. package/dist/src/ui/commands/types.d.ts +7 -2
  190. package/dist/src/ui/commands/types.js +0 -1
  191. package/dist/src/ui/commands/types.js.map +1 -1
  192. package/dist/src/ui/components/AboutBox.js +2 -2
  193. package/dist/src/ui/components/AboutBox.js.map +1 -1
  194. package/dist/src/ui/components/AnsiOutput.d.ts +13 -0
  195. package/dist/src/ui/components/AnsiOutput.js +12 -0
  196. package/dist/src/ui/components/AnsiOutput.js.map +1 -0
  197. package/dist/src/ui/components/AnsiOutput.test.d.ts +6 -0
  198. package/dist/src/ui/components/AnsiOutput.test.js +97 -0
  199. package/dist/src/ui/components/AnsiOutput.test.js.map +1 -0
  200. package/dist/src/ui/components/AppHeader.d.ts +10 -0
  201. package/dist/src/ui/components/AppHeader.js +19 -0
  202. package/dist/src/ui/components/AppHeader.js.map +1 -0
  203. package/dist/src/ui/components/AutoAcceptIndicator.js +5 -5
  204. package/dist/src/ui/components/AutoAcceptIndicator.js.map +1 -1
  205. package/dist/src/ui/components/Composer.d.ts +6 -0
  206. package/dist/src/ui/components/Composer.js +54 -0
  207. package/dist/src/ui/components/Composer.js.map +1 -0
  208. package/dist/src/ui/components/Composer.test.d.ts +6 -0
  209. package/dist/src/ui/components/Composer.test.js +337 -0
  210. package/dist/src/ui/components/Composer.test.js.map +1 -0
  211. package/dist/src/ui/components/ConfigInitDisplay.d.ts +6 -0
  212. package/dist/src/ui/components/ConfigInitDisplay.js +38 -0
  213. package/dist/src/ui/components/ConfigInitDisplay.js.map +1 -0
  214. package/dist/src/ui/components/ConsentPrompt.d.ts +13 -0
  215. package/dist/src/ui/components/ConsentPrompt.js +19 -0
  216. package/dist/src/ui/components/ConsentPrompt.js.map +1 -0
  217. package/dist/src/ui/components/ConsentPrompt.test.d.ts +6 -0
  218. package/dist/src/ui/components/ConsentPrompt.test.js +67 -0
  219. package/dist/src/ui/components/ConsentPrompt.test.js.map +1 -0
  220. package/dist/src/ui/components/ConsoleSummaryDisplay.js +2 -2
  221. package/dist/src/ui/components/ConsoleSummaryDisplay.js.map +1 -1
  222. package/dist/src/ui/components/ContextSummaryDisplay.js +3 -3
  223. package/dist/src/ui/components/ContextSummaryDisplay.js.map +1 -1
  224. package/dist/src/ui/components/ContextUsageDisplay.d.ts +2 -1
  225. package/dist/src/ui/components/ContextUsageDisplay.js +5 -3
  226. package/dist/src/ui/components/ContextUsageDisplay.js.map +1 -1
  227. package/dist/src/ui/components/DebugProfiler.js +2 -2
  228. package/dist/src/ui/components/DebugProfiler.js.map +1 -1
  229. package/dist/src/ui/components/DetailedMessagesDisplay.js +7 -7
  230. package/dist/src/ui/components/DetailedMessagesDisplay.js.map +1 -1
  231. package/dist/src/ui/components/DialogManager.d.ts +12 -0
  232. package/dist/src/ui/components/DialogManager.js +129 -0
  233. package/dist/src/ui/components/DialogManager.js.map +1 -0
  234. package/dist/src/ui/components/EditorSettingsDialog.js +16 -7
  235. package/dist/src/ui/components/EditorSettingsDialog.js.map +1 -1
  236. package/dist/src/ui/components/ExitWarning.d.ts +7 -0
  237. package/dist/src/ui/components/ExitWarning.js +9 -0
  238. package/dist/src/ui/components/ExitWarning.js.map +1 -0
  239. package/dist/src/ui/components/FolderTrustDialog.js +22 -9
  240. package/dist/src/ui/components/FolderTrustDialog.js.map +1 -1
  241. package/dist/src/ui/components/FolderTrustDialog.test.js +37 -12
  242. package/dist/src/ui/components/FolderTrustDialog.test.js.map +1 -1
  243. package/dist/src/ui/components/Footer.d.ts +1 -17
  244. package/dist/src/ui/components/Footer.js +33 -11
  245. package/dist/src/ui/components/Footer.js.map +1 -1
  246. package/dist/src/ui/components/GeminiRespondingSpinner.d.ts +5 -0
  247. package/dist/src/ui/components/GeminiRespondingSpinner.js +7 -2
  248. package/dist/src/ui/components/GeminiRespondingSpinner.js.map +1 -1
  249. package/dist/src/ui/components/Header.js +2 -2
  250. package/dist/src/ui/components/Header.js.map +1 -1
  251. package/dist/src/ui/components/Help.d.ts +1 -1
  252. package/dist/src/ui/components/Help.js +9 -6
  253. package/dist/src/ui/components/Help.js.map +1 -1
  254. package/dist/src/ui/components/Help.test.d.ts +6 -0
  255. package/dist/src/ui/components/Help.test.js +57 -0
  256. package/dist/src/ui/components/Help.test.js.map +1 -0
  257. package/dist/src/ui/components/HistoryItemDisplay.d.ts +5 -4
  258. package/dist/src/ui/components/HistoryItemDisplay.js +13 -4
  259. package/dist/src/ui/components/HistoryItemDisplay.js.map +1 -1
  260. package/dist/src/ui/components/HistoryItemDisplay.test.js +90 -9
  261. package/dist/src/ui/components/HistoryItemDisplay.test.js.map +1 -1
  262. package/dist/src/ui/components/IdeTrustChangeDialog.d.ts +11 -0
  263. package/dist/src/ui/components/IdeTrustChangeDialog.js +32 -0
  264. package/dist/src/ui/components/IdeTrustChangeDialog.js.map +1 -0
  265. package/dist/src/ui/components/IdeTrustChangeDialog.test.d.ts +6 -0
  266. package/dist/src/ui/components/IdeTrustChangeDialog.test.js +57 -0
  267. package/dist/src/ui/components/IdeTrustChangeDialog.test.js.map +1 -0
  268. package/dist/src/ui/components/InputPrompt.d.ts +9 -0
  269. package/dist/src/ui/components/InputPrompt.js +192 -45
  270. package/dist/src/ui/components/InputPrompt.js.map +1 -1
  271. package/dist/src/ui/components/LoadingIndicator.js +2 -2
  272. package/dist/src/ui/components/LoadingIndicator.js.map +1 -1
  273. package/dist/src/ui/components/LoadingIndicator.test.js +4 -0
  274. package/dist/src/ui/components/LoadingIndicator.test.js.map +1 -1
  275. package/dist/src/ui/components/LoopDetectionConfirmation.d.ts +13 -0
  276. package/dist/src/ui/components/LoopDetectionConfirmation.js +37 -0
  277. package/dist/src/ui/components/LoopDetectionConfirmation.js.map +1 -0
  278. package/dist/src/ui/components/LoopDetectionConfirmation.test.d.ts +6 -0
  279. package/dist/src/ui/components/LoopDetectionConfirmation.test.js +28 -0
  280. package/dist/src/ui/components/LoopDetectionConfirmation.test.js.map +1 -0
  281. package/dist/src/ui/components/MainContent.d.ts +6 -0
  282. package/dist/src/ui/components/MainContent.js +28 -0
  283. package/dist/src/ui/components/MainContent.js.map +1 -0
  284. package/dist/src/ui/components/MemoryUsageDisplay.js +6 -4
  285. package/dist/src/ui/components/MemoryUsageDisplay.js.map +1 -1
  286. package/dist/src/ui/components/ModelDialog.d.ts +11 -0
  287. package/dist/src/ui/components/ModelDialog.js +42 -0
  288. package/dist/src/ui/components/ModelDialog.js.map +1 -0
  289. package/dist/src/ui/components/ModelDialog.test.d.ts +6 -0
  290. package/dist/src/ui/components/ModelDialog.test.js +158 -0
  291. package/dist/src/ui/components/ModelDialog.test.js.map +1 -0
  292. package/dist/src/ui/components/ModelStatsDisplay.js +7 -7
  293. package/dist/src/ui/components/ModelStatsDisplay.js.map +1 -1
  294. package/dist/src/ui/components/ModelSwitchDialog.js +3 -0
  295. package/dist/src/ui/components/ModelSwitchDialog.js.map +1 -1
  296. package/dist/src/ui/components/ModelSwitchDialog.test.js +3 -0
  297. package/dist/src/ui/components/ModelSwitchDialog.test.js.map +1 -1
  298. package/dist/src/ui/components/Notifications.d.ts +6 -0
  299. package/dist/src/ui/components/Notifications.js +23 -0
  300. package/dist/src/ui/components/Notifications.js.map +1 -0
  301. package/dist/src/ui/components/OpenAIKeyPrompt.js +63 -39
  302. package/dist/src/ui/components/OpenAIKeyPrompt.js.map +1 -1
  303. package/dist/src/ui/components/OpenAIKeyPrompt.test.js +8 -1
  304. package/dist/src/ui/components/OpenAIKeyPrompt.test.js.map +1 -1
  305. package/dist/src/ui/components/PermissionsModifyTrustDialog.d.ts +13 -0
  306. package/dist/src/ui/components/PermissionsModifyTrustDialog.js +48 -0
  307. package/dist/src/ui/components/PermissionsModifyTrustDialog.js.map +1 -0
  308. package/dist/src/ui/components/PermissionsModifyTrustDialog.test.d.ts +6 -0
  309. package/dist/src/ui/components/PermissionsModifyTrustDialog.test.js +154 -0
  310. package/dist/src/ui/components/PermissionsModifyTrustDialog.test.js.map +1 -0
  311. package/dist/src/ui/components/PrepareLabel.d.ts +5 -5
  312. package/dist/src/ui/components/PrepareLabel.js +67 -11
  313. package/dist/src/ui/components/PrepareLabel.js.map +1 -1
  314. package/dist/src/ui/components/PrepareLabel.test.d.ts +6 -0
  315. package/dist/src/ui/components/PrepareLabel.test.js +71 -0
  316. package/dist/src/ui/components/PrepareLabel.test.js.map +1 -0
  317. package/dist/src/ui/components/ProQuotaDialog.d.ts +13 -0
  318. package/dist/src/ui/components/ProQuotaDialog.js +23 -0
  319. package/dist/src/ui/components/ProQuotaDialog.js.map +1 -0
  320. package/dist/src/ui/components/ProQuotaDialog.test.d.ts +6 -0
  321. package/dist/src/ui/components/ProQuotaDialog.test.js +58 -0
  322. package/dist/src/ui/components/ProQuotaDialog.test.js.map +1 -0
  323. package/dist/src/ui/components/QueuedMessageDisplay.d.ts +9 -0
  324. package/dist/src/ui/components/QueuedMessageDisplay.js +20 -0
  325. package/dist/src/ui/components/QueuedMessageDisplay.js.map +1 -0
  326. package/dist/src/ui/components/QueuedMessageDisplay.test.d.ts +6 -0
  327. package/dist/src/ui/components/QueuedMessageDisplay.test.js +56 -0
  328. package/dist/src/ui/components/QueuedMessageDisplay.test.js.map +1 -0
  329. package/dist/src/ui/components/QuitConfirmationDialog.js +4 -0
  330. package/dist/src/ui/components/QuitConfirmationDialog.js.map +1 -1
  331. package/dist/src/ui/components/QuittingDisplay.d.ts +6 -0
  332. package/dist/src/ui/components/QuittingDisplay.js +20 -0
  333. package/dist/src/ui/components/QuittingDisplay.js.map +1 -0
  334. package/dist/src/ui/components/QwenOAuthProgress.js +5 -4
  335. package/dist/src/ui/components/QwenOAuthProgress.js.map +1 -1
  336. package/dist/src/ui/components/QwenOAuthProgress.test.js +82 -11
  337. package/dist/src/ui/components/QwenOAuthProgress.test.js.map +1 -1
  338. package/dist/src/ui/components/SettingsDialog.d.ts +2 -1
  339. package/dist/src/ui/components/SettingsDialog.js +97 -23
  340. package/dist/src/ui/components/SettingsDialog.js.map +1 -1
  341. package/dist/src/ui/components/SettingsDialog.test.js +474 -84
  342. package/dist/src/ui/components/SettingsDialog.test.js.map +1 -1
  343. package/dist/src/ui/components/ShellConfirmationDialog.js +5 -2
  344. package/dist/src/ui/components/ShellConfirmationDialog.js.map +1 -1
  345. package/dist/src/ui/components/ShellInputPrompt.d.ts +11 -0
  346. package/dist/src/ui/components/ShellInputPrompt.js +36 -0
  347. package/dist/src/ui/components/ShellInputPrompt.js.map +1 -0
  348. package/dist/src/ui/components/ShellModeIndicator.js +2 -2
  349. package/dist/src/ui/components/ShellModeIndicator.js.map +1 -1
  350. package/dist/src/ui/components/ShowMoreLines.js +2 -2
  351. package/dist/src/ui/components/ShowMoreLines.js.map +1 -1
  352. package/dist/src/ui/components/StatsDisplay.js +6 -6
  353. package/dist/src/ui/components/StatsDisplay.js.map +1 -1
  354. package/dist/src/ui/components/SuggestionsDisplay.d.ts +7 -2
  355. package/dist/src/ui/components/SuggestionsDisplay.js +17 -17
  356. package/dist/src/ui/components/SuggestionsDisplay.js.map +1 -1
  357. package/dist/src/ui/components/ThemeDialog.js +14 -29
  358. package/dist/src/ui/components/ThemeDialog.js.map +1 -1
  359. package/dist/src/ui/components/ThemeDialog.test.d.ts +6 -0
  360. package/dist/src/ui/components/ThemeDialog.test.js +75 -0
  361. package/dist/src/ui/components/ThemeDialog.test.js.map +1 -0
  362. package/dist/src/ui/components/Tips.js +2 -2
  363. package/dist/src/ui/components/Tips.js.map +1 -1
  364. package/dist/src/ui/components/ToolStatsDisplay.js +4 -4
  365. package/dist/src/ui/components/ToolStatsDisplay.js.map +1 -1
  366. package/dist/src/ui/components/UpdateNotification.js +2 -2
  367. package/dist/src/ui/components/UpdateNotification.js.map +1 -1
  368. package/dist/src/ui/components/WelcomeBackDialog.js +2 -0
  369. package/dist/src/ui/components/WelcomeBackDialog.js.map +1 -1
  370. package/dist/src/ui/components/WorkspaceMigrationDialog.js +14 -11
  371. package/dist/src/ui/components/WorkspaceMigrationDialog.js.map +1 -1
  372. package/dist/src/ui/components/messages/CompressionMessage.d.ts +1 -2
  373. package/dist/src/ui/components/messages/CompressionMessage.js +37 -8
  374. package/dist/src/ui/components/messages/CompressionMessage.js.map +1 -1
  375. package/dist/src/ui/components/messages/CompressionMessage.test.d.ts +6 -0
  376. package/dist/src/ui/components/messages/CompressionMessage.test.js +160 -0
  377. package/dist/src/ui/components/messages/CompressionMessage.test.js.map +1 -0
  378. package/dist/src/ui/components/messages/DiffRenderer.d.ts +2 -1
  379. package/dist/src/ui/components/messages/DiffRenderer.js +14 -22
  380. package/dist/src/ui/components/messages/DiffRenderer.js.map +1 -1
  381. package/dist/src/ui/components/messages/ErrorMessage.js +2 -2
  382. package/dist/src/ui/components/messages/ErrorMessage.js.map +1 -1
  383. package/dist/src/ui/components/messages/GeminiMessage.js +2 -2
  384. package/dist/src/ui/components/messages/GeminiMessage.js.map +1 -1
  385. package/dist/src/ui/components/messages/InfoMessage.js +2 -2
  386. package/dist/src/ui/components/messages/InfoMessage.js.map +1 -1
  387. package/dist/src/ui/components/messages/ToolConfirmationMessage.js +53 -21
  388. package/dist/src/ui/components/messages/ToolConfirmationMessage.js.map +1 -1
  389. package/dist/src/ui/components/messages/ToolConfirmationMessage.test.js +0 -8
  390. package/dist/src/ui/components/messages/ToolConfirmationMessage.test.js.map +1 -1
  391. package/dist/src/ui/components/messages/ToolGroupMessage.d.ts +3 -2
  392. package/dist/src/ui/components/messages/ToolGroupMessage.js +18 -10
  393. package/dist/src/ui/components/messages/ToolGroupMessage.js.map +1 -1
  394. package/dist/src/ui/components/messages/ToolGroupMessage.test.js +17 -15
  395. package/dist/src/ui/components/messages/ToolGroupMessage.test.js.map +1 -1
  396. package/dist/src/ui/components/messages/ToolMessage.d.ts +3 -1
  397. package/dist/src/ui/components/messages/ToolMessage.js +53 -11
  398. package/dist/src/ui/components/messages/ToolMessage.js.map +1 -1
  399. package/dist/src/ui/components/messages/ToolMessage.test.js +34 -1
  400. package/dist/src/ui/components/messages/ToolMessage.test.js.map +1 -1
  401. package/dist/src/ui/components/messages/UserMessage.js +3 -4
  402. package/dist/src/ui/components/messages/UserMessage.js.map +1 -1
  403. package/dist/src/ui/components/messages/UserShellMessage.js +2 -2
  404. package/dist/src/ui/components/messages/UserShellMessage.js.map +1 -1
  405. package/dist/src/ui/components/messages/WarningMessage.d.ts +11 -0
  406. package/dist/src/ui/components/messages/WarningMessage.js +10 -0
  407. package/dist/src/ui/components/messages/WarningMessage.js.map +1 -0
  408. package/dist/src/ui/components/shared/BaseSelectionList.d.ts +38 -0
  409. package/dist/src/ui/components/shared/BaseSelectionList.js +72 -0
  410. package/dist/src/ui/components/shared/BaseSelectionList.js.map +1 -0
  411. package/dist/src/ui/components/shared/BaseSelectionList.test.d.ts +6 -0
  412. package/dist/src/ui/components/shared/BaseSelectionList.test.js +376 -0
  413. package/dist/src/ui/components/shared/BaseSelectionList.test.js.map +1 -0
  414. package/dist/src/ui/components/shared/DescriptiveRadioButtonSelect.d.ts +35 -0
  415. package/dist/src/ui/components/shared/DescriptiveRadioButtonSelect.js +13 -0
  416. package/dist/src/ui/components/shared/DescriptiveRadioButtonSelect.js.map +1 -0
  417. package/dist/src/ui/components/shared/DescriptiveRadioButtonSelect.test.d.ts +6 -0
  418. package/dist/src/ui/components/shared/DescriptiveRadioButtonSelect.test.js +79 -0
  419. package/dist/src/ui/components/shared/DescriptiveRadioButtonSelect.test.js.map +1 -0
  420. package/dist/src/ui/components/shared/EnumSelector.d.ts +18 -0
  421. package/dist/src/ui/components/shared/EnumSelector.js +44 -0
  422. package/dist/src/ui/components/shared/EnumSelector.js.map +1 -0
  423. package/dist/src/ui/components/shared/EnumSelector.test.d.ts +6 -0
  424. package/dist/src/ui/components/shared/EnumSelector.test.js +70 -0
  425. package/dist/src/ui/components/shared/EnumSelector.test.js.map +1 -0
  426. package/dist/src/ui/components/shared/MaxSizedBox.js +2 -2
  427. package/dist/src/ui/components/shared/MaxSizedBox.js.map +1 -1
  428. package/dist/src/ui/components/shared/RadioButtonSelect.d.ts +2 -3
  429. package/dist/src/ui/components/shared/RadioButtonSelect.js +10 -105
  430. package/dist/src/ui/components/shared/RadioButtonSelect.js.map +1 -1
  431. package/dist/src/ui/components/shared/RadioButtonSelect.test.js +115 -92
  432. package/dist/src/ui/components/shared/RadioButtonSelect.test.js.map +1 -1
  433. package/dist/src/ui/components/shared/ScopeSelector.d.ts +19 -0
  434. package/dist/src/ui/components/shared/ScopeSelector.js +14 -0
  435. package/dist/src/ui/components/shared/ScopeSelector.js.map +1 -0
  436. package/dist/src/ui/components/shared/text-buffer.d.ts +25 -2
  437. package/dist/src/ui/components/shared/text-buffer.js +296 -187
  438. package/dist/src/ui/components/shared/text-buffer.js.map +1 -1
  439. package/dist/src/ui/components/subagents/create/AgentCreationWizard.js +2 -3
  440. package/dist/src/ui/components/subagents/create/AgentCreationWizard.js.map +1 -1
  441. package/dist/src/ui/components/subagents/create/ColorSelector.js +3 -2
  442. package/dist/src/ui/components/subagents/create/ColorSelector.js.map +1 -1
  443. package/dist/src/ui/components/subagents/create/CreationSummary.js +6 -5
  444. package/dist/src/ui/components/subagents/create/CreationSummary.js.map +1 -1
  445. package/dist/src/ui/components/subagents/create/DescriptionInput.js +2 -3
  446. package/dist/src/ui/components/subagents/create/DescriptionInput.js.map +1 -1
  447. package/dist/src/ui/components/subagents/create/GenerationMethodSelector.js +1 -0
  448. package/dist/src/ui/components/subagents/create/GenerationMethodSelector.js.map +1 -1
  449. package/dist/src/ui/components/subagents/create/LocationSelector.js +1 -0
  450. package/dist/src/ui/components/subagents/create/LocationSelector.js.map +1 -1
  451. package/dist/src/ui/components/subagents/create/TextEntryStep.js +2 -2
  452. package/dist/src/ui/components/subagents/create/TextEntryStep.js.map +1 -1
  453. package/dist/src/ui/components/subagents/create/ToolSelector.js +4 -3
  454. package/dist/src/ui/components/subagents/create/ToolSelector.js.map +1 -1
  455. package/dist/src/ui/components/subagents/manage/ActionSelectionStep.js +4 -4
  456. package/dist/src/ui/components/subagents/manage/ActionSelectionStep.js.map +1 -1
  457. package/dist/src/ui/components/subagents/manage/AgentEditStep.js +1 -0
  458. package/dist/src/ui/components/subagents/manage/AgentEditStep.js.map +1 -1
  459. package/dist/src/ui/components/subagents/manage/AgentSelectionStep.js +1 -2
  460. package/dist/src/ui/components/subagents/manage/AgentSelectionStep.js.map +1 -1
  461. package/dist/src/ui/components/subagents/manage/AgentsManagerDialog.js +1 -2
  462. package/dist/src/ui/components/subagents/manage/AgentsManagerDialog.js.map +1 -1
  463. package/dist/src/ui/components/subagents/runtime/AgentExecutionDisplay.js +9 -10
  464. package/dist/src/ui/components/subagents/runtime/AgentExecutionDisplay.js.map +1 -1
  465. package/dist/src/ui/components/views/ExtensionsList.d.ts +6 -0
  466. package/dist/src/ui/components/views/ExtensionsList.js +47 -0
  467. package/dist/src/ui/components/views/ExtensionsList.js.map +1 -0
  468. package/dist/src/ui/components/views/ExtensionsList.test.d.ts +6 -0
  469. package/dist/src/ui/components/views/ExtensionsList.test.js +97 -0
  470. package/dist/src/ui/components/views/ExtensionsList.test.js.map +1 -0
  471. package/dist/src/ui/components/views/McpStatus.d.ts +27 -0
  472. package/dist/src/ui/components/views/McpStatus.js +77 -0
  473. package/dist/src/ui/components/views/McpStatus.js.map +1 -0
  474. package/dist/src/ui/components/views/McpStatus.test.d.ts +6 -0
  475. package/dist/src/ui/components/views/McpStatus.test.js +117 -0
  476. package/dist/src/ui/components/views/McpStatus.test.js.map +1 -0
  477. package/dist/src/ui/components/views/ToolsList.d.ts +14 -0
  478. package/dist/src/ui/components/views/ToolsList.js +7 -0
  479. package/dist/src/ui/components/views/ToolsList.js.map +1 -0
  480. package/dist/src/ui/components/views/ToolsList.test.d.ts +6 -0
  481. package/dist/src/ui/components/views/ToolsList.test.js +45 -0
  482. package/dist/src/ui/components/views/ToolsList.test.js.map +1 -0
  483. package/dist/src/ui/constants.d.ts +1 -0
  484. package/dist/src/ui/constants.js +1 -0
  485. package/dist/src/ui/constants.js.map +1 -1
  486. package/dist/src/ui/contexts/AppContext.d.ts +11 -0
  487. package/dist/src/ui/contexts/AppContext.js +15 -0
  488. package/dist/src/ui/contexts/AppContext.js.map +1 -0
  489. package/dist/src/ui/contexts/ConfigContext.d.ts +9 -0
  490. package/dist/src/ui/contexts/ConfigContext.js +16 -0
  491. package/dist/src/ui/contexts/ConfigContext.js.map +1 -0
  492. package/dist/src/ui/contexts/KeypressContext.d.ts +3 -0
  493. package/dist/src/ui/contexts/KeypressContext.js +309 -44
  494. package/dist/src/ui/contexts/KeypressContext.js.map +1 -1
  495. package/dist/src/ui/contexts/KeypressContext.test.js +288 -2
  496. package/dist/src/ui/contexts/KeypressContext.test.js.map +1 -1
  497. package/dist/src/ui/contexts/SessionContext.d.ts +6 -0
  498. package/dist/src/ui/contexts/SessionContext.js +107 -5
  499. package/dist/src/ui/contexts/SessionContext.js.map +1 -1
  500. package/dist/src/ui/contexts/ShellFocusContext.d.ts +7 -0
  501. package/dist/src/ui/contexts/ShellFocusContext.js +9 -0
  502. package/dist/src/ui/contexts/ShellFocusContext.js.map +1 -0
  503. package/dist/src/ui/contexts/UIActionsContext.d.ts +45 -0
  504. package/dist/src/ui/contexts/UIActionsContext.js +21 -0
  505. package/dist/src/ui/contexts/UIActionsContext.js.map +1 -0
  506. package/dist/src/ui/contexts/UIStateContext.d.ts +117 -0
  507. package/dist/src/ui/contexts/UIStateContext.js +17 -0
  508. package/dist/src/ui/contexts/UIStateContext.js.map +1 -0
  509. package/dist/src/ui/hooks/atCommandProcessor.js +12 -12
  510. package/dist/src/ui/hooks/atCommandProcessor.js.map +1 -1
  511. package/dist/src/ui/hooks/atCommandProcessor.test.js +21 -19
  512. package/dist/src/ui/hooks/atCommandProcessor.test.js.map +1 -1
  513. package/dist/src/ui/hooks/keyToAnsi.d.ts +15 -0
  514. package/dist/src/ui/hooks/keyToAnsi.js +67 -0
  515. package/dist/src/ui/hooks/keyToAnsi.js.map +1 -0
  516. package/dist/src/ui/hooks/shellCommandProcessor.d.ts +2 -1
  517. package/dist/src/ui/hooks/shellCommandProcessor.js +65 -15
  518. package/dist/src/ui/hooks/shellCommandProcessor.js.map +1 -1
  519. package/dist/src/ui/hooks/shellCommandProcessor.test.js +196 -17
  520. package/dist/src/ui/hooks/shellCommandProcessor.test.js.map +1 -1
  521. package/dist/src/ui/hooks/slashCommandProcessor.d.ts +20 -2
  522. package/dist/src/ui/hooks/slashCommandProcessor.js +41 -82
  523. package/dist/src/ui/hooks/slashCommandProcessor.js.map +1 -1
  524. package/dist/src/ui/hooks/useAtCompletion.js +1 -1
  525. package/dist/src/ui/hooks/useAtCompletion.js.map +1 -1
  526. package/dist/src/ui/hooks/useAutoAcceptIndicator.d.ts +3 -2
  527. package/dist/src/ui/hooks/useAutoAcceptIndicator.js +20 -18
  528. package/dist/src/ui/hooks/useAutoAcceptIndicator.js.map +1 -1
  529. package/dist/src/ui/hooks/useAutoAcceptIndicator.test.js +43 -0
  530. package/dist/src/ui/hooks/useAutoAcceptIndicator.test.js.map +1 -1
  531. package/dist/src/ui/hooks/useExtensionUpdates.d.ts +21 -0
  532. package/dist/src/ui/hooks/useExtensionUpdates.js +116 -0
  533. package/dist/src/ui/hooks/useExtensionUpdates.js.map +1 -0
  534. package/dist/src/ui/hooks/useExtensionUpdates.test.d.ts +6 -0
  535. package/dist/src/ui/hooks/useExtensionUpdates.test.js +243 -0
  536. package/dist/src/ui/hooks/useExtensionUpdates.test.js.map +1 -0
  537. package/dist/src/ui/hooks/useFocus.js +10 -0
  538. package/dist/src/ui/hooks/useFocus.js.map +1 -1
  539. package/dist/src/ui/hooks/useFolderTrust.js +6 -10
  540. package/dist/src/ui/hooks/useFolderTrust.js.map +1 -1
  541. package/dist/src/ui/hooks/useGeminiStream.d.ts +14 -3
  542. package/dist/src/ui/hooks/useGeminiStream.js +173 -79
  543. package/dist/src/ui/hooks/useGeminiStream.js.map +1 -1
  544. package/dist/src/ui/hooks/useGitBranchName.js +15 -18
  545. package/dist/src/ui/hooks/useGitBranchName.js.map +1 -1
  546. package/dist/src/ui/hooks/useGitBranchName.test.js +49 -53
  547. package/dist/src/ui/hooks/useGitBranchName.test.js.map +1 -1
  548. package/dist/src/ui/hooks/useIdeTrustListener.d.ts +16 -0
  549. package/dist/src/ui/hooks/useIdeTrustListener.js +65 -0
  550. package/dist/src/ui/hooks/useIdeTrustListener.js.map +1 -0
  551. package/dist/src/ui/hooks/useIdeTrustListener.test.d.ts +6 -0
  552. package/dist/src/ui/hooks/useIdeTrustListener.test.js +183 -0
  553. package/dist/src/ui/hooks/useIdeTrustListener.test.js.map +1 -0
  554. package/dist/src/ui/hooks/useInputHistoryStore.d.ts +19 -0
  555. package/dist/src/ui/hooks/useInputHistoryStore.js +81 -0
  556. package/dist/src/ui/hooks/useInputHistoryStore.js.map +1 -0
  557. package/dist/src/ui/hooks/useInputHistoryStore.test.d.ts +6 -0
  558. package/dist/src/ui/hooks/useInputHistoryStore.test.js +234 -0
  559. package/dist/src/ui/hooks/useInputHistoryStore.test.js.map +1 -0
  560. package/dist/src/ui/hooks/useLoadingIndicator.d.ts +1 -1
  561. package/dist/src/ui/hooks/useLoadingIndicator.js +2 -2
  562. package/dist/src/ui/hooks/useLoadingIndicator.js.map +1 -1
  563. package/dist/src/ui/hooks/useLoadingIndicator.test.js +2 -2
  564. package/dist/src/ui/hooks/useLoadingIndicator.test.js.map +1 -1
  565. package/dist/src/ui/hooks/useMemoryMonitor.d.ts +13 -0
  566. package/dist/src/ui/hooks/useMemoryMonitor.js +28 -0
  567. package/dist/src/ui/hooks/useMemoryMonitor.js.map +1 -0
  568. package/dist/src/ui/hooks/useMemoryMonitor.test.d.ts +6 -0
  569. package/dist/src/ui/hooks/useMemoryMonitor.test.js +57 -0
  570. package/dist/src/ui/hooks/useMemoryMonitor.test.js.map +1 -0
  571. package/dist/src/ui/hooks/useMessageQueue.d.ts +2 -1
  572. package/dist/src/ui/hooks/useMessageQueue.js +5 -3
  573. package/dist/src/ui/hooks/useMessageQueue.js.map +1 -1
  574. package/dist/src/ui/hooks/useMessageQueue.test.js +9 -0
  575. package/dist/src/ui/hooks/useMessageQueue.test.js.map +1 -1
  576. package/dist/src/ui/hooks/useModelCommand.d.ts +12 -0
  577. package/dist/src/ui/hooks/useModelCommand.js +21 -0
  578. package/dist/src/ui/hooks/useModelCommand.js.map +1 -0
  579. package/dist/src/ui/hooks/useModelCommand.test.d.ts +6 -0
  580. package/dist/src/ui/hooks/useModelCommand.test.js +35 -0
  581. package/dist/src/ui/hooks/useModelCommand.test.js.map +1 -0
  582. package/dist/src/ui/hooks/usePermissionsModifyTrust.d.ts +17 -0
  583. package/dist/src/ui/hooks/usePermissionsModifyTrust.js +78 -0
  584. package/dist/src/ui/hooks/usePermissionsModifyTrust.js.map +1 -0
  585. package/dist/src/ui/hooks/usePermissionsModifyTrust.test.d.ts +6 -0
  586. package/dist/src/ui/hooks/usePermissionsModifyTrust.test.js +182 -0
  587. package/dist/src/ui/hooks/usePermissionsModifyTrust.test.js.map +1 -0
  588. package/dist/src/ui/hooks/usePhraseCycler.d.ts +1 -1
  589. package/dist/src/ui/hooks/usePhraseCycler.js +11 -8
  590. package/dist/src/ui/hooks/usePhraseCycler.js.map +1 -1
  591. package/dist/src/ui/hooks/useQuotaAndFallback.d.ts +21 -0
  592. package/dist/src/ui/hooks/useQuotaAndFallback.js +122 -0
  593. package/dist/src/ui/hooks/useQuotaAndFallback.js.map +1 -0
  594. package/dist/src/ui/hooks/useQuotaAndFallback.test.d.ts +6 -0
  595. package/dist/src/ui/hooks/useQuotaAndFallback.test.js +269 -0
  596. package/dist/src/ui/hooks/useQuotaAndFallback.test.js.map +1 -0
  597. package/dist/src/ui/hooks/useReactToolScheduler.d.ts +3 -2
  598. package/dist/src/ui/hooks/useReactToolScheduler.js +23 -17
  599. package/dist/src/ui/hooks/useReactToolScheduler.js.map +1 -1
  600. package/dist/src/ui/hooks/useReverseSearchCompletion.d.ts +1 -1
  601. package/dist/src/ui/hooks/useReverseSearchCompletion.js +67 -20
  602. package/dist/src/ui/hooks/useReverseSearchCompletion.js.map +1 -1
  603. package/dist/src/ui/hooks/useSelectionList.d.ts +34 -0
  604. package/dist/src/ui/hooks/useSelectionList.js +245 -0
  605. package/dist/src/ui/hooks/useSelectionList.js.map +1 -0
  606. package/dist/src/ui/hooks/useSelectionList.test.d.ts +6 -0
  607. package/dist/src/ui/hooks/useSelectionList.test.js +701 -0
  608. package/dist/src/ui/hooks/useSelectionList.test.js.map +1 -0
  609. package/dist/src/ui/hooks/useSlashCompletion.d.ts +1 -1
  610. package/dist/src/ui/hooks/useSlashCompletion.js +281 -67
  611. package/dist/src/ui/hooks/useSlashCompletion.js.map +1 -1
  612. package/dist/src/ui/hooks/useSlashCompletion.test.d.ts +4 -1
  613. package/dist/src/ui/hooks/useSlashCompletion.test.js +390 -65
  614. package/dist/src/ui/hooks/useSlashCompletion.test.js.map +1 -1
  615. package/dist/src/ui/hooks/useStateAndRef.d.ts +1 -1
  616. package/dist/src/ui/hooks/useStateAndRef.js +2 -2
  617. package/dist/src/ui/hooks/useStateAndRef.js.map +1 -1
  618. package/dist/src/ui/hooks/useThemeCommand.d.ts +1 -1
  619. package/dist/src/ui/hooks/useThemeCommand.js +3 -14
  620. package/dist/src/ui/hooks/useThemeCommand.js.map +1 -1
  621. package/dist/src/ui/hooks/useToolScheduler.test.js +64 -291
  622. package/dist/src/ui/hooks/useToolScheduler.test.js.map +1 -1
  623. package/dist/src/ui/hooks/useWelcomeBack.js +2 -2
  624. package/dist/src/ui/hooks/useWelcomeBack.js.map +1 -1
  625. package/dist/src/ui/hooks/useWorkspaceMigration.js +2 -1
  626. package/dist/src/ui/hooks/useWorkspaceMigration.js.map +1 -1
  627. package/dist/src/ui/keyMatchers.test.js +17 -0
  628. package/dist/src/ui/keyMatchers.test.js.map +1 -1
  629. package/dist/src/ui/layouts/DefaultAppLayout.d.ts +9 -0
  630. package/dist/src/ui/layouts/DefaultAppLayout.js +13 -0
  631. package/dist/src/ui/layouts/DefaultAppLayout.js.map +1 -0
  632. package/dist/src/ui/layouts/ScreenReaderAppLayout.d.ts +7 -0
  633. package/dist/src/ui/layouts/ScreenReaderAppLayout.js +14 -0
  634. package/dist/src/ui/layouts/ScreenReaderAppLayout.js.map +1 -0
  635. package/dist/src/ui/models/availableModels.d.ts +3 -0
  636. package/dist/src/ui/models/availableModels.js +27 -3
  637. package/dist/src/ui/models/availableModels.js.map +1 -1
  638. package/dist/src/ui/noninteractive/nonInteractiveUi.d.ts +12 -0
  639. package/dist/src/ui/noninteractive/nonInteractiveUi.js +28 -0
  640. package/dist/src/ui/noninteractive/nonInteractiveUi.js.map +1 -0
  641. package/dist/src/ui/state/extensions.d.ts +42 -0
  642. package/dist/src/ui/state/extensions.js +62 -0
  643. package/dist/src/ui/state/extensions.js.map +1 -0
  644. package/dist/src/ui/themes/ayu.js +1 -1
  645. package/dist/src/ui/themes/dracula.js +2 -2
  646. package/dist/src/ui/themes/github-dark.js +1 -1
  647. package/dist/src/ui/themes/theme.js +19 -19
  648. package/dist/src/ui/themes/theme.js.map +1 -1
  649. package/dist/src/ui/types.d.ts +79 -3
  650. package/dist/src/ui/types.js +14 -0
  651. package/dist/src/ui/types.js.map +1 -1
  652. package/dist/src/ui/utils/CodeColorizer.js +3 -2
  653. package/dist/src/ui/utils/CodeColorizer.js.map +1 -1
  654. package/dist/src/ui/utils/InlineMarkdownRenderer.js +7 -7
  655. package/dist/src/ui/utils/InlineMarkdownRenderer.js.map +1 -1
  656. package/dist/src/ui/utils/MarkdownDisplay.js +11 -11
  657. package/dist/src/ui/utils/MarkdownDisplay.js.map +1 -1
  658. package/dist/src/ui/utils/MarkdownDisplay.test.js +95 -87
  659. package/dist/src/ui/utils/MarkdownDisplay.test.js.map +1 -1
  660. package/dist/src/ui/utils/TableRenderer.js +4 -4
  661. package/dist/src/ui/utils/TableRenderer.js.map +1 -1
  662. package/dist/src/ui/utils/clipboardUtils.js +7 -8
  663. package/dist/src/ui/utils/clipboardUtils.js.map +1 -1
  664. package/dist/src/ui/utils/displayUtils.d.ts +1 -0
  665. package/dist/src/ui/utils/displayUtils.js +7 -4
  666. package/dist/src/ui/utils/displayUtils.js.map +1 -1
  667. package/dist/src/ui/utils/displayUtils.test.js +37 -18
  668. package/dist/src/ui/utils/displayUtils.test.js.map +1 -1
  669. package/dist/src/ui/utils/highlight.d.ts +11 -0
  670. package/dist/src/ui/utils/highlight.js +78 -0
  671. package/dist/src/ui/utils/highlight.js.map +1 -0
  672. package/dist/src/ui/utils/highlight.test.d.ts +6 -0
  673. package/dist/src/ui/utils/highlight.test.js +120 -0
  674. package/dist/src/ui/utils/highlight.test.js.map +1 -0
  675. package/dist/src/ui/utils/kittyProtocolDetector.js +39 -29
  676. package/dist/src/ui/utils/kittyProtocolDetector.js.map +1 -1
  677. package/dist/src/ui/utils/platformConstants.d.ts +24 -1
  678. package/dist/src/ui/utils/platformConstants.js +26 -1
  679. package/dist/src/ui/utils/platformConstants.js.map +1 -1
  680. package/dist/src/ui/utils/textUtils.d.ts +10 -0
  681. package/dist/src/ui/utils/textUtils.js +108 -3
  682. package/dist/src/ui/utils/textUtils.js.map +1 -1
  683. package/dist/src/ui/utils/textUtils.test.d.ts +6 -0
  684. package/dist/src/ui/utils/textUtils.test.js +132 -0
  685. package/dist/src/ui/utils/textUtils.test.js.map +1 -0
  686. package/dist/src/utils/commands.d.ts +20 -0
  687. package/dist/src/utils/commands.js +53 -0
  688. package/dist/src/utils/commands.js.map +1 -0
  689. package/dist/src/utils/commands.test.d.ts +6 -0
  690. package/dist/src/utils/commands.test.js +115 -0
  691. package/dist/src/utils/commands.test.js.map +1 -0
  692. package/dist/src/utils/commentJson.d.ts +9 -0
  693. package/dist/src/utils/commentJson.js +48 -0
  694. package/dist/src/utils/commentJson.js.map +1 -0
  695. package/dist/src/utils/commentJson.test.d.ts +6 -0
  696. package/dist/src/utils/commentJson.test.js +146 -0
  697. package/dist/src/utils/commentJson.test.js.map +1 -0
  698. package/dist/src/utils/deepMerge.d.ts +9 -0
  699. package/dist/src/utils/deepMerge.js +58 -0
  700. package/dist/src/utils/deepMerge.js.map +1 -0
  701. package/dist/src/utils/deepMerge.test.d.ts +6 -0
  702. package/dist/src/utils/deepMerge.test.js +143 -0
  703. package/dist/src/utils/deepMerge.test.js.map +1 -0
  704. package/dist/src/utils/envVarResolver.d.ts +39 -0
  705. package/dist/src/utils/envVarResolver.js +97 -0
  706. package/dist/src/utils/envVarResolver.js.map +1 -0
  707. package/dist/src/utils/envVarResolver.test.d.ts +6 -0
  708. package/dist/src/utils/envVarResolver.test.js +221 -0
  709. package/dist/src/utils/envVarResolver.test.js.map +1 -0
  710. package/dist/src/utils/errors.d.ts +21 -0
  711. package/dist/src/utils/errors.js +93 -0
  712. package/dist/src/utils/errors.js.map +1 -1
  713. package/dist/src/utils/errors.test.d.ts +6 -0
  714. package/dist/src/utils/errors.test.js +303 -0
  715. package/dist/src/utils/errors.test.js.map +1 -0
  716. package/dist/src/utils/events.d.ts +2 -1
  717. package/dist/src/utils/events.js +1 -0
  718. package/dist/src/utils/events.js.map +1 -1
  719. package/dist/src/utils/math.d.ts +13 -0
  720. package/dist/src/utils/math.js +14 -0
  721. package/dist/src/utils/math.js.map +1 -0
  722. package/dist/src/utils/processUtils.d.ts +13 -0
  723. package/dist/src/utils/processUtils.js +18 -0
  724. package/dist/src/utils/processUtils.js.map +1 -0
  725. package/dist/src/utils/processUtils.test.d.ts +6 -0
  726. package/dist/src/utils/processUtils.test.js +20 -0
  727. package/dist/src/utils/processUtils.test.js.map +1 -0
  728. package/dist/src/utils/relaunch.d.ts +7 -0
  729. package/dist/src/utils/relaunch.js +57 -0
  730. package/dist/src/utils/relaunch.js.map +1 -0
  731. package/dist/src/utils/relaunch.test.d.ts +6 -0
  732. package/dist/src/utils/relaunch.test.js +273 -0
  733. package/dist/src/utils/relaunch.test.js.map +1 -0
  734. package/dist/src/utils/sandbox.d.ts +1 -1
  735. package/dist/src/utils/sandbox.js +42 -17
  736. package/dist/src/utils/sandbox.js.map +1 -1
  737. package/dist/src/utils/settingsUtils.d.ts +16 -6
  738. package/dist/src/utils/settingsUtils.js +35 -25
  739. package/dist/src/utils/settingsUtils.js.map +1 -1
  740. package/dist/src/utils/settingsUtils.test.js +455 -158
  741. package/dist/src/utils/settingsUtils.test.js.map +1 -1
  742. package/dist/src/utils/userStartupWarnings.d.ts +1 -1
  743. package/dist/src/utils/userStartupWarnings.js +1 -1
  744. package/dist/src/utils/userStartupWarnings.js.map +1 -1
  745. package/dist/src/utils/windowTitle.d.ts +12 -0
  746. package/dist/src/utils/windowTitle.js +19 -0
  747. package/dist/src/utils/windowTitle.js.map +1 -0
  748. package/dist/src/utils/windowTitle.test.d.ts +6 -0
  749. package/dist/src/utils/windowTitle.test.js +49 -0
  750. package/dist/src/utils/windowTitle.test.js.map +1 -0
  751. package/dist/src/validateNonInterActiveAuth.d.ts +4 -2
  752. package/dist/src/validateNonInterActiveAuth.js +33 -12
  753. package/dist/src/validateNonInterActiveAuth.js.map +1 -1
  754. package/dist/src/zed-integration/fileSystemService.d.ts +1 -0
  755. package/dist/src/zed-integration/fileSystemService.js +3 -0
  756. package/dist/src/zed-integration/fileSystemService.js.map +1 -1
  757. package/dist/src/zed-integration/schema.d.ts +310 -310
  758. package/dist/src/zed-integration/zedIntegration.d.ts +8 -1
  759. package/dist/src/zed-integration/zedIntegration.js +32 -15
  760. package/dist/src/zed-integration/zedIntegration.js.map +1 -1
  761. package/dist/tsconfig.tsbuildinfo +1 -1
  762. package/package.json +15 -10
  763. package/dist/src/ui/components/AuthDialog.js.map +0 -1
  764. package/dist/src/ui/components/AuthDialog.test.js.map +0 -1
  765. package/dist/src/ui/components/AuthInProgress.js.map +0 -1
  766. package/dist/src/ui/components/ModelSelectionDialog.d.ts +0 -14
  767. package/dist/src/ui/components/ModelSelectionDialog.js +0 -26
  768. package/dist/src/ui/components/ModelSelectionDialog.js.map +0 -1
  769. package/dist/src/ui/components/ModelSelectionDialog.test.js +0 -124
  770. package/dist/src/ui/components/ModelSelectionDialog.test.js.map +0 -1
  771. package/dist/src/ui/hooks/useAuthCommand.js.map +0 -1
  772. /package/dist/src/{ui/components/AuthDialog.test.d.ts → commands/extensions/new.test.d.ts} +0 -0
  773. /package/dist/src/ui/{components → auth}/AuthDialog.d.ts +0 -0
  774. /package/dist/src/ui/{components → auth}/AuthInProgress.d.ts +0 -0
@@ -0,0 +1,701 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2025 Google LLC
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
7
+ import { renderHook, act } from '@testing-library/react';
8
+ import { useSelectionList, } from './useSelectionList.js';
9
+ import { useKeypress } from './useKeypress.js';
10
+ vi.mock('./useKeypress.js');
11
+ let activeKeypressHandler = null;
12
+ describe('useSelectionList', () => {
13
+ const mockOnSelect = vi.fn();
14
+ const mockOnHighlight = vi.fn();
15
+ const items = [
16
+ { value: 'A', key: 'A' },
17
+ { value: 'B', disabled: true, key: 'B' },
18
+ { value: 'C', key: 'C' },
19
+ { value: 'D', key: 'D' },
20
+ ];
21
+ beforeEach(() => {
22
+ activeKeypressHandler = null;
23
+ vi.mocked(useKeypress).mockImplementation((handler, options) => {
24
+ if (options?.isActive) {
25
+ activeKeypressHandler = handler;
26
+ }
27
+ else {
28
+ activeKeypressHandler = null;
29
+ }
30
+ });
31
+ mockOnSelect.mockClear();
32
+ mockOnHighlight.mockClear();
33
+ });
34
+ const pressKey = (name, sequence = name) => {
35
+ act(() => {
36
+ if (activeKeypressHandler) {
37
+ const key = {
38
+ name,
39
+ sequence,
40
+ ctrl: false,
41
+ meta: false,
42
+ shift: false,
43
+ paste: false,
44
+ };
45
+ activeKeypressHandler(key);
46
+ }
47
+ else {
48
+ throw new Error(`Test attempted to press key (${name}) but the keypress handler is not active. Ensure the hook is focused (isFocused=true) and the list is not empty.`);
49
+ }
50
+ });
51
+ };
52
+ describe('Initialization', () => {
53
+ it('should initialize with the default index (0) if enabled', () => {
54
+ const { result } = renderHook(() => useSelectionList({ items, onSelect: mockOnSelect }));
55
+ expect(result.current.activeIndex).toBe(0);
56
+ });
57
+ it('should initialize with the provided initialIndex if enabled', () => {
58
+ const { result } = renderHook(() => useSelectionList({
59
+ items,
60
+ initialIndex: 2,
61
+ onSelect: mockOnSelect,
62
+ }));
63
+ expect(result.current.activeIndex).toBe(2);
64
+ });
65
+ it('should handle an empty list gracefully', () => {
66
+ const { result } = renderHook(() => useSelectionList({ items: [], onSelect: mockOnSelect }));
67
+ expect(result.current.activeIndex).toBe(0);
68
+ });
69
+ it('should find the next enabled item (downwards) if initialIndex is disabled', () => {
70
+ const { result } = renderHook(() => useSelectionList({
71
+ items,
72
+ initialIndex: 1,
73
+ onSelect: mockOnSelect,
74
+ }));
75
+ expect(result.current.activeIndex).toBe(2);
76
+ });
77
+ it('should wrap around to find the next enabled item if initialIndex is disabled', () => {
78
+ const wrappingItems = [
79
+ { value: 'A', key: 'A' },
80
+ { value: 'B', disabled: true, key: 'B' },
81
+ { value: 'C', disabled: true, key: 'C' },
82
+ ];
83
+ const { result } = renderHook(() => useSelectionList({
84
+ items: wrappingItems,
85
+ initialIndex: 2,
86
+ onSelect: mockOnSelect,
87
+ }));
88
+ expect(result.current.activeIndex).toBe(0);
89
+ });
90
+ it('should default to 0 if initialIndex is out of bounds', () => {
91
+ const { result } = renderHook(() => useSelectionList({
92
+ items,
93
+ initialIndex: 10,
94
+ onSelect: mockOnSelect,
95
+ }));
96
+ expect(result.current.activeIndex).toBe(0);
97
+ const { result: resultNeg } = renderHook(() => useSelectionList({
98
+ items,
99
+ initialIndex: -1,
100
+ onSelect: mockOnSelect,
101
+ }));
102
+ expect(resultNeg.current.activeIndex).toBe(0);
103
+ });
104
+ it('should stick to the initial index if all items are disabled', () => {
105
+ const allDisabled = [
106
+ { value: 'A', disabled: true, key: 'A' },
107
+ { value: 'B', disabled: true, key: 'B' },
108
+ ];
109
+ const { result } = renderHook(() => useSelectionList({
110
+ items: allDisabled,
111
+ initialIndex: 1,
112
+ onSelect: mockOnSelect,
113
+ }));
114
+ expect(result.current.activeIndex).toBe(1);
115
+ });
116
+ });
117
+ describe('Keyboard Navigation (Up/Down/J/K)', () => {
118
+ it('should move down with "j" and "down" keys, skipping disabled items', () => {
119
+ const { result } = renderHook(() => useSelectionList({ items, onSelect: mockOnSelect }));
120
+ expect(result.current.activeIndex).toBe(0);
121
+ pressKey('j');
122
+ expect(result.current.activeIndex).toBe(2);
123
+ pressKey('down');
124
+ expect(result.current.activeIndex).toBe(3);
125
+ });
126
+ it('should move up with "k" and "up" keys, skipping disabled items', () => {
127
+ const { result } = renderHook(() => useSelectionList({ items, initialIndex: 3, onSelect: mockOnSelect }));
128
+ expect(result.current.activeIndex).toBe(3);
129
+ pressKey('k');
130
+ expect(result.current.activeIndex).toBe(2);
131
+ pressKey('up');
132
+ expect(result.current.activeIndex).toBe(0);
133
+ });
134
+ it('should wrap navigation correctly', () => {
135
+ const { result } = renderHook(() => useSelectionList({
136
+ items,
137
+ initialIndex: items.length - 1,
138
+ onSelect: mockOnSelect,
139
+ }));
140
+ expect(result.current.activeIndex).toBe(3);
141
+ pressKey('down');
142
+ expect(result.current.activeIndex).toBe(0);
143
+ pressKey('up');
144
+ expect(result.current.activeIndex).toBe(3);
145
+ });
146
+ it('should call onHighlight when index changes', () => {
147
+ renderHook(() => useSelectionList({
148
+ items,
149
+ onSelect: mockOnSelect,
150
+ onHighlight: mockOnHighlight,
151
+ }));
152
+ pressKey('down');
153
+ expect(mockOnHighlight).toHaveBeenCalledTimes(1);
154
+ expect(mockOnHighlight).toHaveBeenCalledWith('C');
155
+ });
156
+ it('should not move or call onHighlight if navigation results in the same index (e.g., single item)', () => {
157
+ const singleItem = [{ value: 'A', key: 'A' }];
158
+ const { result } = renderHook(() => useSelectionList({
159
+ items: singleItem,
160
+ onSelect: mockOnSelect,
161
+ onHighlight: mockOnHighlight,
162
+ }));
163
+ pressKey('down');
164
+ expect(result.current.activeIndex).toBe(0);
165
+ expect(mockOnHighlight).not.toHaveBeenCalled();
166
+ });
167
+ it('should not move or call onHighlight if all items are disabled', () => {
168
+ const allDisabled = [
169
+ { value: 'A', disabled: true, key: 'A' },
170
+ { value: 'B', disabled: true, key: 'B' },
171
+ ];
172
+ const { result } = renderHook(() => useSelectionList({
173
+ items: allDisabled,
174
+ onSelect: mockOnSelect,
175
+ onHighlight: mockOnHighlight,
176
+ }));
177
+ const initialIndex = result.current.activeIndex;
178
+ pressKey('down');
179
+ expect(result.current.activeIndex).toBe(initialIndex);
180
+ expect(mockOnHighlight).not.toHaveBeenCalled();
181
+ });
182
+ });
183
+ describe('Selection (Enter)', () => {
184
+ it('should call onSelect when "return" is pressed on enabled item', () => {
185
+ renderHook(() => useSelectionList({
186
+ items,
187
+ initialIndex: 2,
188
+ onSelect: mockOnSelect,
189
+ }));
190
+ pressKey('return');
191
+ expect(mockOnSelect).toHaveBeenCalledTimes(1);
192
+ expect(mockOnSelect).toHaveBeenCalledWith('C');
193
+ });
194
+ it('should not call onSelect if the active item is disabled', () => {
195
+ const { result } = renderHook(() => useSelectionList({
196
+ items,
197
+ onSelect: mockOnSelect,
198
+ }));
199
+ act(() => result.current.setActiveIndex(1));
200
+ pressKey('return');
201
+ expect(mockOnSelect).not.toHaveBeenCalled();
202
+ });
203
+ });
204
+ describe('Keyboard Navigation Robustness (Rapid Input)', () => {
205
+ it('should handle rapid navigation and selection robustly (avoiding stale state)', () => {
206
+ const { result } = renderHook(() => useSelectionList({
207
+ items, // A, B(disabled), C, D. Initial index 0 (A).
208
+ onSelect: mockOnSelect,
209
+ onHighlight: mockOnHighlight,
210
+ }));
211
+ // Simulate rapid inputs with separate act blocks to allow effects to run
212
+ if (!activeKeypressHandler)
213
+ throw new Error('Handler not active');
214
+ const handler = activeKeypressHandler;
215
+ const press = (name) => {
216
+ const key = {
217
+ name,
218
+ sequence: name,
219
+ ctrl: false,
220
+ meta: false,
221
+ shift: false,
222
+ paste: false,
223
+ };
224
+ handler(key);
225
+ };
226
+ // 1. Press Down. Should move 0 (A) -> 2 (C).
227
+ act(() => {
228
+ press('down');
229
+ });
230
+ // 2. Press Down again. Should move 2 (C) -> 3 (D).
231
+ act(() => {
232
+ press('down');
233
+ });
234
+ // 3. Press Enter. Should select D.
235
+ act(() => {
236
+ press('return');
237
+ });
238
+ expect(result.current.activeIndex).toBe(3);
239
+ expect(mockOnHighlight).toHaveBeenCalledTimes(2);
240
+ expect(mockOnHighlight).toHaveBeenNthCalledWith(1, 'C');
241
+ expect(mockOnHighlight).toHaveBeenNthCalledWith(2, 'D');
242
+ expect(mockOnSelect).toHaveBeenCalledTimes(1);
243
+ expect(mockOnSelect).toHaveBeenCalledWith('D');
244
+ expect(mockOnSelect).not.toHaveBeenCalledWith('A');
245
+ });
246
+ it('should handle ultra-rapid input (multiple presses in single act) without stale state', () => {
247
+ const { result } = renderHook(() => useSelectionList({
248
+ items, // A, B(disabled), C, D. Initial index 0 (A).
249
+ onSelect: mockOnSelect,
250
+ onHighlight: mockOnHighlight,
251
+ }));
252
+ // Simulate ultra-rapid inputs where all keypresses happen faster than React can re-render
253
+ act(() => {
254
+ if (!activeKeypressHandler)
255
+ throw new Error('Handler not active');
256
+ const handler = activeKeypressHandler;
257
+ const press = (name) => {
258
+ const key = {
259
+ name,
260
+ sequence: name,
261
+ ctrl: false,
262
+ meta: false,
263
+ shift: false,
264
+ paste: false,
265
+ };
266
+ handler(key);
267
+ };
268
+ // All presses happen in same render cycle - React batches the state updates
269
+ press('down'); // Should move 0 (A) -> 2 (C)
270
+ press('down'); // Should move 2 (C) -> 3 (D)
271
+ press('return'); // Should select D
272
+ });
273
+ expect(result.current.activeIndex).toBe(3);
274
+ expect(mockOnHighlight).toHaveBeenCalledWith('D');
275
+ expect(mockOnSelect).toHaveBeenCalledTimes(1);
276
+ expect(mockOnSelect).toHaveBeenCalledWith('D');
277
+ });
278
+ });
279
+ describe('Focus Management (isFocused)', () => {
280
+ it('should activate the keypress handler when focused (default) and items exist', () => {
281
+ const { result } = renderHook(() => useSelectionList({ items, onSelect: mockOnSelect }));
282
+ expect(activeKeypressHandler).not.toBeNull();
283
+ pressKey('down');
284
+ expect(result.current.activeIndex).toBe(2);
285
+ });
286
+ it('should not activate the keypress handler when isFocused is false', () => {
287
+ renderHook(() => useSelectionList({ items, onSelect: mockOnSelect, isFocused: false }));
288
+ expect(activeKeypressHandler).toBeNull();
289
+ expect(() => pressKey('down')).toThrow(/keypress handler is not active/);
290
+ });
291
+ it('should not activate the keypress handler when items list is empty', () => {
292
+ renderHook(() => useSelectionList({
293
+ items: [],
294
+ onSelect: mockOnSelect,
295
+ isFocused: true,
296
+ }));
297
+ expect(activeKeypressHandler).toBeNull();
298
+ expect(() => pressKey('down')).toThrow(/keypress handler is not active/);
299
+ });
300
+ it('should activate/deactivate when isFocused prop changes', () => {
301
+ const { result, rerender } = renderHook((props) => useSelectionList({ items, onSelect: mockOnSelect, ...props }), { initialProps: { isFocused: false } });
302
+ expect(activeKeypressHandler).toBeNull();
303
+ rerender({ isFocused: true });
304
+ expect(activeKeypressHandler).not.toBeNull();
305
+ pressKey('down');
306
+ expect(result.current.activeIndex).toBe(2);
307
+ rerender({ isFocused: false });
308
+ expect(activeKeypressHandler).toBeNull();
309
+ expect(() => pressKey('down')).toThrow(/keypress handler is not active/);
310
+ });
311
+ });
312
+ describe('Numeric Quick Selection (showNumbers=true)', () => {
313
+ beforeEach(() => {
314
+ vi.useFakeTimers();
315
+ });
316
+ afterEach(() => {
317
+ vi.useRealTimers();
318
+ });
319
+ const shortList = items;
320
+ const longList = Array.from({ length: 15 }, (_, i) => ({ value: `Item ${i + 1}`, key: `Item ${i + 1}` }));
321
+ const pressNumber = (num) => pressKey(num, num);
322
+ it('should not respond to numbers if showNumbers is false (default)', () => {
323
+ const { result } = renderHook(() => useSelectionList({ items: shortList, onSelect: mockOnSelect }));
324
+ pressNumber('1');
325
+ expect(result.current.activeIndex).toBe(0);
326
+ expect(mockOnSelect).not.toHaveBeenCalled();
327
+ });
328
+ it('should select item immediately if the number cannot be extended (unambiguous)', () => {
329
+ const { result } = renderHook(() => useSelectionList({
330
+ items: shortList,
331
+ onSelect: mockOnSelect,
332
+ onHighlight: mockOnHighlight,
333
+ showNumbers: true,
334
+ }));
335
+ pressNumber('3');
336
+ expect(result.current.activeIndex).toBe(2);
337
+ expect(mockOnHighlight).toHaveBeenCalledWith('C');
338
+ expect(mockOnSelect).toHaveBeenCalledTimes(1);
339
+ expect(mockOnSelect).toHaveBeenCalledWith('C');
340
+ expect(vi.getTimerCount()).toBe(0);
341
+ });
342
+ it('should highlight and wait for timeout if the number can be extended (ambiguous)', () => {
343
+ const { result } = renderHook(() => useSelectionList({
344
+ items: longList,
345
+ initialIndex: 1, // Start at index 1 so pressing "1" (index 0) causes a change
346
+ onSelect: mockOnSelect,
347
+ onHighlight: mockOnHighlight,
348
+ showNumbers: true,
349
+ }));
350
+ pressNumber('1');
351
+ expect(result.current.activeIndex).toBe(0);
352
+ expect(mockOnHighlight).toHaveBeenCalledWith('Item 1');
353
+ expect(mockOnSelect).not.toHaveBeenCalled();
354
+ expect(vi.getTimerCount()).toBe(1);
355
+ act(() => {
356
+ vi.advanceTimersByTime(1000);
357
+ });
358
+ expect(mockOnSelect).toHaveBeenCalledTimes(1);
359
+ expect(mockOnSelect).toHaveBeenCalledWith('Item 1');
360
+ });
361
+ it('should handle multi-digit input correctly', () => {
362
+ const { result } = renderHook(() => useSelectionList({
363
+ items: longList,
364
+ onSelect: mockOnSelect,
365
+ showNumbers: true,
366
+ }));
367
+ pressNumber('1');
368
+ expect(mockOnSelect).not.toHaveBeenCalled();
369
+ pressNumber('2');
370
+ expect(result.current.activeIndex).toBe(11);
371
+ expect(mockOnSelect).toHaveBeenCalledTimes(1);
372
+ expect(mockOnSelect).toHaveBeenCalledWith('Item 12');
373
+ });
374
+ it('should reset buffer if input becomes invalid (out of bounds)', () => {
375
+ const { result } = renderHook(() => useSelectionList({
376
+ items: shortList,
377
+ onSelect: mockOnSelect,
378
+ showNumbers: true,
379
+ }));
380
+ pressNumber('5');
381
+ expect(result.current.activeIndex).toBe(0);
382
+ expect(mockOnSelect).not.toHaveBeenCalled();
383
+ pressNumber('3');
384
+ expect(result.current.activeIndex).toBe(2);
385
+ expect(mockOnSelect).toHaveBeenCalledWith('C');
386
+ });
387
+ it('should allow "0" as subsequent digit, but ignore as first digit', () => {
388
+ const { result } = renderHook(() => useSelectionList({
389
+ items: longList,
390
+ onSelect: mockOnSelect,
391
+ showNumbers: true,
392
+ }));
393
+ pressNumber('0');
394
+ expect(result.current.activeIndex).toBe(0);
395
+ expect(mockOnSelect).not.toHaveBeenCalled();
396
+ // Timer should be running to clear the '0' input buffer
397
+ expect(vi.getTimerCount()).toBe(1);
398
+ // Press '1', then '0' (Item 10, index 9)
399
+ pressNumber('1');
400
+ pressNumber('0');
401
+ expect(result.current.activeIndex).toBe(9);
402
+ expect(mockOnSelect).toHaveBeenCalledWith('Item 10');
403
+ });
404
+ it('should clear the initial "0" input after timeout', () => {
405
+ renderHook(() => useSelectionList({
406
+ items: longList,
407
+ onSelect: mockOnSelect,
408
+ showNumbers: true,
409
+ }));
410
+ pressNumber('0');
411
+ act(() => vi.advanceTimersByTime(1000)); // Timeout the '0' input
412
+ pressNumber('1');
413
+ expect(mockOnSelect).not.toHaveBeenCalled(); // Should be waiting for second digit
414
+ act(() => vi.advanceTimersByTime(1000)); // Timeout '1'
415
+ expect(mockOnSelect).toHaveBeenCalledWith('Item 1');
416
+ });
417
+ it('should highlight but not select a disabled item (immediate selection case)', () => {
418
+ const { result } = renderHook(() => useSelectionList({
419
+ items: shortList, // B (index 1, number 2) is disabled
420
+ onSelect: mockOnSelect,
421
+ onHighlight: mockOnHighlight,
422
+ showNumbers: true,
423
+ }));
424
+ pressNumber('2');
425
+ expect(result.current.activeIndex).toBe(1);
426
+ expect(mockOnHighlight).toHaveBeenCalledWith('B');
427
+ // Should not select immediately, even though 20 > 4
428
+ expect(mockOnSelect).not.toHaveBeenCalled();
429
+ });
430
+ it('should highlight but not select a disabled item (timeout case)', () => {
431
+ // Create a list where the ambiguous prefix points to a disabled item
432
+ const disabledAmbiguousList = [
433
+ { value: 'Item 1 Disabled', disabled: true, key: 'Item 1 Disabled' },
434
+ ...longList.slice(1),
435
+ ];
436
+ const { result } = renderHook(() => useSelectionList({
437
+ items: disabledAmbiguousList,
438
+ onSelect: mockOnSelect,
439
+ showNumbers: true,
440
+ }));
441
+ pressNumber('1');
442
+ expect(result.current.activeIndex).toBe(0);
443
+ expect(vi.getTimerCount()).toBe(1);
444
+ act(() => {
445
+ vi.advanceTimersByTime(1000);
446
+ });
447
+ // Should not select after timeout
448
+ expect(mockOnSelect).not.toHaveBeenCalled();
449
+ });
450
+ it('should clear the number buffer if a non-numeric key (e.g., navigation) is pressed', () => {
451
+ const { result } = renderHook(() => useSelectionList({
452
+ items: longList,
453
+ onSelect: mockOnSelect,
454
+ showNumbers: true,
455
+ }));
456
+ pressNumber('1');
457
+ expect(vi.getTimerCount()).toBe(1);
458
+ pressKey('down');
459
+ expect(result.current.activeIndex).toBe(1);
460
+ expect(vi.getTimerCount()).toBe(0);
461
+ pressNumber('3');
462
+ // Should select '3', not '13'
463
+ expect(result.current.activeIndex).toBe(2);
464
+ });
465
+ it('should clear the number buffer if "return" is pressed', () => {
466
+ renderHook(() => useSelectionList({
467
+ items: longList,
468
+ onSelect: mockOnSelect,
469
+ showNumbers: true,
470
+ }));
471
+ pressNumber('1');
472
+ pressKey('return');
473
+ expect(mockOnSelect).toHaveBeenCalledTimes(1);
474
+ expect(vi.getTimerCount()).toBe(0);
475
+ act(() => {
476
+ vi.advanceTimersByTime(1000);
477
+ });
478
+ expect(mockOnSelect).toHaveBeenCalledTimes(1);
479
+ });
480
+ });
481
+ describe('Reactivity (Dynamic Updates)', () => {
482
+ it('should update activeIndex when initialIndex prop changes', () => {
483
+ const { result, rerender } = renderHook(({ initialIndex }) => useSelectionList({
484
+ items,
485
+ onSelect: mockOnSelect,
486
+ initialIndex,
487
+ }), { initialProps: { initialIndex: 0 } });
488
+ rerender({ initialIndex: 2 });
489
+ expect(result.current.activeIndex).toBe(2);
490
+ });
491
+ it('should respect a new initialIndex even after user interaction', () => {
492
+ const { result, rerender } = renderHook(({ initialIndex }) => useSelectionList({
493
+ items,
494
+ onSelect: mockOnSelect,
495
+ initialIndex,
496
+ }), { initialProps: { initialIndex: 0 } });
497
+ // User navigates, changing the active index
498
+ pressKey('down');
499
+ expect(result.current.activeIndex).toBe(2);
500
+ // The component re-renders with a new initial index
501
+ rerender({ initialIndex: 3 });
502
+ // The hook should now respect the new initial index
503
+ expect(result.current.activeIndex).toBe(3);
504
+ });
505
+ it('should validate index when initialIndex prop changes to a disabled item', () => {
506
+ const { result, rerender } = renderHook(({ initialIndex }) => useSelectionList({
507
+ items,
508
+ onSelect: mockOnSelect,
509
+ initialIndex,
510
+ }), { initialProps: { initialIndex: 0 } });
511
+ rerender({ initialIndex: 1 });
512
+ expect(result.current.activeIndex).toBe(2);
513
+ });
514
+ it('should adjust activeIndex if items change and the initialIndex is now out of bounds', () => {
515
+ const { result, rerender } = renderHook(({ items: testItems }) => useSelectionList({
516
+ onSelect: mockOnSelect,
517
+ initialIndex: 3,
518
+ items: testItems,
519
+ }), { initialProps: { items } });
520
+ expect(result.current.activeIndex).toBe(3);
521
+ const shorterItems = [
522
+ { value: 'X', key: 'X' },
523
+ { value: 'Y', key: 'Y' },
524
+ ];
525
+ rerender({ items: shorterItems }); // Length 2
526
+ // The useEffect syncs based on the initialIndex (3) which is now out of bounds. It defaults to 0.
527
+ expect(result.current.activeIndex).toBe(0);
528
+ });
529
+ it('should adjust activeIndex if items change and the initialIndex becomes disabled', () => {
530
+ const initialItems = [
531
+ { value: 'A', key: 'A' },
532
+ { value: 'B', key: 'B' },
533
+ { value: 'C', key: 'C' },
534
+ ];
535
+ const { result, rerender } = renderHook(({ items: testItems }) => useSelectionList({
536
+ onSelect: mockOnSelect,
537
+ initialIndex: 1,
538
+ items: testItems,
539
+ }), { initialProps: { items: initialItems } });
540
+ expect(result.current.activeIndex).toBe(1);
541
+ const newItems = [
542
+ { value: 'A', key: 'A' },
543
+ { value: 'B', disabled: true, key: 'B' },
544
+ { value: 'C', key: 'C' },
545
+ ];
546
+ rerender({ items: newItems });
547
+ expect(result.current.activeIndex).toBe(2);
548
+ });
549
+ it('should reset to 0 if items change to an empty list', () => {
550
+ const { result, rerender } = renderHook(({ items: testItems }) => useSelectionList({
551
+ onSelect: mockOnSelect,
552
+ initialIndex: 2,
553
+ items: testItems,
554
+ }), { initialProps: { items } });
555
+ rerender({ items: [] });
556
+ expect(result.current.activeIndex).toBe(0);
557
+ });
558
+ it('should not reset activeIndex when items are deeply equal', () => {
559
+ const initialItems = [
560
+ { value: 'A', key: 'A' },
561
+ { value: 'B', disabled: true, key: 'B' },
562
+ { value: 'C', key: 'C' },
563
+ { value: 'D', key: 'D' },
564
+ ];
565
+ const { result, rerender } = renderHook(({ items: testItems }) => useSelectionList({
566
+ onSelect: mockOnSelect,
567
+ onHighlight: mockOnHighlight,
568
+ initialIndex: 2,
569
+ items: testItems,
570
+ }), { initialProps: { items: initialItems } });
571
+ expect(result.current.activeIndex).toBe(2);
572
+ act(() => {
573
+ result.current.setActiveIndex(3);
574
+ });
575
+ expect(result.current.activeIndex).toBe(3);
576
+ mockOnHighlight.mockClear();
577
+ // Create new array with same content (deeply equal but not identical)
578
+ const newItems = [
579
+ { value: 'A', key: 'A' },
580
+ { value: 'B', disabled: true, key: 'B' },
581
+ { value: 'C', key: 'C' },
582
+ { value: 'D', key: 'D' },
583
+ ];
584
+ rerender({ items: newItems });
585
+ // Active index should remain the same since items are deeply equal
586
+ expect(result.current.activeIndex).toBe(3);
587
+ // onHighlight should NOT be called since the index didn't change
588
+ expect(mockOnHighlight).not.toHaveBeenCalled();
589
+ });
590
+ it('should update activeIndex when items change structurally', () => {
591
+ const initialItems = [
592
+ { value: 'A', key: 'A' },
593
+ { value: 'B', disabled: true, key: 'B' },
594
+ { value: 'C', key: 'C' },
595
+ { value: 'D', key: 'D' },
596
+ ];
597
+ const { result, rerender } = renderHook(({ items: testItems }) => useSelectionList({
598
+ onSelect: mockOnSelect,
599
+ onHighlight: mockOnHighlight,
600
+ initialIndex: 3,
601
+ items: testItems,
602
+ }), { initialProps: { items: initialItems } });
603
+ expect(result.current.activeIndex).toBe(3);
604
+ mockOnHighlight.mockClear();
605
+ // Change item values (not deeply equal)
606
+ const newItems = [
607
+ { value: 'X', key: 'X' },
608
+ { value: 'Y', key: 'Y' },
609
+ { value: 'Z', key: 'Z' },
610
+ ];
611
+ rerender({ items: newItems });
612
+ // Active index should update based on initialIndex and new items
613
+ expect(result.current.activeIndex).toBe(0);
614
+ });
615
+ it('should handle partial changes in items array', () => {
616
+ const initialItems = [
617
+ { value: 'A', key: 'A' },
618
+ { value: 'B', key: 'B' },
619
+ { value: 'C', key: 'C' },
620
+ ];
621
+ const { result, rerender } = renderHook(({ items: testItems }) => useSelectionList({
622
+ onSelect: mockOnSelect,
623
+ initialIndex: 1,
624
+ items: testItems,
625
+ }), { initialProps: { items: initialItems } });
626
+ expect(result.current.activeIndex).toBe(1);
627
+ // Change only one item's disabled status
628
+ const newItems = [
629
+ { value: 'A', key: 'A' },
630
+ { value: 'B', disabled: true, key: 'B' },
631
+ { value: 'C', key: 'C' },
632
+ ];
633
+ rerender({ items: newItems });
634
+ // Should find next valid index since current became disabled
635
+ expect(result.current.activeIndex).toBe(2);
636
+ });
637
+ it('should update selection when a new item is added to the start of the list', () => {
638
+ const initialItems = [
639
+ { value: 'A', key: 'A' },
640
+ { value: 'B', key: 'B' },
641
+ { value: 'C', key: 'C' },
642
+ ];
643
+ const { result, rerender } = renderHook(({ items: testItems }) => useSelectionList({
644
+ onSelect: mockOnSelect,
645
+ items: testItems,
646
+ }), { initialProps: { items: initialItems } });
647
+ pressKey('down');
648
+ expect(result.current.activeIndex).toBe(1);
649
+ const newItems = [
650
+ { value: 'D', key: 'D' },
651
+ { value: 'A', key: 'A' },
652
+ { value: 'B', key: 'B' },
653
+ { value: 'C', key: 'C' },
654
+ ];
655
+ rerender({ items: newItems });
656
+ expect(result.current.activeIndex).toBe(2);
657
+ });
658
+ });
659
+ describe('Manual Control', () => {
660
+ it('should allow manual setting of active index via setActiveIndex', () => {
661
+ const { result } = renderHook(() => useSelectionList({ items, onSelect: mockOnSelect }));
662
+ act(() => {
663
+ result.current.setActiveIndex(3);
664
+ });
665
+ expect(result.current.activeIndex).toBe(3);
666
+ act(() => {
667
+ result.current.setActiveIndex(1);
668
+ });
669
+ expect(result.current.activeIndex).toBe(1);
670
+ });
671
+ });
672
+ describe('Cleanup', () => {
673
+ beforeEach(() => {
674
+ vi.useFakeTimers();
675
+ });
676
+ afterEach(() => {
677
+ vi.useRealTimers();
678
+ });
679
+ it('should clear timeout on unmount when timer is active', () => {
680
+ const longList = Array.from({ length: 15 }, (_, i) => ({ value: `Item ${i + 1}`, key: `Item ${i + 1}` }));
681
+ const { unmount } = renderHook(() => useSelectionList({
682
+ items: longList,
683
+ onSelect: mockOnSelect,
684
+ showNumbers: true,
685
+ }));
686
+ pressKey('1', '1');
687
+ expect(vi.getTimerCount()).toBe(1);
688
+ act(() => {
689
+ vi.advanceTimersByTime(500);
690
+ });
691
+ expect(mockOnSelect).not.toHaveBeenCalled();
692
+ unmount();
693
+ expect(vi.getTimerCount()).toBe(0);
694
+ act(() => {
695
+ vi.advanceTimersByTime(1000);
696
+ });
697
+ expect(mockOnSelect).not.toHaveBeenCalled();
698
+ });
699
+ });
700
+ });
701
+ //# sourceMappingURL=useSelectionList.test.js.map