@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,831 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ /**
3
+ * @license
4
+ * Copyright 2025 Google LLC
5
+ * SPDX-License-Identifier: Apache-2.0
6
+ */
7
+ import { describe, it, expect, vi, beforeEach, afterEach, } from 'vitest';
8
+ import { render, cleanup } from 'ink-testing-library';
9
+ import { AppContainer } from './AppContainer.js';
10
+ import { makeFakeConfig, } from '@rdmind/rdmind-core';
11
+ import { useQuotaAndFallback } from './hooks/useQuotaAndFallback.js';
12
+ import { UIStateContext } from './contexts/UIStateContext.js';
13
+ import { UIActionsContext, } from './contexts/UIActionsContext.js';
14
+ import { useContext } from 'react';
15
+ // Mock useStdout to capture terminal title writes
16
+ let mockStdout;
17
+ vi.mock('ink', async (importOriginal) => {
18
+ const actual = await importOriginal();
19
+ return {
20
+ ...actual,
21
+ useStdout: () => ({ stdout: mockStdout }),
22
+ measureElement: vi.fn(),
23
+ };
24
+ });
25
+ // Helper component will read the context values provided by AppContainer
26
+ // so we can assert against them in our tests.
27
+ let capturedUIState;
28
+ let capturedUIActions;
29
+ function TestContextConsumer() {
30
+ capturedUIState = useContext(UIStateContext);
31
+ capturedUIActions = useContext(UIActionsContext);
32
+ return null;
33
+ }
34
+ vi.mock('./App.js', () => ({
35
+ App: TestContextConsumer,
36
+ }));
37
+ vi.mock('./hooks/useQuotaAndFallback.js');
38
+ vi.mock('./hooks/useHistoryManager.js');
39
+ vi.mock('./hooks/useThemeCommand.js');
40
+ vi.mock('./auth/useAuth.js');
41
+ vi.mock('./hooks/useEditorSettings.js');
42
+ vi.mock('./hooks/useSettingsCommand.js');
43
+ vi.mock('./hooks/useModelCommand.js');
44
+ vi.mock('./hooks/slashCommandProcessor.js');
45
+ vi.mock('./hooks/useConsoleMessages.js');
46
+ vi.mock('./hooks/useTerminalSize.js', () => ({
47
+ useTerminalSize: vi.fn(() => ({ columns: 80, rows: 24 })),
48
+ }));
49
+ vi.mock('./hooks/useGeminiStream.js');
50
+ vi.mock('./hooks/vim.js');
51
+ vi.mock('./hooks/useFocus.js');
52
+ vi.mock('./hooks/useBracketedPaste.js');
53
+ vi.mock('./hooks/useKeypress.js');
54
+ vi.mock('./hooks/useLoadingIndicator.js');
55
+ vi.mock('./hooks/useFolderTrust.js');
56
+ vi.mock('./hooks/useIdeTrustListener.js');
57
+ vi.mock('./hooks/useMessageQueue.js');
58
+ vi.mock('./hooks/useAutoAcceptIndicator.js');
59
+ vi.mock('./hooks/useWorkspaceMigration.js');
60
+ vi.mock('./hooks/useGitBranchName.js');
61
+ vi.mock('./contexts/VimModeContext.js');
62
+ vi.mock('./contexts/SessionContext.js');
63
+ vi.mock('./components/shared/text-buffer.js');
64
+ vi.mock('./hooks/useLogger.js');
65
+ // Mock external utilities
66
+ vi.mock('../utils/events.js');
67
+ vi.mock('../utils/handleAutoUpdate.js');
68
+ vi.mock('./utils/ConsolePatcher.js');
69
+ vi.mock('../utils/cleanup.js');
70
+ import { useHistory } from './hooks/useHistoryManager.js';
71
+ import { useThemeCommand } from './hooks/useThemeCommand.js';
72
+ import { useAuthCommand } from './auth/useAuth.js';
73
+ import { useEditorSettings } from './hooks/useEditorSettings.js';
74
+ import { useSettingsCommand } from './hooks/useSettingsCommand.js';
75
+ import { useModelCommand } from './hooks/useModelCommand.js';
76
+ import { useSlashCommandProcessor } from './hooks/slashCommandProcessor.js';
77
+ import { useConsoleMessages } from './hooks/useConsoleMessages.js';
78
+ import { useGeminiStream } from './hooks/useGeminiStream.js';
79
+ import { useVim } from './hooks/vim.js';
80
+ import { useFolderTrust } from './hooks/useFolderTrust.js';
81
+ import { useIdeTrustListener } from './hooks/useIdeTrustListener.js';
82
+ import { useMessageQueue } from './hooks/useMessageQueue.js';
83
+ import { useAutoAcceptIndicator } from './hooks/useAutoAcceptIndicator.js';
84
+ import { useWorkspaceMigration } from './hooks/useWorkspaceMigration.js';
85
+ import { useGitBranchName } from './hooks/useGitBranchName.js';
86
+ import { useVimMode } from './contexts/VimModeContext.js';
87
+ import { useSessionStats } from './contexts/SessionContext.js';
88
+ import { useTextBuffer } from './components/shared/text-buffer.js';
89
+ import { useLogger } from './hooks/useLogger.js';
90
+ import { useLoadingIndicator } from './hooks/useLoadingIndicator.js';
91
+ import { measureElement } from 'ink';
92
+ import { useTerminalSize } from './hooks/useTerminalSize.js';
93
+ import { ShellExecutionService } from '@rdmind/rdmind-core';
94
+ describe('AppContainer State Management', () => {
95
+ let mockConfig;
96
+ let mockSettings;
97
+ let mockInitResult;
98
+ // Create typed mocks for all hooks
99
+ const mockedUseQuotaAndFallback = useQuotaAndFallback;
100
+ const mockedUseHistory = useHistory;
101
+ const mockedUseThemeCommand = useThemeCommand;
102
+ const mockedUseAuthCommand = useAuthCommand;
103
+ const mockedUseEditorSettings = useEditorSettings;
104
+ const mockedUseSettingsCommand = useSettingsCommand;
105
+ const mockedUseModelCommand = useModelCommand;
106
+ const mockedUseSlashCommandProcessor = useSlashCommandProcessor;
107
+ const mockedUseConsoleMessages = useConsoleMessages;
108
+ const mockedUseGeminiStream = useGeminiStream;
109
+ const mockedUseVim = useVim;
110
+ const mockedUseFolderTrust = useFolderTrust;
111
+ const mockedUseIdeTrustListener = useIdeTrustListener;
112
+ const mockedUseMessageQueue = useMessageQueue;
113
+ const mockedUseAutoAcceptIndicator = useAutoAcceptIndicator;
114
+ const mockedUseWorkspaceMigration = useWorkspaceMigration;
115
+ const mockedUseGitBranchName = useGitBranchName;
116
+ const mockedUseVimMode = useVimMode;
117
+ const mockedUseSessionStats = useSessionStats;
118
+ const mockedUseTextBuffer = useTextBuffer;
119
+ const mockedUseLogger = useLogger;
120
+ const mockedUseLoadingIndicator = useLoadingIndicator;
121
+ beforeEach(() => {
122
+ vi.clearAllMocks();
123
+ // Initialize mock stdout for terminal title tests
124
+ mockStdout = { write: vi.fn() };
125
+ // Mock computeWindowTitle function to centralize title logic testing
126
+ vi.mock('../utils/windowTitle.js', async () => ({
127
+ computeWindowTitle: vi.fn((folderName) =>
128
+ // Default behavior: return "Gemini - {folderName}" unless CLI_TITLE is set
129
+ process.env['CLI_TITLE'] || `Gemini - ${folderName}`),
130
+ }));
131
+ capturedUIState = null;
132
+ capturedUIActions = null;
133
+ // **Provide a default return value for EVERY mocked hook.**
134
+ mockedUseQuotaAndFallback.mockReturnValue({
135
+ proQuotaRequest: null,
136
+ handleProQuotaChoice: vi.fn(),
137
+ });
138
+ mockedUseHistory.mockReturnValue({
139
+ history: [],
140
+ addItem: vi.fn(),
141
+ updateItem: vi.fn(),
142
+ clearItems: vi.fn(),
143
+ loadHistory: vi.fn(),
144
+ });
145
+ mockedUseThemeCommand.mockReturnValue({
146
+ isThemeDialogOpen: false,
147
+ openThemeDialog: vi.fn(),
148
+ handleThemeSelect: vi.fn(),
149
+ handleThemeHighlight: vi.fn(),
150
+ });
151
+ mockedUseAuthCommand.mockReturnValue({
152
+ authState: 'authenticated',
153
+ setAuthState: vi.fn(),
154
+ authError: null,
155
+ onAuthError: vi.fn(),
156
+ isAuthDialogOpen: false,
157
+ isAuthenticating: false,
158
+ handleAuthSelect: vi.fn(),
159
+ openAuthDialog: vi.fn(),
160
+ cancelAuthentication: vi.fn(),
161
+ });
162
+ mockedUseEditorSettings.mockReturnValue({
163
+ isEditorDialogOpen: false,
164
+ openEditorDialog: vi.fn(),
165
+ handleEditorSelect: vi.fn(),
166
+ exitEditorDialog: vi.fn(),
167
+ });
168
+ mockedUseSettingsCommand.mockReturnValue({
169
+ isSettingsDialogOpen: false,
170
+ openSettingsDialog: vi.fn(),
171
+ closeSettingsDialog: vi.fn(),
172
+ });
173
+ mockedUseModelCommand.mockReturnValue({
174
+ isModelDialogOpen: false,
175
+ openModelDialog: vi.fn(),
176
+ closeModelDialog: vi.fn(),
177
+ });
178
+ mockedUseSlashCommandProcessor.mockReturnValue({
179
+ handleSlashCommand: vi.fn(),
180
+ slashCommands: [],
181
+ pendingHistoryItems: [],
182
+ commandContext: {},
183
+ shellConfirmationRequest: null,
184
+ confirmationRequest: null,
185
+ });
186
+ mockedUseConsoleMessages.mockReturnValue({
187
+ consoleMessages: [],
188
+ handleNewMessage: vi.fn(),
189
+ clearConsoleMessages: vi.fn(),
190
+ });
191
+ mockedUseGeminiStream.mockReturnValue({
192
+ streamingState: 'idle',
193
+ submitQuery: vi.fn(),
194
+ initError: null,
195
+ pendingHistoryItems: [],
196
+ thought: null,
197
+ cancelOngoingRequest: vi.fn(),
198
+ });
199
+ mockedUseVim.mockReturnValue({ handleInput: vi.fn() });
200
+ mockedUseFolderTrust.mockReturnValue({
201
+ isFolderTrustDialogOpen: false,
202
+ handleFolderTrustSelect: vi.fn(),
203
+ isRestarting: false,
204
+ });
205
+ mockedUseIdeTrustListener.mockReturnValue({
206
+ needsRestart: false,
207
+ restartReason: 'NONE',
208
+ });
209
+ mockedUseMessageQueue.mockReturnValue({
210
+ messageQueue: [],
211
+ addMessage: vi.fn(),
212
+ clearQueue: vi.fn(),
213
+ getQueuedMessagesText: vi.fn().mockReturnValue(''),
214
+ });
215
+ mockedUseAutoAcceptIndicator.mockReturnValue(false);
216
+ mockedUseWorkspaceMigration.mockReturnValue({
217
+ showWorkspaceMigrationDialog: false,
218
+ workspaceExtensions: [],
219
+ onWorkspaceMigrationDialogOpen: vi.fn(),
220
+ onWorkspaceMigrationDialogClose: vi.fn(),
221
+ });
222
+ mockedUseGitBranchName.mockReturnValue('main');
223
+ mockedUseVimMode.mockReturnValue({
224
+ isVimEnabled: false,
225
+ toggleVimEnabled: vi.fn(),
226
+ });
227
+ mockedUseSessionStats.mockReturnValue({ stats: {} });
228
+ mockedUseTextBuffer.mockReturnValue({
229
+ text: '',
230
+ setText: vi.fn(),
231
+ // Add other properties if AppContainer uses them
232
+ });
233
+ mockedUseLogger.mockReturnValue({
234
+ getPreviousUserMessages: vi.fn().mockResolvedValue([]),
235
+ });
236
+ mockedUseLoadingIndicator.mockReturnValue({
237
+ elapsedTime: '0.0s',
238
+ currentLoadingPhrase: '',
239
+ });
240
+ // Mock Config
241
+ mockConfig = makeFakeConfig();
242
+ // Mock config's getTargetDir to return consistent workspace directory
243
+ vi.spyOn(mockConfig, 'getTargetDir').mockReturnValue('/test/workspace');
244
+ // Mock GeminiClient to prevent unhandled errors from TaskTool.refreshSubagents
245
+ const mockGeminiClient = {
246
+ initialize: vi.fn().mockResolvedValue(undefined),
247
+ setTools: vi.fn().mockResolvedValue(undefined),
248
+ isInitialized: vi.fn().mockReturnValue(false), // Return false to prevent setTools from being called
249
+ };
250
+ vi.spyOn(mockConfig, 'getGeminiClient').mockReturnValue(mockGeminiClient);
251
+ // Mock SubagentManager to prevent errors during TaskTool initialization
252
+ const mockSubagentManager = {
253
+ listSubagents: vi.fn().mockResolvedValue([]),
254
+ addChangeListener: vi.fn(),
255
+ loadSubagent: vi.fn(),
256
+ createSubagentScope: vi.fn(),
257
+ };
258
+ vi.spyOn(mockConfig, 'getSubagentManager').mockReturnValue(mockSubagentManager);
259
+ // Mock LoadedSettings
260
+ mockSettings = {
261
+ merged: {
262
+ hideBanner: false,
263
+ hideFooter: false,
264
+ hideTips: false,
265
+ showMemoryUsage: false,
266
+ theme: 'default',
267
+ ui: {
268
+ showStatusInTitle: false,
269
+ hideWindowTitle: false,
270
+ },
271
+ },
272
+ };
273
+ // Mock InitializationResult
274
+ mockInitResult = {
275
+ themeError: null,
276
+ authError: null,
277
+ shouldOpenAuthDialog: false,
278
+ geminiMdFileCount: 0,
279
+ };
280
+ });
281
+ afterEach(() => {
282
+ cleanup();
283
+ });
284
+ describe('Basic Rendering', () => {
285
+ it('renders without crashing with minimal props', () => {
286
+ expect(() => {
287
+ render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: "1.0.0", initializationResult: mockInitResult }));
288
+ }).not.toThrow();
289
+ });
290
+ it('renders with startup warnings', () => {
291
+ const startupWarnings = ['Warning 1', 'Warning 2'];
292
+ expect(() => {
293
+ render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, startupWarnings: startupWarnings, version: "1.0.0", initializationResult: mockInitResult }));
294
+ }).not.toThrow();
295
+ });
296
+ });
297
+ describe('State Initialization', () => {
298
+ it('initializes with theme error from initialization result', () => {
299
+ const initResultWithError = {
300
+ ...mockInitResult,
301
+ themeError: 'Failed to load theme',
302
+ };
303
+ expect(() => {
304
+ render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: "1.0.0", initializationResult: initResultWithError }));
305
+ }).not.toThrow();
306
+ });
307
+ it('handles debug mode state', () => {
308
+ const debugConfig = makeFakeConfig();
309
+ vi.spyOn(debugConfig, 'getDebugMode').mockReturnValue(true);
310
+ expect(() => {
311
+ render(_jsx(AppContainer, { config: debugConfig, settings: mockSettings, version: "1.0.0", initializationResult: mockInitResult }));
312
+ }).not.toThrow();
313
+ });
314
+ });
315
+ describe('Context Providers', () => {
316
+ it('provides AppContext with correct values', () => {
317
+ const { unmount } = render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: "2.0.0", initializationResult: mockInitResult }));
318
+ // Should render and unmount cleanly
319
+ expect(() => unmount()).not.toThrow();
320
+ });
321
+ it('provides UIStateContext with state management', () => {
322
+ expect(() => {
323
+ render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: "1.0.0", initializationResult: mockInitResult }));
324
+ }).not.toThrow();
325
+ });
326
+ it('provides UIActionsContext with action handlers', () => {
327
+ expect(() => {
328
+ render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: "1.0.0", initializationResult: mockInitResult }));
329
+ }).not.toThrow();
330
+ });
331
+ it('provides ConfigContext with config object', () => {
332
+ expect(() => {
333
+ render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: "1.0.0", initializationResult: mockInitResult }));
334
+ }).not.toThrow();
335
+ });
336
+ });
337
+ describe('Settings Integration', () => {
338
+ it('handles settings with all display options disabled', () => {
339
+ const settingsAllHidden = {
340
+ merged: {
341
+ hideBanner: true,
342
+ hideFooter: true,
343
+ hideTips: true,
344
+ showMemoryUsage: false,
345
+ },
346
+ };
347
+ expect(() => {
348
+ render(_jsx(AppContainer, { config: mockConfig, settings: settingsAllHidden, version: "1.0.0", initializationResult: mockInitResult }));
349
+ }).not.toThrow();
350
+ });
351
+ it('handles settings with memory usage enabled', () => {
352
+ const settingsWithMemory = {
353
+ merged: {
354
+ hideBanner: false,
355
+ hideFooter: false,
356
+ hideTips: false,
357
+ showMemoryUsage: true,
358
+ },
359
+ };
360
+ expect(() => {
361
+ render(_jsx(AppContainer, { config: mockConfig, settings: settingsWithMemory, version: "1.0.0", initializationResult: mockInitResult }));
362
+ }).not.toThrow();
363
+ });
364
+ });
365
+ describe('Version Handling', () => {
366
+ it.each(['1.0.0', '2.1.3-beta', '3.0.0-nightly'])('handles version format: %s', (version) => {
367
+ expect(() => {
368
+ render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: version, initializationResult: mockInitResult }));
369
+ }).not.toThrow();
370
+ });
371
+ });
372
+ describe('Error Handling', () => {
373
+ it('handles config methods that might throw', () => {
374
+ const errorConfig = makeFakeConfig();
375
+ vi.spyOn(errorConfig, 'getModel').mockImplementation(() => {
376
+ throw new Error('Config error');
377
+ });
378
+ // Should still render without crashing - errors should be handled internally
379
+ expect(() => {
380
+ render(_jsx(AppContainer, { config: errorConfig, settings: mockSettings, version: "1.0.0", initializationResult: mockInitResult }));
381
+ }).not.toThrow();
382
+ });
383
+ it('handles undefined settings gracefully', () => {
384
+ const undefinedSettings = {
385
+ merged: {},
386
+ };
387
+ expect(() => {
388
+ render(_jsx(AppContainer, { config: mockConfig, settings: undefinedSettings, version: "1.0.0", initializationResult: mockInitResult }));
389
+ }).not.toThrow();
390
+ });
391
+ });
392
+ describe('Provider Hierarchy', () => {
393
+ it('establishes correct provider nesting order', () => {
394
+ // This tests that all the context providers are properly nested
395
+ // and that the component tree can be built without circular dependencies
396
+ const { unmount } = render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: "1.0.0", initializationResult: mockInitResult }));
397
+ expect(() => unmount()).not.toThrow();
398
+ });
399
+ });
400
+ describe('Quota and Fallback Integration', () => {
401
+ it('passes a null proQuotaRequest to UIStateContext by default', () => {
402
+ // The default mock from beforeEach already sets proQuotaRequest to null
403
+ render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: "1.0.0", initializationResult: mockInitResult }));
404
+ // Assert that the context value is as expected
405
+ expect(capturedUIState.proQuotaRequest).toBeNull();
406
+ });
407
+ it('passes a valid proQuotaRequest to UIStateContext when provided by the hook', () => {
408
+ // Arrange: Create a mock request object that a UI dialog would receive
409
+ const mockRequest = {
410
+ failedModel: 'gemini-pro',
411
+ fallbackModel: 'gemini-flash',
412
+ resolve: vi.fn(),
413
+ };
414
+ mockedUseQuotaAndFallback.mockReturnValue({
415
+ proQuotaRequest: mockRequest,
416
+ handleProQuotaChoice: vi.fn(),
417
+ });
418
+ // Act: Render the container
419
+ render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: "1.0.0", initializationResult: mockInitResult }));
420
+ // Assert: The mock request is correctly passed through the context
421
+ expect(capturedUIState.proQuotaRequest).toEqual(mockRequest);
422
+ });
423
+ it('passes the handleProQuotaChoice function to UIActionsContext', () => {
424
+ // Arrange: Create a mock handler function
425
+ const mockHandler = vi.fn();
426
+ mockedUseQuotaAndFallback.mockReturnValue({
427
+ proQuotaRequest: null,
428
+ handleProQuotaChoice: mockHandler,
429
+ });
430
+ // Act: Render the container
431
+ render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: "1.0.0", initializationResult: mockInitResult }));
432
+ // Assert: The action in the context is the mock handler we provided
433
+ expect(capturedUIActions.handleProQuotaChoice).toBe(mockHandler);
434
+ // You can even verify that the plumbed function is callable
435
+ capturedUIActions.handleProQuotaChoice('auth');
436
+ expect(mockHandler).toHaveBeenCalledWith('auth');
437
+ });
438
+ });
439
+ describe('Terminal Title Update Feature', () => {
440
+ beforeEach(() => {
441
+ // Reset mock stdout for each test
442
+ mockStdout = { write: vi.fn() };
443
+ });
444
+ it('should not update terminal title when showStatusInTitle is false', () => {
445
+ // Arrange: Set up mock settings with showStatusInTitle disabled
446
+ const mockSettingsWithShowStatusFalse = {
447
+ ...mockSettings,
448
+ merged: {
449
+ ...mockSettings.merged,
450
+ ui: {
451
+ ...mockSettings.merged.ui,
452
+ showStatusInTitle: false,
453
+ hideWindowTitle: false,
454
+ },
455
+ },
456
+ };
457
+ // Act: Render the container
458
+ const { unmount } = render(_jsx(AppContainer, { config: mockConfig, settings: mockSettingsWithShowStatusFalse, version: "1.0.0", initializationResult: mockInitResult }));
459
+ // Assert: Check that no title-related writes occurred
460
+ const titleWrites = mockStdout.write.mock.calls.filter((call) => call[0].includes('\x1b]2;'));
461
+ expect(titleWrites).toHaveLength(0);
462
+ unmount();
463
+ });
464
+ it('should not update terminal title when hideWindowTitle is true', () => {
465
+ // Arrange: Set up mock settings with hideWindowTitle enabled
466
+ const mockSettingsWithHideTitleTrue = {
467
+ ...mockSettings,
468
+ merged: {
469
+ ...mockSettings.merged,
470
+ ui: {
471
+ ...mockSettings.merged.ui,
472
+ showStatusInTitle: true,
473
+ hideWindowTitle: true,
474
+ },
475
+ },
476
+ };
477
+ // Act: Render the container
478
+ const { unmount } = render(_jsx(AppContainer, { config: mockConfig, settings: mockSettingsWithHideTitleTrue, version: "1.0.0", initializationResult: mockInitResult }));
479
+ // Assert: Check that no title-related writes occurred
480
+ const titleWrites = mockStdout.write.mock.calls.filter((call) => call[0].includes('\x1b]2;'));
481
+ expect(titleWrites).toHaveLength(0);
482
+ unmount();
483
+ });
484
+ it('should update terminal title with thought subject when in active state', () => {
485
+ // Arrange: Set up mock settings with showStatusInTitle enabled
486
+ const mockSettingsWithTitleEnabled = {
487
+ ...mockSettings,
488
+ merged: {
489
+ ...mockSettings.merged,
490
+ ui: {
491
+ ...mockSettings.merged.ui,
492
+ showStatusInTitle: true,
493
+ hideWindowTitle: false,
494
+ },
495
+ },
496
+ };
497
+ // Mock the streaming state and thought
498
+ const thoughtSubject = 'Processing request';
499
+ mockedUseGeminiStream.mockReturnValue({
500
+ streamingState: 'responding',
501
+ submitQuery: vi.fn(),
502
+ initError: null,
503
+ pendingHistoryItems: [],
504
+ thought: { subject: thoughtSubject },
505
+ cancelOngoingRequest: vi.fn(),
506
+ });
507
+ // Act: Render the container
508
+ const { unmount } = render(_jsx(AppContainer, { config: mockConfig, settings: mockSettingsWithTitleEnabled, version: "1.0.0", initializationResult: mockInitResult }));
509
+ // Assert: Check that title was updated with thought subject
510
+ const titleWrites = mockStdout.write.mock.calls.filter((call) => call[0].includes('\x1b]2;'));
511
+ expect(titleWrites).toHaveLength(1);
512
+ expect(titleWrites[0][0]).toBe(`\x1b]2;${thoughtSubject.padEnd(80, ' ')}\x07`);
513
+ unmount();
514
+ });
515
+ it('should update terminal title with default text when in Idle state and no thought subject', () => {
516
+ // Arrange: Set up mock settings with showStatusInTitle enabled
517
+ const mockSettingsWithTitleEnabled = {
518
+ ...mockSettings,
519
+ merged: {
520
+ ...mockSettings.merged,
521
+ ui: {
522
+ ...mockSettings.merged.ui,
523
+ showStatusInTitle: true,
524
+ hideWindowTitle: false,
525
+ },
526
+ },
527
+ };
528
+ // Mock the streaming state as Idle with no thought
529
+ mockedUseGeminiStream.mockReturnValue({
530
+ streamingState: 'idle',
531
+ submitQuery: vi.fn(),
532
+ initError: null,
533
+ pendingHistoryItems: [],
534
+ thought: null,
535
+ cancelOngoingRequest: vi.fn(),
536
+ });
537
+ // Act: Render the container
538
+ const { unmount } = render(_jsx(AppContainer, { config: mockConfig, settings: mockSettingsWithTitleEnabled, version: "1.0.0", initializationResult: mockInitResult }));
539
+ // Assert: Check that title was updated with default Idle text
540
+ const titleWrites = mockStdout.write.mock.calls.filter((call) => call[0].includes('\x1b]2;'));
541
+ expect(titleWrites).toHaveLength(1);
542
+ expect(titleWrites[0][0]).toBe(`\x1b]2;${'Gemini - workspace'.padEnd(80, ' ')}\x07`);
543
+ unmount();
544
+ });
545
+ it('should update terminal title when in WaitingForConfirmation state with thought subject', () => {
546
+ // Arrange: Set up mock settings with showStatusInTitle enabled
547
+ const mockSettingsWithTitleEnabled = {
548
+ ...mockSettings,
549
+ merged: {
550
+ ...mockSettings.merged,
551
+ ui: {
552
+ ...mockSettings.merged.ui,
553
+ showStatusInTitle: true,
554
+ hideWindowTitle: false,
555
+ },
556
+ },
557
+ };
558
+ // Mock the streaming state and thought
559
+ const thoughtSubject = 'Confirm tool execution';
560
+ mockedUseGeminiStream.mockReturnValue({
561
+ streamingState: 'waitingForConfirmation',
562
+ submitQuery: vi.fn(),
563
+ initError: null,
564
+ pendingHistoryItems: [],
565
+ thought: { subject: thoughtSubject },
566
+ cancelOngoingRequest: vi.fn(),
567
+ });
568
+ // Act: Render the container
569
+ const { unmount } = render(_jsx(AppContainer, { config: mockConfig, settings: mockSettingsWithTitleEnabled, version: "1.0.0", initializationResult: mockInitResult }));
570
+ // Assert: Check that title was updated with confirmation text
571
+ const titleWrites = mockStdout.write.mock.calls.filter((call) => call[0].includes('\x1b]2;'));
572
+ expect(titleWrites).toHaveLength(1);
573
+ expect(titleWrites[0][0]).toBe(`\x1b]2;${thoughtSubject.padEnd(80, ' ')}\x07`);
574
+ unmount();
575
+ });
576
+ it('should pad title to exactly 80 characters', () => {
577
+ // Arrange: Set up mock settings with showStatusInTitle enabled
578
+ const mockSettingsWithTitleEnabled = {
579
+ ...mockSettings,
580
+ merged: {
581
+ ...mockSettings.merged,
582
+ ui: {
583
+ ...mockSettings.merged.ui,
584
+ showStatusInTitle: true,
585
+ hideWindowTitle: false,
586
+ },
587
+ },
588
+ };
589
+ // Mock the streaming state and thought with a short subject
590
+ const shortTitle = 'Short';
591
+ mockedUseGeminiStream.mockReturnValue({
592
+ streamingState: 'responding',
593
+ submitQuery: vi.fn(),
594
+ initError: null,
595
+ pendingHistoryItems: [],
596
+ thought: { subject: shortTitle },
597
+ cancelOngoingRequest: vi.fn(),
598
+ });
599
+ // Act: Render the container
600
+ const { unmount } = render(_jsx(AppContainer, { config: mockConfig, settings: mockSettingsWithTitleEnabled, version: "1.0.0", initializationResult: mockInitResult }));
601
+ // Assert: Check that title is padded to exactly 80 characters
602
+ const titleWrites = mockStdout.write.mock.calls.filter((call) => call[0].includes('\x1b]2;'));
603
+ expect(titleWrites).toHaveLength(1);
604
+ const calledWith = titleWrites[0][0];
605
+ const expectedTitle = shortTitle.padEnd(80, ' ');
606
+ expect(calledWith).toContain(shortTitle);
607
+ expect(calledWith).toContain('\x1b]2;');
608
+ expect(calledWith).toContain('\x07');
609
+ expect(calledWith).toBe('\x1b]2;' + expectedTitle + '\x07');
610
+ unmount();
611
+ });
612
+ it('should use correct ANSI escape code format', () => {
613
+ // Arrange: Set up mock settings with showStatusInTitle enabled
614
+ const mockSettingsWithTitleEnabled = {
615
+ ...mockSettings,
616
+ merged: {
617
+ ...mockSettings.merged,
618
+ ui: {
619
+ ...mockSettings.merged.ui,
620
+ showStatusInTitle: true,
621
+ hideWindowTitle: false,
622
+ },
623
+ },
624
+ };
625
+ // Mock the streaming state and thought
626
+ const title = 'Test Title';
627
+ mockedUseGeminiStream.mockReturnValue({
628
+ streamingState: 'responding',
629
+ submitQuery: vi.fn(),
630
+ initError: null,
631
+ pendingHistoryItems: [],
632
+ thought: { subject: title },
633
+ cancelOngoingRequest: vi.fn(),
634
+ });
635
+ // Act: Render the container
636
+ const { unmount } = render(_jsx(AppContainer, { config: mockConfig, settings: mockSettingsWithTitleEnabled, version: "1.0.0", initializationResult: mockInitResult }));
637
+ // Assert: Check that the correct ANSI escape sequence is used
638
+ const titleWrites = mockStdout.write.mock.calls.filter((call) => call[0].includes('\x1b]2;'));
639
+ expect(titleWrites).toHaveLength(1);
640
+ const expectedEscapeSequence = `\x1b]2;${title.padEnd(80, ' ')}\x07`;
641
+ expect(titleWrites[0][0]).toBe(expectedEscapeSequence);
642
+ unmount();
643
+ });
644
+ it('should use CLI_TITLE environment variable when set', () => {
645
+ // Arrange: Set up mock settings with showStatusInTitle enabled
646
+ const mockSettingsWithTitleEnabled = {
647
+ ...mockSettings,
648
+ merged: {
649
+ ...mockSettings.merged,
650
+ ui: {
651
+ ...mockSettings.merged.ui,
652
+ showStatusInTitle: true,
653
+ hideWindowTitle: false,
654
+ },
655
+ },
656
+ };
657
+ // Mock CLI_TITLE environment variable
658
+ vi.stubEnv('CLI_TITLE', 'Custom Gemini Title');
659
+ // Mock the streaming state as Idle with no thought
660
+ mockedUseGeminiStream.mockReturnValue({
661
+ streamingState: 'idle',
662
+ submitQuery: vi.fn(),
663
+ initError: null,
664
+ pendingHistoryItems: [],
665
+ thought: null,
666
+ cancelOngoingRequest: vi.fn(),
667
+ });
668
+ // Act: Render the container
669
+ const { unmount } = render(_jsx(AppContainer, { config: mockConfig, settings: mockSettingsWithTitleEnabled, version: "1.0.0", initializationResult: mockInitResult }));
670
+ // Assert: Check that title was updated with CLI_TITLE value
671
+ const titleWrites = mockStdout.write.mock.calls.filter((call) => call[0].includes('\x1b]2;'));
672
+ expect(titleWrites).toHaveLength(1);
673
+ expect(titleWrites[0][0]).toBe(`\x1b]2;${'Custom Gemini Title'.padEnd(80, ' ')}\x07`);
674
+ unmount();
675
+ });
676
+ });
677
+ describe('Terminal Height Calculation', () => {
678
+ const mockedMeasureElement = measureElement;
679
+ const mockedUseTerminalSize = useTerminalSize;
680
+ it('should prevent terminal height from being less than 1', () => {
681
+ const resizePtySpy = vi.spyOn(ShellExecutionService, 'resizePty');
682
+ // Arrange: Simulate a small terminal and a large footer
683
+ mockedUseTerminalSize.mockReturnValue({ columns: 80, rows: 5 });
684
+ mockedMeasureElement.mockReturnValue({ width: 80, height: 10 }); // Footer is taller than the screen
685
+ mockedUseGeminiStream.mockReturnValue({
686
+ streamingState: 'idle',
687
+ submitQuery: vi.fn(),
688
+ initError: null,
689
+ pendingHistoryItems: [],
690
+ thought: null,
691
+ cancelOngoingRequest: vi.fn(),
692
+ activePtyId: 'some-id',
693
+ });
694
+ render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: "1.0.0", initializationResult: mockInitResult }));
695
+ // Assert: The shell should be resized to a minimum height of 1, not a negative number.
696
+ // The old code would have tried to set a negative height.
697
+ expect(resizePtySpy).toHaveBeenCalled();
698
+ const lastCall = resizePtySpy.mock.calls[resizePtySpy.mock.calls.length - 1];
699
+ // Check the height argument specifically
700
+ expect(lastCall[2]).toBe(1);
701
+ });
702
+ });
703
+ describe('Keyboard Input Handling', () => {
704
+ it('should block quit command during authentication', () => {
705
+ mockedUseAuthCommand.mockReturnValue({
706
+ authState: 'unauthenticated',
707
+ setAuthState: vi.fn(),
708
+ authError: null,
709
+ onAuthError: vi.fn(),
710
+ isAuthDialogOpen: false,
711
+ isAuthenticating: true,
712
+ handleAuthSelect: vi.fn(),
713
+ openAuthDialog: vi.fn(),
714
+ cancelAuthentication: vi.fn(),
715
+ });
716
+ const mockHandleSlashCommand = vi.fn();
717
+ mockedUseSlashCommandProcessor.mockReturnValue({
718
+ handleSlashCommand: mockHandleSlashCommand,
719
+ slashCommands: [],
720
+ pendingHistoryItems: [],
721
+ commandContext: {},
722
+ shellConfirmationRequest: null,
723
+ confirmationRequest: null,
724
+ });
725
+ render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: "1.0.0", initializationResult: mockInitResult }));
726
+ expect(mockHandleSlashCommand).not.toHaveBeenCalledWith('/quit');
727
+ });
728
+ it('should prevent exit command when text buffer has content', () => {
729
+ mockedUseTextBuffer.mockReturnValue({
730
+ text: 'some user input',
731
+ setText: vi.fn(),
732
+ });
733
+ const mockHandleSlashCommand = vi.fn();
734
+ mockedUseSlashCommandProcessor.mockReturnValue({
735
+ handleSlashCommand: mockHandleSlashCommand,
736
+ slashCommands: [],
737
+ pendingHistoryItems: [],
738
+ commandContext: {},
739
+ shellConfirmationRequest: null,
740
+ confirmationRequest: null,
741
+ });
742
+ render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: "1.0.0", initializationResult: mockInitResult }));
743
+ expect(mockHandleSlashCommand).not.toHaveBeenCalledWith('/quit');
744
+ });
745
+ it('should require double Ctrl+C to exit when dialogs are open', () => {
746
+ vi.useFakeTimers();
747
+ mockedUseThemeCommand.mockReturnValue({
748
+ isThemeDialogOpen: true,
749
+ openThemeDialog: vi.fn(),
750
+ handleThemeSelect: vi.fn(),
751
+ handleThemeHighlight: vi.fn(),
752
+ });
753
+ const mockHandleSlashCommand = vi.fn();
754
+ mockedUseSlashCommandProcessor.mockReturnValue({
755
+ handleSlashCommand: mockHandleSlashCommand,
756
+ slashCommands: [],
757
+ pendingHistoryItems: [],
758
+ commandContext: {},
759
+ shellConfirmationRequest: null,
760
+ confirmationRequest: null,
761
+ });
762
+ render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: "1.0.0", initializationResult: mockInitResult }));
763
+ expect(mockHandleSlashCommand).not.toHaveBeenCalledWith('/quit');
764
+ expect(mockHandleSlashCommand).not.toHaveBeenCalledWith('/quit');
765
+ vi.useRealTimers();
766
+ });
767
+ it('should cancel ongoing request on first Ctrl+C', () => {
768
+ const mockCancelOngoingRequest = vi.fn();
769
+ mockedUseGeminiStream.mockReturnValue({
770
+ streamingState: 'responding',
771
+ submitQuery: vi.fn(),
772
+ initError: null,
773
+ pendingHistoryItems: [],
774
+ thought: null,
775
+ cancelOngoingRequest: mockCancelOngoingRequest,
776
+ });
777
+ const mockHandleSlashCommand = vi.fn();
778
+ mockedUseSlashCommandProcessor.mockReturnValue({
779
+ handleSlashCommand: mockHandleSlashCommand,
780
+ slashCommands: [],
781
+ pendingHistoryItems: [],
782
+ commandContext: {},
783
+ shellConfirmationRequest: null,
784
+ confirmationRequest: null,
785
+ });
786
+ render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: "1.0.0", initializationResult: mockInitResult }));
787
+ expect(mockHandleSlashCommand).not.toHaveBeenCalledWith('/quit');
788
+ });
789
+ it('should reset Ctrl+C state after timeout', () => {
790
+ vi.useFakeTimers();
791
+ const mockHandleSlashCommand = vi.fn();
792
+ mockedUseSlashCommandProcessor.mockReturnValue({
793
+ handleSlashCommand: mockHandleSlashCommand,
794
+ slashCommands: [],
795
+ pendingHistoryItems: [],
796
+ commandContext: {},
797
+ shellConfirmationRequest: null,
798
+ confirmationRequest: null,
799
+ });
800
+ render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: "1.0.0", initializationResult: mockInitResult }));
801
+ expect(mockHandleSlashCommand).not.toHaveBeenCalledWith('/quit');
802
+ vi.advanceTimersByTime(1001);
803
+ expect(mockHandleSlashCommand).not.toHaveBeenCalledWith('/quit');
804
+ vi.useRealTimers();
805
+ });
806
+ });
807
+ describe('Model Dialog Integration', () => {
808
+ it('should provide isModelDialogOpen in the UIStateContext', () => {
809
+ mockedUseModelCommand.mockReturnValue({
810
+ isModelDialogOpen: true,
811
+ openModelDialog: vi.fn(),
812
+ closeModelDialog: vi.fn(),
813
+ });
814
+ render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: "1.0.0", initializationResult: mockInitResult }));
815
+ expect(capturedUIState.isModelDialogOpen).toBe(true);
816
+ });
817
+ it('should provide model dialog actions in the UIActionsContext', () => {
818
+ const mockCloseModelDialog = vi.fn();
819
+ mockedUseModelCommand.mockReturnValue({
820
+ isModelDialogOpen: false,
821
+ openModelDialog: vi.fn(),
822
+ closeModelDialog: mockCloseModelDialog,
823
+ });
824
+ render(_jsx(AppContainer, { config: mockConfig, settings: mockSettings, version: "1.0.0", initializationResult: mockInitResult }));
825
+ // Verify that the actions are correctly passed through context
826
+ capturedUIActions.closeModelDialog();
827
+ expect(mockCloseModelDialog).toHaveBeenCalled();
828
+ });
829
+ });
830
+ });
831
+ //# sourceMappingURL=AppContainer.test.js.map