@umsai/ums-code 0.0.14-v2 → 0.3.0-v1

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 (1007) hide show
  1. package/dist/package.json +25 -12
  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 +2 -4
  48. package/dist/src/config/auth.js +10 -36
  49. package/dist/src/config/auth.js.map +1 -1
  50. package/dist/src/config/auth.test.js +12 -32
  51. package/dist/src/config/auth.test.js.map +1 -1
  52. package/dist/src/config/config.d.ts +13 -2
  53. package/dist/src/config/config.js +278 -128
  54. package/dist/src/config/config.js.map +1 -1
  55. package/dist/src/config/extension.d.ts +41 -18
  56. package/dist/src/config/extension.js +352 -195
  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/config/extensions/extensionEnablement.test.js +333 -0
  62. package/dist/src/config/extensions/extensionEnablement.test.js.map +1 -0
  63. package/dist/src/config/extensions/github.d.ts +30 -0
  64. package/dist/src/config/extensions/github.js +322 -0
  65. package/dist/src/config/extensions/github.js.map +1 -0
  66. package/dist/src/config/extensions/github.test.d.ts +6 -0
  67. package/dist/src/config/extensions/github.test.js +334 -0
  68. package/dist/src/config/extensions/github.test.js.map +1 -0
  69. package/dist/src/config/extensions/update.d.ts +19 -0
  70. package/dist/src/config/extensions/update.js +113 -0
  71. package/dist/src/config/extensions/update.js.map +1 -0
  72. package/dist/src/config/extensions/update.test.d.ts +6 -0
  73. package/dist/src/config/extensions/update.test.js +342 -0
  74. package/dist/src/config/extensions/update.test.js.map +1 -0
  75. package/dist/src/config/extensions/variableSchema.d.ts +8 -0
  76. package/dist/src/config/extensions/variableSchema.js +4 -0
  77. package/dist/src/config/extensions/variableSchema.js.map +1 -1
  78. package/dist/src/config/keyBindings.d.ts +5 -1
  79. package/dist/src/config/keyBindings.js +14 -25
  80. package/dist/src/config/keyBindings.js.map +1 -1
  81. package/dist/src/config/settings.d.ts +15 -5
  82. package/dist/src/config/settings.js +231 -274
  83. package/dist/src/config/settings.js.map +1 -1
  84. package/dist/src/config/settingsSchema.d.ts +425 -149
  85. package/dist/src/config/settingsSchema.js +396 -145
  86. package/dist/src/config/settingsSchema.js.map +1 -1
  87. package/dist/src/config/settingsSchema.test.js +64 -57
  88. package/dist/src/config/settingsSchema.test.js.map +1 -1
  89. package/dist/src/config/trustedFolders.d.ts +24 -5
  90. package/dist/src/config/trustedFolders.js +98 -48
  91. package/dist/src/config/trustedFolders.js.map +1 -1
  92. package/dist/src/config/trustedFolders.test.js +196 -20
  93. package/dist/src/config/trustedFolders.test.js.map +1 -1
  94. package/dist/src/config/webSearch.d.ts +35 -0
  95. package/dist/src/config/webSearch.js +87 -0
  96. package/dist/src/config/webSearch.js.map +1 -0
  97. package/dist/src/core/auth.d.ts +13 -0
  98. package/dist/src/core/auth.js +43 -0
  99. package/dist/src/core/auth.js.map +1 -0
  100. package/dist/src/core/initializer.d.ts +21 -0
  101. package/dist/src/core/initializer.js +44 -0
  102. package/dist/src/core/initializer.js.map +1 -0
  103. package/dist/src/core/theme.d.ts +12 -0
  104. package/dist/src/core/theme.js +23 -0
  105. package/dist/src/core/theme.js.map +1 -0
  106. package/dist/src/gemini.d.ts +2 -1
  107. package/dist/src/gemini.js +166 -128
  108. package/dist/src/gemini.js.map +1 -1
  109. package/dist/src/gemini.test.js +307 -47
  110. package/dist/src/gemini.test.js.map +1 -1
  111. package/dist/src/generated/git-commit.d.ts +2 -2
  112. package/dist/src/generated/git-commit.js +2 -2
  113. package/dist/src/generated/git-commit.js.map +1 -1
  114. package/dist/src/i18n/index.d.ts +18 -0
  115. package/dist/src/i18n/index.js +184 -0
  116. package/dist/src/i18n/index.js.map +1 -0
  117. package/dist/src/i18n/locales/en.js +1129 -0
  118. package/dist/src/i18n/locales/zh.js +1052 -0
  119. package/dist/src/nonInteractive/control/ControlContext.d.ts +63 -0
  120. package/dist/src/nonInteractive/control/ControlContext.js +31 -0
  121. package/dist/src/nonInteractive/control/ControlContext.js.map +1 -0
  122. package/dist/src/nonInteractive/control/ControlDispatcher.d.ts +86 -0
  123. package/dist/src/nonInteractive/control/ControlDispatcher.js +238 -0
  124. package/dist/src/nonInteractive/control/ControlDispatcher.js.map +1 -0
  125. package/dist/src/nonInteractive/control/ControlDispatcher.test.d.ts +6 -0
  126. package/dist/src/nonInteractive/control/ControlDispatcher.test.js +549 -0
  127. package/dist/src/nonInteractive/control/ControlDispatcher.test.js.map +1 -0
  128. package/dist/src/nonInteractive/control/ControlService.d.ts +78 -0
  129. package/dist/src/nonInteractive/control/ControlService.js +154 -0
  130. package/dist/src/nonInteractive/control/ControlService.js.map +1 -0
  131. package/dist/src/nonInteractive/control/controllers/baseController.d.ts +50 -0
  132. package/dist/src/nonInteractive/control/controllers/baseController.js +102 -0
  133. package/dist/src/nonInteractive/control/controllers/baseController.js.map +1 -0
  134. package/dist/src/nonInteractive/control/controllers/hookController.d.ts +25 -0
  135. package/dist/src/nonInteractive/control/controllers/hookController.js +42 -0
  136. package/dist/src/nonInteractive/control/controllers/hookController.js.map +1 -0
  137. package/dist/src/nonInteractive/control/controllers/mcpController.d.ts +42 -0
  138. package/dist/src/nonInteractive/control/controllers/mcpController.js +205 -0
  139. package/dist/src/nonInteractive/control/controllers/mcpController.js.map +1 -0
  140. package/dist/src/nonInteractive/control/controllers/permissionController.d.ts +78 -0
  141. package/dist/src/nonInteractive/control/controllers/permissionController.js +358 -0
  142. package/dist/src/nonInteractive/control/controllers/permissionController.js.map +1 -0
  143. package/dist/src/nonInteractive/control/controllers/systemController.d.ts +56 -0
  144. package/dist/src/nonInteractive/control/controllers/systemController.js +166 -0
  145. package/dist/src/nonInteractive/control/controllers/systemController.js.map +1 -0
  146. package/dist/src/nonInteractive/control/types/serviceAPIs.d.ts +120 -0
  147. package/dist/src/nonInteractive/control/types/serviceAPIs.js +7 -0
  148. package/dist/src/nonInteractive/control/types/serviceAPIs.js.map +1 -0
  149. package/dist/src/nonInteractive/io/BaseJsonOutputAdapter.d.ts +446 -0
  150. package/dist/src/nonInteractive/io/BaseJsonOutputAdapter.js +891 -0
  151. package/dist/src/nonInteractive/io/BaseJsonOutputAdapter.js.map +1 -0
  152. package/dist/src/nonInteractive/io/BaseJsonOutputAdapter.test.d.ts +6 -0
  153. package/dist/src/nonInteractive/io/BaseJsonOutputAdapter.test.js +1197 -0
  154. package/dist/src/nonInteractive/io/BaseJsonOutputAdapter.test.js.map +1 -0
  155. package/dist/src/nonInteractive/io/JsonOutputAdapter.d.ts +29 -0
  156. package/dist/src/nonInteractive/io/JsonOutputAdapter.js +56 -0
  157. package/dist/src/nonInteractive/io/JsonOutputAdapter.js.map +1 -0
  158. package/dist/src/nonInteractive/io/JsonOutputAdapter.test.d.ts +6 -0
  159. package/dist/src/nonInteractive/io/JsonOutputAdapter.test.js +624 -0
  160. package/dist/src/nonInteractive/io/JsonOutputAdapter.test.js.map +1 -0
  161. package/dist/src/nonInteractive/io/StreamJsonInputReader.d.ts +16 -0
  162. package/dist/src/nonInteractive/io/StreamJsonInputReader.js +54 -0
  163. package/dist/src/nonInteractive/io/StreamJsonInputReader.js.map +1 -0
  164. package/dist/src/nonInteractive/io/StreamJsonInputReader.test.d.ts +6 -0
  165. package/dist/src/nonInteractive/io/StreamJsonInputReader.test.js +178 -0
  166. package/dist/src/nonInteractive/io/StreamJsonInputReader.test.js.map +1 -0
  167. package/dist/src/nonInteractive/io/StreamJsonOutputAdapter.d.ts +69 -0
  168. package/dist/src/nonInteractive/io/StreamJsonOutputAdapter.js +185 -0
  169. package/dist/src/nonInteractive/io/StreamJsonOutputAdapter.js.map +1 -0
  170. package/dist/src/nonInteractive/io/StreamJsonOutputAdapter.test.d.ts +6 -0
  171. package/dist/src/nonInteractive/io/StreamJsonOutputAdapter.test.js +808 -0
  172. package/dist/src/nonInteractive/io/StreamJsonOutputAdapter.test.js.map +1 -0
  173. package/dist/src/nonInteractive/session.d.ts +23 -0
  174. package/dist/src/nonInteractive/session.js +549 -0
  175. package/dist/src/nonInteractive/session.js.map +1 -0
  176. package/dist/src/nonInteractive/session.test.d.ts +6 -0
  177. package/dist/src/nonInteractive/session.test.js +407 -0
  178. package/dist/src/nonInteractive/session.test.js.map +1 -0
  179. package/dist/src/nonInteractive/types.d.ts +344 -0
  180. package/dist/src/nonInteractive/types.js +78 -0
  181. package/dist/src/nonInteractive/types.js.map +1 -0
  182. package/dist/src/nonInteractiveCli.d.ts +22 -1
  183. package/dist/src/nonInteractiveCli.js +245 -69
  184. package/dist/src/nonInteractiveCli.js.map +1 -1
  185. package/dist/src/nonInteractiveCliCommands.d.ts +35 -0
  186. package/dist/src/nonInteractiveCliCommands.js +144 -0
  187. package/dist/src/nonInteractiveCliCommands.js.map +1 -0
  188. package/dist/src/services/BuiltinCommandLoader.js +5 -3
  189. package/dist/src/services/BuiltinCommandLoader.js.map +1 -1
  190. package/dist/src/services/BuiltinCommandLoader.test.js +53 -19
  191. package/dist/src/services/BuiltinCommandLoader.test.js.map +1 -1
  192. package/dist/src/services/FileCommandLoader.d.ts +2 -0
  193. package/dist/src/services/FileCommandLoader.js +11 -1
  194. package/dist/src/services/FileCommandLoader.js.map +1 -1
  195. package/dist/src/services/McpPromptLoader.js +43 -8
  196. package/dist/src/services/McpPromptLoader.js.map +1 -1
  197. package/dist/src/services/McpPromptLoader.test.js +228 -1
  198. package/dist/src/services/McpPromptLoader.test.js.map +1 -1
  199. package/dist/src/services/prompt-processors/shellProcessor.js +8 -1
  200. package/dist/src/services/prompt-processors/shellProcessor.js.map +1 -1
  201. package/dist/src/test-utils/createExtension.d.ts +15 -0
  202. package/dist/src/test-utils/createExtension.js +25 -0
  203. package/dist/src/test-utils/createExtension.js.map +1 -0
  204. package/dist/src/test-utils/mockCommandContext.js +2 -0
  205. package/dist/src/test-utils/mockCommandContext.js.map +1 -1
  206. package/dist/src/test-utils/render.d.ts +5 -1
  207. package/dist/src/test-utils/render.js +5 -1
  208. package/dist/src/test-utils/render.js.map +1 -1
  209. package/dist/src/ui/App.d.ts +1 -10
  210. package/dist/src/ui/App.js +26 -833
  211. package/dist/src/ui/App.js.map +1 -1
  212. package/dist/src/ui/AppContainer.d.ts +17 -0
  213. package/dist/src/ui/AppContainer.js +1072 -0
  214. package/dist/src/ui/AppContainer.js.map +1 -0
  215. package/dist/src/ui/AppContainer.test.d.ts +6 -0
  216. package/dist/src/ui/AppContainer.test.js +831 -0
  217. package/dist/src/ui/AppContainer.test.js.map +1 -0
  218. package/dist/src/ui/IdeIntegrationNudge.d.ts +2 -2
  219. package/dist/src/ui/IdeIntegrationNudge.js +6 -8
  220. package/dist/src/ui/IdeIntegrationNudge.js.map +1 -1
  221. package/dist/src/ui/auth/AuthDialog.d.ts +7 -0
  222. package/dist/src/ui/auth/AuthDialog.js +90 -0
  223. package/dist/src/ui/auth/AuthDialog.js.map +1 -0
  224. package/dist/src/ui/auth/AuthDialog.test.d.ts +6 -0
  225. package/dist/src/ui/{components → auth}/AuthDialog.test.js +141 -29
  226. package/dist/src/ui/auth/AuthDialog.test.js.map +1 -0
  227. package/dist/src/ui/{components → auth}/AuthInProgress.js +3 -2
  228. package/dist/src/ui/auth/AuthInProgress.js.map +1 -0
  229. package/dist/src/ui/auth/useAuth.d.ts +25 -0
  230. package/dist/src/ui/auth/useAuth.js +180 -0
  231. package/dist/src/ui/auth/useAuth.js.map +1 -0
  232. package/dist/src/ui/commands/aboutCommand.js +7 -25
  233. package/dist/src/ui/commands/aboutCommand.js.map +1 -1
  234. package/dist/src/ui/commands/agentsCommand.js +10 -3
  235. package/dist/src/ui/commands/agentsCommand.js.map +1 -1
  236. package/dist/src/ui/commands/approvalModeCommand.js +8 -329
  237. package/dist/src/ui/commands/approvalModeCommand.js.map +1 -1
  238. package/dist/src/ui/commands/approvalModeCommand.test.js +19 -263
  239. package/dist/src/ui/commands/approvalModeCommand.test.js.map +1 -1
  240. package/dist/src/ui/commands/authCommand.js +4 -1
  241. package/dist/src/ui/commands/authCommand.js.map +1 -1
  242. package/dist/src/ui/commands/bugCommand.js +13 -33
  243. package/dist/src/ui/commands/bugCommand.js.map +1 -1
  244. package/dist/src/ui/commands/chatCommand.d.ts +2 -0
  245. package/dist/src/ui/commands/chatCommand.js +137 -21
  246. package/dist/src/ui/commands/chatCommand.js.map +1 -1
  247. package/dist/src/ui/commands/clearCommand.js +7 -4
  248. package/dist/src/ui/commands/clearCommand.js.map +1 -1
  249. package/dist/src/ui/commands/compressCommand.js +9 -4
  250. package/dist/src/ui/commands/compressCommand.js.map +1 -1
  251. package/dist/src/ui/commands/copyCommand.js +4 -1
  252. package/dist/src/ui/commands/copyCommand.js.map +1 -1
  253. package/dist/src/ui/commands/corgiCommand.js +1 -0
  254. package/dist/src/ui/commands/corgiCommand.js.map +1 -1
  255. package/dist/src/ui/commands/directoryCommand.js +31 -13
  256. package/dist/src/ui/commands/directoryCommand.js.map +1 -1
  257. package/dist/src/ui/commands/docsCommand.js +9 -3
  258. package/dist/src/ui/commands/docsCommand.js.map +1 -1
  259. package/dist/src/ui/commands/editorCommand.js +4 -1
  260. package/dist/src/ui/commands/editorCommand.js.map +1 -1
  261. package/dist/src/ui/commands/extensionsCommand.js +99 -15
  262. package/dist/src/ui/commands/extensionsCommand.js.map +1 -1
  263. package/dist/src/ui/commands/helpCommand.js +4 -1
  264. package/dist/src/ui/commands/helpCommand.js.map +1 -1
  265. package/dist/src/ui/commands/ideCommand.d.ts +1 -2
  266. package/dist/src/ui/commands/ideCommand.js +42 -17
  267. package/dist/src/ui/commands/ideCommand.js.map +1 -1
  268. package/dist/src/ui/commands/initCommand.js +5 -3
  269. package/dist/src/ui/commands/initCommand.js.map +1 -1
  270. package/dist/src/ui/commands/{privacyCommand.d.ts → languageCommand.d.ts} +1 -1
  271. package/dist/src/ui/commands/languageCommand.js +386 -0
  272. package/dist/src/ui/commands/languageCommand.js.map +1 -0
  273. package/dist/src/ui/commands/mcpCommand.js +124 -279
  274. package/dist/src/ui/commands/mcpCommand.js.map +1 -1
  275. package/dist/src/ui/commands/memoryCommand.js +55 -26
  276. package/dist/src/ui/commands/memoryCommand.js.map +1 -1
  277. package/dist/src/ui/commands/modelCommand.js +10 -20
  278. package/dist/src/ui/commands/modelCommand.js.map +1 -1
  279. package/dist/src/ui/commands/modelCommand.test.js +10 -11
  280. package/dist/src/ui/commands/modelCommand.test.js.map +1 -1
  281. package/dist/src/ui/commands/permissionsCommand.d.ts +7 -0
  282. package/dist/src/ui/commands/permissionsCommand.js +19 -0
  283. package/dist/src/ui/commands/permissionsCommand.js.map +1 -0
  284. package/dist/src/ui/commands/permissionsCommand.test.d.ts +6 -0
  285. package/dist/src/ui/commands/permissionsCommand.test.js +30 -0
  286. package/dist/src/ui/commands/permissionsCommand.test.js.map +1 -0
  287. package/dist/src/ui/commands/quitCommand.js +7 -2
  288. package/dist/src/ui/commands/quitCommand.js.map +1 -1
  289. package/dist/src/ui/commands/settingsCommand.js +4 -1
  290. package/dist/src/ui/commands/settingsCommand.js.map +1 -1
  291. package/dist/src/ui/commands/setupGithubCommand.js +4 -1
  292. package/dist/src/ui/commands/setupGithubCommand.js.map +1 -1
  293. package/dist/src/ui/commands/statsCommand.js +11 -4
  294. package/dist/src/ui/commands/statsCommand.js.map +1 -1
  295. package/dist/src/ui/commands/summaryCommand.js +16 -9
  296. package/dist/src/ui/commands/summaryCommand.js.map +1 -1
  297. package/dist/src/ui/commands/terminalSetupCommand.js +9 -3
  298. package/dist/src/ui/commands/terminalSetupCommand.js.map +1 -1
  299. package/dist/src/ui/commands/themeCommand.js +4 -1
  300. package/dist/src/ui/commands/themeCommand.js.map +1 -1
  301. package/dist/src/ui/commands/toolsCommand.js +15 -26
  302. package/dist/src/ui/commands/toolsCommand.js.map +1 -1
  303. package/dist/src/ui/commands/types.d.ts +8 -3
  304. package/dist/src/ui/commands/types.js +0 -1
  305. package/dist/src/ui/commands/types.js.map +1 -1
  306. package/dist/src/ui/commands/vimCommand.js +4 -1
  307. package/dist/src/ui/commands/vimCommand.js.map +1 -1
  308. package/dist/src/ui/components/AboutBox.d.ts +2 -9
  309. package/dist/src/ui/components/AboutBox.js +7 -3
  310. package/dist/src/ui/components/AboutBox.js.map +1 -1
  311. package/dist/src/ui/components/AnsiOutput.d.ts +13 -0
  312. package/dist/src/ui/components/AnsiOutput.js +12 -0
  313. package/dist/src/ui/components/AnsiOutput.js.map +1 -0
  314. package/dist/src/ui/components/AnsiOutput.test.d.ts +6 -0
  315. package/dist/src/ui/components/AnsiOutput.test.js +97 -0
  316. package/dist/src/ui/components/AnsiOutput.test.js.map +1 -0
  317. package/dist/src/ui/components/AppHeader.d.ts +10 -0
  318. package/dist/src/ui/components/AppHeader.js +19 -0
  319. package/dist/src/ui/components/AppHeader.js.map +1 -0
  320. package/dist/src/ui/components/ApprovalModeDialog.d.ts +21 -0
  321. package/dist/src/ui/components/ApprovalModeDialog.js +68 -0
  322. package/dist/src/ui/components/ApprovalModeDialog.js.map +1 -0
  323. package/dist/src/ui/components/AutoAcceptIndicator.js +12 -11
  324. package/dist/src/ui/components/AutoAcceptIndicator.js.map +1 -1
  325. package/dist/src/ui/components/Composer.d.ts +6 -0
  326. package/dist/src/ui/components/Composer.js +55 -0
  327. package/dist/src/ui/components/Composer.js.map +1 -0
  328. package/dist/src/ui/components/Composer.test.d.ts +6 -0
  329. package/dist/src/ui/components/Composer.test.js +337 -0
  330. package/dist/src/ui/components/Composer.test.js.map +1 -0
  331. package/dist/src/ui/components/ConfigInitDisplay.d.ts +6 -0
  332. package/dist/src/ui/components/ConfigInitDisplay.js +42 -0
  333. package/dist/src/ui/components/ConfigInitDisplay.js.map +1 -0
  334. package/dist/src/ui/components/ConsentPrompt.d.ts +13 -0
  335. package/dist/src/ui/components/ConsentPrompt.js +19 -0
  336. package/dist/src/ui/components/ConsentPrompt.js.map +1 -0
  337. package/dist/src/ui/components/ConsentPrompt.test.d.ts +6 -0
  338. package/dist/src/ui/components/ConsentPrompt.test.js +67 -0
  339. package/dist/src/ui/components/ConsentPrompt.test.js.map +1 -0
  340. package/dist/src/ui/components/ConsoleSummaryDisplay.js +2 -2
  341. package/dist/src/ui/components/ConsoleSummaryDisplay.js.map +1 -1
  342. package/dist/src/ui/components/ContextSummaryDisplay.js +34 -10
  343. package/dist/src/ui/components/ContextSummaryDisplay.js.map +1 -1
  344. package/dist/src/ui/components/ContextUsageDisplay.d.ts +4 -1
  345. package/dist/src/ui/components/ContextUsageDisplay.js +27 -5
  346. package/dist/src/ui/components/ContextUsageDisplay.js.map +1 -1
  347. package/dist/src/ui/components/DebugProfiler.js +2 -2
  348. package/dist/src/ui/components/DebugProfiler.js.map +1 -1
  349. package/dist/src/ui/components/DetailedMessagesDisplay.js +7 -7
  350. package/dist/src/ui/components/DetailedMessagesDisplay.js.map +1 -1
  351. package/dist/src/ui/components/DialogManager.d.ts +12 -0
  352. package/dist/src/ui/components/DialogManager.js +177 -0
  353. package/dist/src/ui/components/DialogManager.js.map +1 -0
  354. package/dist/src/ui/components/EditorSettingsDialog.js +21 -7
  355. package/dist/src/ui/components/EditorSettingsDialog.js.map +1 -1
  356. package/dist/src/ui/components/ExitWarning.d.ts +7 -0
  357. package/dist/src/ui/components/ExitWarning.js +9 -0
  358. package/dist/src/ui/components/ExitWarning.js.map +1 -0
  359. package/dist/src/ui/components/FolderTrustDialog.js +22 -9
  360. package/dist/src/ui/components/FolderTrustDialog.js.map +1 -1
  361. package/dist/src/ui/components/FolderTrustDialog.test.js +37 -12
  362. package/dist/src/ui/components/FolderTrustDialog.test.js.map +1 -1
  363. package/dist/src/ui/components/Footer.d.ts +1 -17
  364. package/dist/src/ui/components/Footer.js +33 -11
  365. package/dist/src/ui/components/Footer.js.map +1 -1
  366. package/dist/src/ui/components/GeminiRespondingSpinner.d.ts +5 -0
  367. package/dist/src/ui/components/GeminiRespondingSpinner.js +7 -2
  368. package/dist/src/ui/components/GeminiRespondingSpinner.js.map +1 -1
  369. package/dist/src/ui/components/Header.js +2 -2
  370. package/dist/src/ui/components/Header.js.map +1 -1
  371. package/dist/src/ui/components/Help.d.ts +1 -1
  372. package/dist/src/ui/components/Help.js +20 -7
  373. package/dist/src/ui/components/Help.js.map +1 -1
  374. package/dist/src/ui/components/Help.test.d.ts +6 -0
  375. package/dist/src/ui/components/Help.test.js +57 -0
  376. package/dist/src/ui/components/Help.test.js.map +1 -0
  377. package/dist/src/ui/components/HistoryItemDisplay.d.ts +5 -4
  378. package/dist/src/ui/components/HistoryItemDisplay.js +13 -4
  379. package/dist/src/ui/components/HistoryItemDisplay.js.map +1 -1
  380. package/dist/src/ui/components/HistoryItemDisplay.test.js +107 -17
  381. package/dist/src/ui/components/HistoryItemDisplay.test.js.map +1 -1
  382. package/dist/src/ui/components/IdeTrustChangeDialog.d.ts +11 -0
  383. package/dist/src/ui/components/IdeTrustChangeDialog.js +32 -0
  384. package/dist/src/ui/components/IdeTrustChangeDialog.js.map +1 -0
  385. package/dist/src/ui/components/IdeTrustChangeDialog.test.d.ts +6 -0
  386. package/dist/src/ui/components/IdeTrustChangeDialog.test.js +57 -0
  387. package/dist/src/ui/components/IdeTrustChangeDialog.test.js.map +1 -0
  388. package/dist/src/ui/components/InputPrompt.d.ts +9 -0
  389. package/dist/src/ui/components/InputPrompt.js +187 -167
  390. package/dist/src/ui/components/InputPrompt.js.map +1 -1
  391. package/dist/src/ui/components/LoadingIndicator.js +8 -3
  392. package/dist/src/ui/components/LoadingIndicator.js.map +1 -1
  393. package/dist/src/ui/components/LoadingIndicator.test.js +4 -0
  394. package/dist/src/ui/components/LoadingIndicator.test.js.map +1 -1
  395. package/dist/src/ui/components/LoopDetectionConfirmation.d.ts +13 -0
  396. package/dist/src/ui/components/LoopDetectionConfirmation.js +37 -0
  397. package/dist/src/ui/components/LoopDetectionConfirmation.js.map +1 -0
  398. package/dist/src/ui/components/LoopDetectionConfirmation.test.d.ts +6 -0
  399. package/dist/src/ui/components/LoopDetectionConfirmation.test.js +28 -0
  400. package/dist/src/ui/components/LoopDetectionConfirmation.test.js.map +1 -0
  401. package/dist/src/ui/components/MainContent.d.ts +6 -0
  402. package/dist/src/ui/components/MainContent.js +28 -0
  403. package/dist/src/ui/components/MainContent.js.map +1 -0
  404. package/dist/src/ui/components/MemoryUsageDisplay.js +6 -4
  405. package/dist/src/ui/components/MemoryUsageDisplay.js.map +1 -1
  406. package/dist/src/ui/components/ModelDialog.d.ts +11 -0
  407. package/dist/src/ui/components/ModelDialog.js +43 -0
  408. package/dist/src/ui/components/ModelDialog.js.map +1 -0
  409. package/dist/src/ui/components/ModelDialog.test.d.ts +6 -0
  410. package/dist/src/ui/components/ModelDialog.test.js +158 -0
  411. package/dist/src/ui/components/ModelDialog.test.js.map +1 -0
  412. package/dist/src/ui/components/ModelStatsDisplay.js +10 -9
  413. package/dist/src/ui/components/ModelStatsDisplay.js.map +1 -1
  414. package/dist/src/ui/components/ModelSwitchDialog.d.ts +3 -1
  415. package/dist/src/ui/components/ModelSwitchDialog.js +11 -7
  416. package/dist/src/ui/components/ModelSwitchDialog.js.map +1 -1
  417. package/dist/src/ui/components/ModelSwitchDialog.test.js +14 -10
  418. package/dist/src/ui/components/ModelSwitchDialog.test.js.map +1 -1
  419. package/dist/src/ui/components/Notifications.d.ts +6 -0
  420. package/dist/src/ui/components/Notifications.js +23 -0
  421. package/dist/src/ui/components/Notifications.js.map +1 -0
  422. package/dist/src/ui/components/OpenAIKeyPrompt.d.ts +19 -1
  423. package/dist/src/ui/components/OpenAIKeyPrompt.js +99 -43
  424. package/dist/src/ui/components/OpenAIKeyPrompt.js.map +1 -1
  425. package/dist/src/ui/components/OpenAIKeyPrompt.test.js +8 -1
  426. package/dist/src/ui/components/OpenAIKeyPrompt.test.js.map +1 -1
  427. package/dist/src/ui/components/PermissionsModifyTrustDialog.d.ts +13 -0
  428. package/dist/src/ui/components/PermissionsModifyTrustDialog.js +48 -0
  429. package/dist/src/ui/components/PermissionsModifyTrustDialog.js.map +1 -0
  430. package/dist/src/ui/components/PermissionsModifyTrustDialog.test.d.ts +6 -0
  431. package/dist/src/ui/components/PermissionsModifyTrustDialog.test.js +154 -0
  432. package/dist/src/ui/components/PermissionsModifyTrustDialog.test.js.map +1 -0
  433. package/dist/src/ui/components/PrepareLabel.d.ts +5 -5
  434. package/dist/src/ui/components/PrepareLabel.js +67 -11
  435. package/dist/src/ui/components/PrepareLabel.js.map +1 -1
  436. package/dist/src/ui/components/PrepareLabel.test.d.ts +6 -0
  437. package/dist/src/ui/components/PrepareLabel.test.js +71 -0
  438. package/dist/src/ui/components/PrepareLabel.test.js.map +1 -0
  439. package/dist/src/ui/components/ProQuotaDialog.d.ts +13 -0
  440. package/dist/src/ui/components/ProQuotaDialog.js +24 -0
  441. package/dist/src/ui/components/ProQuotaDialog.js.map +1 -0
  442. package/dist/src/ui/components/ProQuotaDialog.test.d.ts +6 -0
  443. package/dist/src/ui/components/ProQuotaDialog.test.js +58 -0
  444. package/dist/src/ui/components/ProQuotaDialog.test.js.map +1 -0
  445. package/dist/src/ui/components/QueuedMessageDisplay.d.ts +9 -0
  446. package/dist/src/ui/components/QueuedMessageDisplay.js +20 -0
  447. package/dist/src/ui/components/QueuedMessageDisplay.js.map +1 -0
  448. package/dist/src/ui/components/QueuedMessageDisplay.test.d.ts +6 -0
  449. package/dist/src/ui/components/QueuedMessageDisplay.test.js +56 -0
  450. package/dist/src/ui/components/QueuedMessageDisplay.test.js.map +1 -0
  451. package/dist/src/ui/components/QuitConfirmationDialog.js +10 -5
  452. package/dist/src/ui/components/QuitConfirmationDialog.js.map +1 -1
  453. package/dist/src/ui/components/QuittingDisplay.d.ts +6 -0
  454. package/dist/src/ui/components/QuittingDisplay.js +20 -0
  455. package/dist/src/ui/components/QuittingDisplay.js.map +1 -0
  456. package/dist/src/ui/components/QwenOAuthProgress.d.ts +2 -2
  457. package/dist/src/ui/components/QwenOAuthProgress.js +19 -11
  458. package/dist/src/ui/components/QwenOAuthProgress.js.map +1 -1
  459. package/dist/src/ui/components/QwenOAuthProgress.test.js +85 -13
  460. package/dist/src/ui/components/QwenOAuthProgress.test.js.map +1 -1
  461. package/dist/src/ui/components/SessionSummaryDisplay.js +2 -1
  462. package/dist/src/ui/components/SessionSummaryDisplay.js.map +1 -1
  463. package/dist/src/ui/components/SettingsDialog.d.ts +4 -1
  464. package/dist/src/ui/components/SettingsDialog.js +125 -28
  465. package/dist/src/ui/components/SettingsDialog.js.map +1 -1
  466. package/dist/src/ui/components/SettingsDialog.test.js +475 -84
  467. package/dist/src/ui/components/SettingsDialog.test.js.map +1 -1
  468. package/dist/src/ui/components/ShellConfirmationDialog.js +9 -5
  469. package/dist/src/ui/components/ShellConfirmationDialog.js.map +1 -1
  470. package/dist/src/ui/components/ShellInputPrompt.d.ts +11 -0
  471. package/dist/src/ui/components/ShellInputPrompt.js +36 -0
  472. package/dist/src/ui/components/ShellInputPrompt.js.map +1 -0
  473. package/dist/src/ui/components/ShellModeIndicator.js +2 -2
  474. package/dist/src/ui/components/ShellModeIndicator.js.map +1 -1
  475. package/dist/src/ui/components/ShowMoreLines.js +2 -2
  476. package/dist/src/ui/components/ShowMoreLines.js.map +1 -1
  477. package/dist/src/ui/components/StatsDisplay.js +8 -7
  478. package/dist/src/ui/components/StatsDisplay.js.map +1 -1
  479. package/dist/src/ui/components/SuggestionsDisplay.d.ts +7 -2
  480. package/dist/src/ui/components/SuggestionsDisplay.js +17 -17
  481. package/dist/src/ui/components/SuggestionsDisplay.js.map +1 -1
  482. package/dist/src/ui/components/ThemeDialog.js +17 -29
  483. package/dist/src/ui/components/ThemeDialog.js.map +1 -1
  484. package/dist/src/ui/components/ThemeDialog.test.d.ts +6 -0
  485. package/dist/src/ui/components/ThemeDialog.test.js +75 -0
  486. package/dist/src/ui/components/ThemeDialog.test.js.map +1 -0
  487. package/dist/src/ui/components/Tips.js +2 -2
  488. package/dist/src/ui/components/Tips.js.map +1 -1
  489. package/dist/src/ui/components/ToolStatsDisplay.js +5 -4
  490. package/dist/src/ui/components/ToolStatsDisplay.js.map +1 -1
  491. package/dist/src/ui/components/UpdateNotification.js +2 -2
  492. package/dist/src/ui/components/UpdateNotification.js.map +1 -1
  493. package/dist/src/ui/components/WelcomeBackDialog.js +15 -4
  494. package/dist/src/ui/components/WelcomeBackDialog.js.map +1 -1
  495. package/dist/src/ui/components/WorkspaceMigrationDialog.js +14 -11
  496. package/dist/src/ui/components/WorkspaceMigrationDialog.js.map +1 -1
  497. package/dist/src/ui/components/messages/CompressionMessage.d.ts +1 -2
  498. package/dist/src/ui/components/messages/CompressionMessage.js +41 -8
  499. package/dist/src/ui/components/messages/CompressionMessage.js.map +1 -1
  500. package/dist/src/ui/components/messages/CompressionMessage.test.d.ts +6 -0
  501. package/dist/src/ui/components/messages/CompressionMessage.test.js +160 -0
  502. package/dist/src/ui/components/messages/CompressionMessage.test.js.map +1 -0
  503. package/dist/src/ui/components/messages/DiffRenderer.d.ts +2 -1
  504. package/dist/src/ui/components/messages/DiffRenderer.js +14 -22
  505. package/dist/src/ui/components/messages/DiffRenderer.js.map +1 -1
  506. package/dist/src/ui/components/messages/ErrorMessage.js +2 -2
  507. package/dist/src/ui/components/messages/ErrorMessage.js.map +1 -1
  508. package/dist/src/ui/components/messages/GeminiMessage.js +2 -2
  509. package/dist/src/ui/components/messages/GeminiMessage.js.map +1 -1
  510. package/dist/src/ui/components/messages/InfoMessage.js +2 -2
  511. package/dist/src/ui/components/messages/InfoMessage.js.map +1 -1
  512. package/dist/src/ui/components/messages/ToolConfirmationMessage.js +91 -45
  513. package/dist/src/ui/components/messages/ToolConfirmationMessage.js.map +1 -1
  514. package/dist/src/ui/components/messages/ToolConfirmationMessage.test.js +36 -8
  515. package/dist/src/ui/components/messages/ToolConfirmationMessage.test.js.map +1 -1
  516. package/dist/src/ui/components/messages/ToolGroupMessage.d.ts +3 -2
  517. package/dist/src/ui/components/messages/ToolGroupMessage.js +18 -10
  518. package/dist/src/ui/components/messages/ToolGroupMessage.js.map +1 -1
  519. package/dist/src/ui/components/messages/ToolGroupMessage.test.js +17 -15
  520. package/dist/src/ui/components/messages/ToolGroupMessage.test.js.map +1 -1
  521. package/dist/src/ui/components/messages/ToolMessage.d.ts +3 -1
  522. package/dist/src/ui/components/messages/ToolMessage.js +53 -11
  523. package/dist/src/ui/components/messages/ToolMessage.js.map +1 -1
  524. package/dist/src/ui/components/messages/ToolMessage.test.js +34 -1
  525. package/dist/src/ui/components/messages/ToolMessage.test.js.map +1 -1
  526. package/dist/src/ui/components/messages/UserMessage.js +3 -4
  527. package/dist/src/ui/components/messages/UserMessage.js.map +1 -1
  528. package/dist/src/ui/components/messages/UserShellMessage.js +2 -2
  529. package/dist/src/ui/components/messages/UserShellMessage.js.map +1 -1
  530. package/dist/src/ui/components/messages/WarningMessage.d.ts +11 -0
  531. package/dist/src/ui/components/messages/WarningMessage.js +10 -0
  532. package/dist/src/ui/components/messages/WarningMessage.js.map +1 -0
  533. package/dist/src/ui/components/shared/BaseSelectionList.d.ts +38 -0
  534. package/dist/src/ui/components/shared/BaseSelectionList.js +72 -0
  535. package/dist/src/ui/components/shared/BaseSelectionList.js.map +1 -0
  536. package/dist/src/ui/components/shared/BaseSelectionList.test.d.ts +6 -0
  537. package/dist/src/ui/components/shared/BaseSelectionList.test.js +376 -0
  538. package/dist/src/ui/components/shared/BaseSelectionList.test.js.map +1 -0
  539. package/dist/src/ui/components/shared/DescriptiveRadioButtonSelect.d.ts +35 -0
  540. package/dist/src/ui/components/shared/DescriptiveRadioButtonSelect.js +13 -0
  541. package/dist/src/ui/components/shared/DescriptiveRadioButtonSelect.js.map +1 -0
  542. package/dist/src/ui/components/shared/DescriptiveRadioButtonSelect.test.d.ts +6 -0
  543. package/dist/src/ui/components/shared/DescriptiveRadioButtonSelect.test.js +79 -0
  544. package/dist/src/ui/components/shared/DescriptiveRadioButtonSelect.test.js.map +1 -0
  545. package/dist/src/ui/components/shared/EnumSelector.d.ts +18 -0
  546. package/dist/src/ui/components/shared/EnumSelector.js +44 -0
  547. package/dist/src/ui/components/shared/EnumSelector.js.map +1 -0
  548. package/dist/src/ui/components/shared/EnumSelector.test.d.ts +6 -0
  549. package/dist/src/ui/components/shared/EnumSelector.test.js +70 -0
  550. package/dist/src/ui/components/shared/EnumSelector.test.js.map +1 -0
  551. package/dist/src/ui/components/shared/MaxSizedBox.js +2 -2
  552. package/dist/src/ui/components/shared/MaxSizedBox.js.map +1 -1
  553. package/dist/src/ui/components/shared/RadioButtonSelect.d.ts +2 -3
  554. package/dist/src/ui/components/shared/RadioButtonSelect.js +10 -105
  555. package/dist/src/ui/components/shared/RadioButtonSelect.js.map +1 -1
  556. package/dist/src/ui/components/shared/RadioButtonSelect.test.js +115 -92
  557. package/dist/src/ui/components/shared/RadioButtonSelect.test.js.map +1 -1
  558. package/dist/src/ui/components/shared/ScopeSelector.d.ts +19 -0
  559. package/dist/src/ui/components/shared/ScopeSelector.js +16 -0
  560. package/dist/src/ui/components/shared/ScopeSelector.js.map +1 -0
  561. package/dist/src/ui/components/shared/text-buffer.d.ts +25 -2
  562. package/dist/src/ui/components/shared/text-buffer.js +296 -187
  563. package/dist/src/ui/components/shared/text-buffer.js.map +1 -1
  564. package/dist/src/ui/components/subagents/create/AgentCreationWizard.js +41 -29
  565. package/dist/src/ui/components/subagents/create/AgentCreationWizard.js.map +1 -1
  566. package/dist/src/ui/components/subagents/create/ColorSelector.js +3 -2
  567. package/dist/src/ui/components/subagents/create/ColorSelector.js.map +1 -1
  568. package/dist/src/ui/components/subagents/create/CreationSummary.js +26 -15
  569. package/dist/src/ui/components/subagents/create/CreationSummary.js.map +1 -1
  570. package/dist/src/ui/components/subagents/create/DescriptionInput.js +7 -5
  571. package/dist/src/ui/components/subagents/create/DescriptionInput.js.map +1 -1
  572. package/dist/src/ui/components/subagents/create/GenerationMethodSelector.js +8 -2
  573. package/dist/src/ui/components/subagents/create/GenerationMethodSelector.js.map +1 -1
  574. package/dist/src/ui/components/subagents/create/LocationSelector.js +8 -2
  575. package/dist/src/ui/components/subagents/create/LocationSelector.js.map +1 -1
  576. package/dist/src/ui/components/subagents/create/TextEntryStep.js +2 -2
  577. package/dist/src/ui/components/subagents/create/TextEntryStep.js.map +1 -1
  578. package/dist/src/ui/components/subagents/create/ToolSelector.js +10 -8
  579. package/dist/src/ui/components/subagents/create/ToolSelector.js.map +1 -1
  580. package/dist/src/ui/components/subagents/manage/ActionSelectionStep.js +29 -4
  581. package/dist/src/ui/components/subagents/manage/ActionSelectionStep.js.map +1 -1
  582. package/dist/src/ui/components/subagents/manage/AgentDeleteStep.js +6 -3
  583. package/dist/src/ui/components/subagents/manage/AgentDeleteStep.js.map +1 -1
  584. package/dist/src/ui/components/subagents/manage/AgentEditStep.js +15 -5
  585. package/dist/src/ui/components/subagents/manage/AgentEditStep.js.map +1 -1
  586. package/dist/src/ui/components/subagents/manage/AgentSelectionStep.js +13 -7
  587. package/dist/src/ui/components/subagents/manage/AgentSelectionStep.js.map +1 -1
  588. package/dist/src/ui/components/subagents/manage/AgentViewerStep.js +3 -2
  589. package/dist/src/ui/components/subagents/manage/AgentViewerStep.js.map +1 -1
  590. package/dist/src/ui/components/subagents/manage/AgentsManagerDialog.js +15 -15
  591. package/dist/src/ui/components/subagents/manage/AgentsManagerDialog.js.map +1 -1
  592. package/dist/src/ui/components/subagents/runtime/AgentExecutionDisplay.js +16 -17
  593. package/dist/src/ui/components/subagents/runtime/AgentExecutionDisplay.js.map +1 -1
  594. package/dist/src/ui/components/ums/UMSKeyPrompt.d.ts +2 -2
  595. package/dist/src/ui/components/ums/UMSKeyPrompt.js +66 -64
  596. package/dist/src/ui/components/ums/UMSKeyPrompt.js.map +1 -1
  597. package/dist/src/ui/components/views/ExtensionsList.d.ts +6 -0
  598. package/dist/src/ui/components/views/ExtensionsList.js +47 -0
  599. package/dist/src/ui/components/views/ExtensionsList.js.map +1 -0
  600. package/dist/src/ui/components/views/ExtensionsList.test.d.ts +6 -0
  601. package/dist/src/ui/components/views/ExtensionsList.test.js +97 -0
  602. package/dist/src/ui/components/views/ExtensionsList.test.js.map +1 -0
  603. package/dist/src/ui/components/views/McpStatus.d.ts +27 -0
  604. package/dist/src/ui/components/views/McpStatus.js +90 -0
  605. package/dist/src/ui/components/views/McpStatus.js.map +1 -0
  606. package/dist/src/ui/components/views/McpStatus.test.d.ts +6 -0
  607. package/dist/src/ui/components/views/McpStatus.test.js +117 -0
  608. package/dist/src/ui/components/views/McpStatus.test.js.map +1 -0
  609. package/dist/src/ui/components/views/ToolsList.d.ts +14 -0
  610. package/dist/src/ui/components/views/ToolsList.js +8 -0
  611. package/dist/src/ui/components/views/ToolsList.js.map +1 -0
  612. package/dist/src/ui/components/views/ToolsList.test.d.ts +6 -0
  613. package/dist/src/ui/components/views/ToolsList.test.js +45 -0
  614. package/dist/src/ui/components/views/ToolsList.test.js.map +1 -0
  615. package/dist/src/ui/constants.d.ts +1 -0
  616. package/dist/src/ui/constants.js +1 -0
  617. package/dist/src/ui/constants.js.map +1 -1
  618. package/dist/src/ui/contexts/AppContext.d.ts +11 -0
  619. package/dist/src/ui/contexts/AppContext.js +15 -0
  620. package/dist/src/ui/contexts/AppContext.js.map +1 -0
  621. package/dist/src/ui/contexts/ConfigContext.d.ts +9 -0
  622. package/dist/src/ui/contexts/ConfigContext.js +16 -0
  623. package/dist/src/ui/contexts/ConfigContext.js.map +1 -0
  624. package/dist/src/ui/contexts/KeypressContext.d.ts +3 -0
  625. package/dist/src/ui/contexts/KeypressContext.js +309 -44
  626. package/dist/src/ui/contexts/KeypressContext.js.map +1 -1
  627. package/dist/src/ui/contexts/KeypressContext.test.js +288 -2
  628. package/dist/src/ui/contexts/KeypressContext.test.js.map +1 -1
  629. package/dist/src/ui/contexts/SessionContext.d.ts +6 -0
  630. package/dist/src/ui/contexts/SessionContext.js +107 -5
  631. package/dist/src/ui/contexts/SessionContext.js.map +1 -1
  632. package/dist/src/ui/contexts/ShellFocusContext.d.ts +7 -0
  633. package/dist/src/ui/contexts/ShellFocusContext.js +9 -0
  634. package/dist/src/ui/contexts/ShellFocusContext.js.map +1 -0
  635. package/dist/src/ui/contexts/UIActionsContext.d.ts +46 -0
  636. package/dist/src/ui/contexts/UIActionsContext.js +22 -0
  637. package/dist/src/ui/contexts/UIActionsContext.js.map +1 -0
  638. package/dist/src/ui/contexts/UIStateContext.d.ts +115 -0
  639. package/dist/src/ui/contexts/UIStateContext.js +17 -0
  640. package/dist/src/ui/contexts/UIStateContext.js.map +1 -0
  641. package/dist/src/ui/editors/editorSettingsManager.js +1 -0
  642. package/dist/src/ui/editors/editorSettingsManager.js.map +1 -1
  643. package/dist/src/ui/hooks/atCommandProcessor.js +12 -12
  644. package/dist/src/ui/hooks/atCommandProcessor.js.map +1 -1
  645. package/dist/src/ui/hooks/atCommandProcessor.test.js +23 -19
  646. package/dist/src/ui/hooks/atCommandProcessor.test.js.map +1 -1
  647. package/dist/src/ui/hooks/keyToAnsi.d.ts +15 -0
  648. package/dist/src/ui/hooks/keyToAnsi.js +67 -0
  649. package/dist/src/ui/hooks/keyToAnsi.js.map +1 -0
  650. package/dist/src/ui/hooks/shellCommandProcessor.d.ts +2 -1
  651. package/dist/src/ui/hooks/shellCommandProcessor.js +65 -15
  652. package/dist/src/ui/hooks/shellCommandProcessor.js.map +1 -1
  653. package/dist/src/ui/hooks/shellCommandProcessor.test.js +196 -17
  654. package/dist/src/ui/hooks/shellCommandProcessor.test.js.map +1 -1
  655. package/dist/src/ui/hooks/slashCommandProcessor.d.ts +21 -3
  656. package/dist/src/ui/hooks/slashCommandProcessor.js +52 -97
  657. package/dist/src/ui/hooks/slashCommandProcessor.js.map +1 -1
  658. package/dist/src/ui/hooks/useApprovalModeCommand.d.ts +14 -0
  659. package/dist/src/ui/hooks/useApprovalModeCommand.js +33 -0
  660. package/dist/src/ui/hooks/useApprovalModeCommand.js.map +1 -0
  661. package/dist/src/ui/hooks/useAtCompletion.js +1 -1
  662. package/dist/src/ui/hooks/useAtCompletion.js.map +1 -1
  663. package/dist/src/ui/hooks/useAttentionNotifications.d.ts +14 -0
  664. package/dist/src/ui/hooks/useAttentionNotifications.js +41 -0
  665. package/dist/src/ui/hooks/useAttentionNotifications.js.map +1 -0
  666. package/dist/src/ui/hooks/useAttentionNotifications.test.js +113 -0
  667. package/dist/src/ui/hooks/useAttentionNotifications.test.js.map +1 -0
  668. package/dist/src/ui/hooks/useAutoAcceptIndicator.d.ts +3 -2
  669. package/dist/src/ui/hooks/useAutoAcceptIndicator.js +20 -18
  670. package/dist/src/ui/hooks/useAutoAcceptIndicator.js.map +1 -1
  671. package/dist/src/ui/hooks/useAutoAcceptIndicator.test.js +43 -0
  672. package/dist/src/ui/hooks/useAutoAcceptIndicator.test.js.map +1 -1
  673. package/dist/src/ui/hooks/useCommandCompletion.d.ts +1 -4
  674. package/dist/src/ui/hooks/useCommandCompletion.js +1 -23
  675. package/dist/src/ui/hooks/useCommandCompletion.js.map +1 -1
  676. package/dist/src/ui/hooks/useDialogClose.d.ts +6 -5
  677. package/dist/src/ui/hooks/useDialogClose.js +3 -12
  678. package/dist/src/ui/hooks/useDialogClose.js.map +1 -1
  679. package/dist/src/ui/hooks/useEditorSettings.js +1 -1
  680. package/dist/src/ui/hooks/useEditorSettings.js.map +1 -1
  681. package/dist/src/ui/hooks/useEditorSettings.test.js +4 -4
  682. package/dist/src/ui/hooks/useEditorSettings.test.js.map +1 -1
  683. package/dist/src/ui/hooks/useExtensionUpdates.d.ts +21 -0
  684. package/dist/src/ui/hooks/useExtensionUpdates.js +116 -0
  685. package/dist/src/ui/hooks/useExtensionUpdates.js.map +1 -0
  686. package/dist/src/ui/hooks/useExtensionUpdates.test.d.ts +6 -0
  687. package/dist/src/ui/hooks/useExtensionUpdates.test.js +243 -0
  688. package/dist/src/ui/hooks/useExtensionUpdates.test.js.map +1 -0
  689. package/dist/src/ui/hooks/useFocus.js +10 -0
  690. package/dist/src/ui/hooks/useFocus.js.map +1 -1
  691. package/dist/src/ui/hooks/useFolderTrust.js +6 -10
  692. package/dist/src/ui/hooks/useFolderTrust.js.map +1 -1
  693. package/dist/src/ui/hooks/useGeminiStream.d.ts +14 -3
  694. package/dist/src/ui/hooks/useGeminiStream.js +184 -83
  695. package/dist/src/ui/hooks/useGeminiStream.js.map +1 -1
  696. package/dist/src/ui/hooks/useGitBranchName.js +18 -18
  697. package/dist/src/ui/hooks/useGitBranchName.js.map +1 -1
  698. package/dist/src/ui/hooks/useGitBranchName.test.js +66 -52
  699. package/dist/src/ui/hooks/useGitBranchName.test.js.map +1 -1
  700. package/dist/src/ui/hooks/useIdeTrustListener.d.ts +16 -0
  701. package/dist/src/ui/hooks/useIdeTrustListener.js +65 -0
  702. package/dist/src/ui/hooks/useIdeTrustListener.js.map +1 -0
  703. package/dist/src/ui/hooks/useIdeTrustListener.test.d.ts +6 -0
  704. package/dist/src/ui/hooks/useIdeTrustListener.test.js +183 -0
  705. package/dist/src/ui/hooks/useIdeTrustListener.test.js.map +1 -0
  706. package/dist/src/ui/hooks/useInitializationAuthError.d.ts +22 -0
  707. package/dist/src/ui/hooks/useInitializationAuthError.js +40 -0
  708. package/dist/src/ui/hooks/useInitializationAuthError.js.map +1 -0
  709. package/dist/src/ui/hooks/useInputHistoryStore.d.ts +19 -0
  710. package/dist/src/ui/hooks/useInputHistoryStore.js +81 -0
  711. package/dist/src/ui/hooks/useInputHistoryStore.js.map +1 -0
  712. package/dist/src/ui/hooks/useInputHistoryStore.test.d.ts +6 -0
  713. package/dist/src/ui/hooks/useInputHistoryStore.test.js +234 -0
  714. package/dist/src/ui/hooks/useInputHistoryStore.test.js.map +1 -0
  715. package/dist/src/ui/hooks/useLoadingIndicator.d.ts +1 -1
  716. package/dist/src/ui/hooks/useLoadingIndicator.js +2 -2
  717. package/dist/src/ui/hooks/useLoadingIndicator.js.map +1 -1
  718. package/dist/src/ui/hooks/useLoadingIndicator.test.js +2 -2
  719. package/dist/src/ui/hooks/useLoadingIndicator.test.js.map +1 -1
  720. package/dist/src/ui/hooks/useMemoryMonitor.d.ts +13 -0
  721. package/dist/src/ui/hooks/useMemoryMonitor.js +28 -0
  722. package/dist/src/ui/hooks/useMemoryMonitor.js.map +1 -0
  723. package/dist/src/ui/hooks/useMemoryMonitor.test.d.ts +6 -0
  724. package/dist/src/ui/hooks/useMemoryMonitor.test.js +57 -0
  725. package/dist/src/ui/hooks/useMemoryMonitor.test.js.map +1 -0
  726. package/dist/src/ui/hooks/useMessageQueue.d.ts +2 -1
  727. package/dist/src/ui/hooks/useMessageQueue.js +5 -3
  728. package/dist/src/ui/hooks/useMessageQueue.js.map +1 -1
  729. package/dist/src/ui/hooks/useMessageQueue.test.js +9 -0
  730. package/dist/src/ui/hooks/useMessageQueue.test.js.map +1 -1
  731. package/dist/src/ui/hooks/useModelCommand.d.ts +12 -0
  732. package/dist/src/ui/hooks/useModelCommand.js +21 -0
  733. package/dist/src/ui/hooks/useModelCommand.js.map +1 -0
  734. package/dist/src/ui/hooks/useModelCommand.test.d.ts +6 -0
  735. package/dist/src/ui/hooks/useModelCommand.test.js +35 -0
  736. package/dist/src/ui/hooks/useModelCommand.test.js.map +1 -0
  737. package/dist/src/ui/hooks/usePermissionsModifyTrust.d.ts +17 -0
  738. package/dist/src/ui/hooks/usePermissionsModifyTrust.js +78 -0
  739. package/dist/src/ui/hooks/usePermissionsModifyTrust.js.map +1 -0
  740. package/dist/src/ui/hooks/usePermissionsModifyTrust.test.d.ts +6 -0
  741. package/dist/src/ui/hooks/usePermissionsModifyTrust.test.js +182 -0
  742. package/dist/src/ui/hooks/usePermissionsModifyTrust.test.js.map +1 -0
  743. package/dist/src/ui/hooks/usePhraseCycler.d.ts +1 -1
  744. package/dist/src/ui/hooks/usePhraseCycler.js +15 -10
  745. package/dist/src/ui/hooks/usePhraseCycler.js.map +1 -1
  746. package/dist/src/ui/hooks/useQuotaAndFallback.d.ts +21 -0
  747. package/dist/src/ui/hooks/useQuotaAndFallback.js +122 -0
  748. package/dist/src/ui/hooks/useQuotaAndFallback.js.map +1 -0
  749. package/dist/src/ui/hooks/useQuotaAndFallback.test.d.ts +6 -0
  750. package/dist/src/ui/hooks/useQuotaAndFallback.test.js +269 -0
  751. package/dist/src/ui/hooks/useQuotaAndFallback.test.js.map +1 -0
  752. package/dist/src/ui/hooks/useQwenAuth.d.ts +7 -12
  753. package/dist/src/ui/hooks/useQwenAuth.js +4 -8
  754. package/dist/src/ui/hooks/useQwenAuth.js.map +1 -1
  755. package/dist/src/ui/hooks/useQwenAuth.test.js +72 -98
  756. package/dist/src/ui/hooks/useQwenAuth.test.js.map +1 -1
  757. package/dist/src/ui/hooks/useReactToolScheduler.d.ts +3 -2
  758. package/dist/src/ui/hooks/useReactToolScheduler.js +23 -17
  759. package/dist/src/ui/hooks/useReactToolScheduler.js.map +1 -1
  760. package/dist/src/ui/hooks/useReverseSearchCompletion.d.ts +1 -1
  761. package/dist/src/ui/hooks/useReverseSearchCompletion.js +67 -20
  762. package/dist/src/ui/hooks/useReverseSearchCompletion.js.map +1 -1
  763. package/dist/src/ui/hooks/useSelectionList.d.ts +34 -0
  764. package/dist/src/ui/hooks/useSelectionList.js +245 -0
  765. package/dist/src/ui/hooks/useSelectionList.js.map +1 -0
  766. package/dist/src/ui/hooks/useSelectionList.test.d.ts +6 -0
  767. package/dist/src/ui/hooks/useSelectionList.test.js +701 -0
  768. package/dist/src/ui/hooks/useSelectionList.test.js.map +1 -0
  769. package/dist/src/ui/hooks/useSlashCompletion.d.ts +1 -1
  770. package/dist/src/ui/hooks/useSlashCompletion.js +281 -67
  771. package/dist/src/ui/hooks/useSlashCompletion.js.map +1 -1
  772. package/dist/src/ui/hooks/useSlashCompletion.test.d.ts +4 -1
  773. package/dist/src/ui/hooks/useSlashCompletion.test.js +390 -65
  774. package/dist/src/ui/hooks/useSlashCompletion.test.js.map +1 -1
  775. package/dist/src/ui/hooks/useStateAndRef.d.ts +1 -1
  776. package/dist/src/ui/hooks/useStateAndRef.js +2 -2
  777. package/dist/src/ui/hooks/useStateAndRef.js.map +1 -1
  778. package/dist/src/ui/hooks/useThemeCommand.d.ts +1 -1
  779. package/dist/src/ui/hooks/useThemeCommand.js +11 -17
  780. package/dist/src/ui/hooks/useThemeCommand.js.map +1 -1
  781. package/dist/src/ui/hooks/useToolScheduler.test.js +64 -291
  782. package/dist/src/ui/hooks/useToolScheduler.test.js.map +1 -1
  783. package/dist/src/ui/hooks/useVisionAutoSwitch.d.ts +1 -1
  784. package/dist/src/ui/hooks/useVisionAutoSwitch.js +36 -6
  785. package/dist/src/ui/hooks/useVisionAutoSwitch.js.map +1 -1
  786. package/dist/src/ui/hooks/useVisionAutoSwitch.test.js +3 -3
  787. package/dist/src/ui/hooks/useVisionAutoSwitch.test.js.map +1 -1
  788. package/dist/src/ui/hooks/useWelcomeBack.js +2 -2
  789. package/dist/src/ui/hooks/useWelcomeBack.js.map +1 -1
  790. package/dist/src/ui/hooks/useWorkspaceMigration.js +2 -1
  791. package/dist/src/ui/hooks/useWorkspaceMigration.js.map +1 -1
  792. package/dist/src/ui/keyMatchers.test.js +17 -0
  793. package/dist/src/ui/keyMatchers.test.js.map +1 -1
  794. package/dist/src/ui/layouts/DefaultAppLayout.d.ts +9 -0
  795. package/dist/src/ui/layouts/DefaultAppLayout.js +13 -0
  796. package/dist/src/ui/layouts/DefaultAppLayout.js.map +1 -0
  797. package/dist/src/ui/layouts/ScreenReaderAppLayout.d.ts +7 -0
  798. package/dist/src/ui/layouts/ScreenReaderAppLayout.js +14 -0
  799. package/dist/src/ui/layouts/ScreenReaderAppLayout.js.map +1 -0
  800. package/dist/src/ui/models/availableModels.d.ts +11 -5
  801. package/dist/src/ui/models/availableModels.js +94 -3
  802. package/dist/src/ui/models/availableModels.js.map +1 -1
  803. package/dist/src/ui/noninteractive/nonInteractiveUi.d.ts +12 -0
  804. package/dist/src/ui/noninteractive/nonInteractiveUi.js +28 -0
  805. package/dist/src/ui/noninteractive/nonInteractiveUi.js.map +1 -0
  806. package/dist/src/ui/state/extensions.d.ts +42 -0
  807. package/dist/src/ui/state/extensions.js +62 -0
  808. package/dist/src/ui/state/extensions.js.map +1 -0
  809. package/dist/src/ui/themes/ayu.js +1 -1
  810. package/dist/src/ui/themes/dracula.js +2 -2
  811. package/dist/src/ui/themes/github-dark.js +1 -1
  812. package/dist/src/ui/themes/theme.js +19 -19
  813. package/dist/src/ui/themes/theme.js.map +1 -1
  814. package/dist/src/ui/types.d.ts +111 -17
  815. package/dist/src/ui/types.js +14 -0
  816. package/dist/src/ui/types.js.map +1 -1
  817. package/dist/src/ui/utils/CodeColorizer.js +3 -2
  818. package/dist/src/ui/utils/CodeColorizer.js.map +1 -1
  819. package/dist/src/ui/utils/InlineMarkdownRenderer.js +7 -7
  820. package/dist/src/ui/utils/InlineMarkdownRenderer.js.map +1 -1
  821. package/dist/src/ui/utils/MarkdownDisplay.js +11 -11
  822. package/dist/src/ui/utils/MarkdownDisplay.js.map +1 -1
  823. package/dist/src/ui/utils/MarkdownDisplay.test.js +95 -87
  824. package/dist/src/ui/utils/MarkdownDisplay.test.js.map +1 -1
  825. package/dist/src/ui/utils/TableRenderer.js +4 -4
  826. package/dist/src/ui/utils/TableRenderer.js.map +1 -1
  827. package/dist/src/ui/utils/clipboardUtils.js +5 -6
  828. package/dist/src/ui/utils/clipboardUtils.js.map +1 -1
  829. package/dist/src/ui/utils/commandUtils.d.ts +16 -0
  830. package/dist/src/ui/utils/commandUtils.js +16 -1
  831. package/dist/src/ui/utils/commandUtils.js.map +1 -1
  832. package/dist/src/ui/utils/commandUtils.test.js +5 -2
  833. package/dist/src/ui/utils/commandUtils.test.js.map +1 -1
  834. package/dist/src/ui/utils/displayUtils.d.ts +1 -0
  835. package/dist/src/ui/utils/displayUtils.js +7 -4
  836. package/dist/src/ui/utils/displayUtils.js.map +1 -1
  837. package/dist/src/ui/utils/displayUtils.test.js +37 -18
  838. package/dist/src/ui/utils/displayUtils.test.js.map +1 -1
  839. package/dist/src/ui/utils/highlight.d.ts +11 -0
  840. package/dist/src/ui/utils/highlight.js +78 -0
  841. package/dist/src/ui/utils/highlight.js.map +1 -0
  842. package/dist/src/ui/utils/highlight.test.d.ts +6 -0
  843. package/dist/src/ui/utils/highlight.test.js +120 -0
  844. package/dist/src/ui/utils/highlight.test.js.map +1 -0
  845. package/dist/src/ui/utils/kittyProtocolDetector.js +39 -29
  846. package/dist/src/ui/utils/kittyProtocolDetector.js.map +1 -1
  847. package/dist/src/ui/utils/platformConstants.d.ts +24 -1
  848. package/dist/src/ui/utils/platformConstants.js +26 -1
  849. package/dist/src/ui/utils/platformConstants.js.map +1 -1
  850. package/dist/src/ui/utils/terminalSetup.js +45 -18
  851. package/dist/src/ui/utils/terminalSetup.js.map +1 -1
  852. package/dist/src/ui/utils/textUtils.d.ts +10 -0
  853. package/dist/src/ui/utils/textUtils.js +108 -3
  854. package/dist/src/ui/utils/textUtils.js.map +1 -1
  855. package/dist/src/ui/utils/textUtils.test.d.ts +6 -0
  856. package/dist/src/ui/utils/textUtils.test.js +132 -0
  857. package/dist/src/ui/utils/textUtils.test.js.map +1 -0
  858. package/dist/src/ui/utils/updateCheck.d.ts +1 -0
  859. package/dist/src/ui/utils/updateCheck.js +53 -2
  860. package/dist/src/ui/utils/updateCheck.js.map +1 -1
  861. package/dist/src/utils/attentionNotification.d.ts +20 -0
  862. package/dist/src/utils/attentionNotification.js +34 -0
  863. package/dist/src/utils/attentionNotification.js.map +1 -0
  864. package/dist/src/utils/attentionNotification.test.d.ts +6 -0
  865. package/dist/src/utils/attentionNotification.test.js +46 -0
  866. package/dist/src/utils/attentionNotification.test.js.map +1 -0
  867. package/dist/src/utils/commands.d.ts +20 -0
  868. package/dist/src/utils/commands.js +53 -0
  869. package/dist/src/utils/commands.js.map +1 -0
  870. package/dist/src/utils/commands.test.d.ts +6 -0
  871. package/dist/src/utils/commands.test.js +115 -0
  872. package/dist/src/utils/commands.test.js.map +1 -0
  873. package/dist/src/utils/commentJson.d.ts +9 -0
  874. package/dist/src/utils/commentJson.js +48 -0
  875. package/dist/src/utils/commentJson.js.map +1 -0
  876. package/dist/src/utils/commentJson.test.d.ts +6 -0
  877. package/dist/src/utils/commentJson.test.js +146 -0
  878. package/dist/src/utils/commentJson.test.js.map +1 -0
  879. package/dist/src/utils/deepMerge.d.ts +9 -0
  880. package/dist/src/utils/deepMerge.js +58 -0
  881. package/dist/src/utils/deepMerge.js.map +1 -0
  882. package/dist/src/utils/deepMerge.test.d.ts +6 -0
  883. package/dist/src/utils/deepMerge.test.js +143 -0
  884. package/dist/src/utils/deepMerge.test.js.map +1 -0
  885. package/dist/src/utils/dialogScopeUtils.d.ts +0 -4
  886. package/dist/src/utils/dialogScopeUtils.js +5 -2
  887. package/dist/src/utils/dialogScopeUtils.js.map +1 -1
  888. package/dist/src/utils/envVarResolver.d.ts +39 -0
  889. package/dist/src/utils/envVarResolver.js +97 -0
  890. package/dist/src/utils/envVarResolver.js.map +1 -0
  891. package/dist/src/utils/envVarResolver.test.d.ts +6 -0
  892. package/dist/src/utils/envVarResolver.test.js +221 -0
  893. package/dist/src/utils/envVarResolver.test.js.map +1 -0
  894. package/dist/src/utils/errors.d.ts +29 -0
  895. package/dist/src/utils/errors.js +94 -0
  896. package/dist/src/utils/errors.js.map +1 -1
  897. package/dist/src/utils/errors.test.d.ts +6 -0
  898. package/dist/src/utils/errors.test.js +340 -0
  899. package/dist/src/utils/errors.test.js.map +1 -0
  900. package/dist/src/utils/events.d.ts +2 -1
  901. package/dist/src/utils/events.js +1 -0
  902. package/dist/src/utils/events.js.map +1 -1
  903. package/dist/src/utils/handleAutoUpdate.js +6 -3
  904. package/dist/src/utils/handleAutoUpdate.js.map +1 -1
  905. package/dist/src/utils/math.d.ts +13 -0
  906. package/dist/src/utils/math.js +14 -0
  907. package/dist/src/utils/math.js.map +1 -0
  908. package/dist/src/utils/nonInteractiveHelpers.d.ts +88 -0
  909. package/dist/src/utils/nonInteractiveHelpers.js +470 -0
  910. package/dist/src/utils/nonInteractiveHelpers.js.map +1 -0
  911. package/dist/src/utils/nonInteractiveHelpers.test.d.ts +6 -0
  912. package/dist/src/utils/nonInteractiveHelpers.test.js +945 -0
  913. package/dist/src/utils/nonInteractiveHelpers.test.js.map +1 -0
  914. package/dist/src/utils/processUtils.d.ts +13 -0
  915. package/dist/src/utils/processUtils.js +18 -0
  916. package/dist/src/utils/processUtils.js.map +1 -0
  917. package/dist/src/utils/processUtils.test.d.ts +6 -0
  918. package/dist/src/utils/processUtils.test.js +20 -0
  919. package/dist/src/utils/processUtils.test.js.map +1 -0
  920. package/dist/src/utils/relaunch.d.ts +7 -0
  921. package/dist/src/utils/relaunch.js +57 -0
  922. package/dist/src/utils/relaunch.js.map +1 -0
  923. package/dist/src/utils/relaunch.test.d.ts +6 -0
  924. package/dist/src/utils/relaunch.test.js +273 -0
  925. package/dist/src/utils/relaunch.test.js.map +1 -0
  926. package/dist/src/utils/sandbox.d.ts +1 -1
  927. package/dist/src/utils/sandbox.js +43 -18
  928. package/dist/src/utils/sandbox.js.map +1 -1
  929. package/dist/src/utils/settingsUtils.d.ts +16 -6
  930. package/dist/src/utils/settingsUtils.js +41 -25
  931. package/dist/src/utils/settingsUtils.js.map +1 -1
  932. package/dist/src/utils/settingsUtils.test.js +455 -158
  933. package/dist/src/utils/settingsUtils.test.js.map +1 -1
  934. package/dist/src/utils/startupWarnings.js +1 -1
  935. package/dist/src/utils/startupWarnings.js.map +1 -1
  936. package/dist/src/utils/systemInfo.d.ts +66 -0
  937. package/dist/src/utils/systemInfo.js +125 -0
  938. package/dist/src/utils/systemInfo.js.map +1 -0
  939. package/dist/src/utils/systemInfo.test.d.ts +6 -0
  940. package/dist/src/utils/systemInfo.test.js +259 -0
  941. package/dist/src/utils/systemInfo.test.js.map +1 -0
  942. package/dist/src/utils/systemInfoFields.d.ts +22 -0
  943. package/dist/src/utils/systemInfoFields.js +96 -0
  944. package/dist/src/utils/systemInfoFields.js.map +1 -0
  945. package/dist/src/utils/userStartupWarnings.d.ts +7 -1
  946. package/dist/src/utils/userStartupWarnings.js +26 -6
  947. package/dist/src/utils/userStartupWarnings.js.map +1 -1
  948. package/dist/src/utils/userStartupWarnings.test.js +26 -5
  949. package/dist/src/utils/userStartupWarnings.test.js.map +1 -1
  950. package/dist/src/utils/windowTitle.d.ts +12 -0
  951. package/dist/src/utils/windowTitle.js +19 -0
  952. package/dist/src/utils/windowTitle.js.map +1 -0
  953. package/dist/src/utils/windowTitle.test.d.ts +6 -0
  954. package/dist/src/utils/windowTitle.test.js +49 -0
  955. package/dist/src/utils/windowTitle.test.js.map +1 -0
  956. package/dist/src/validateNonInterActiveAuth.d.ts +4 -2
  957. package/dist/src/validateNonInterActiveAuth.js +57 -21
  958. package/dist/src/validateNonInterActiveAuth.js.map +1 -1
  959. package/dist/src/zed-integration/acp.js +1 -2
  960. package/dist/src/zed-integration/acp.js.map +1 -1
  961. package/dist/src/zed-integration/fileSystemService.d.ts +1 -0
  962. package/dist/src/zed-integration/fileSystemService.js +3 -0
  963. package/dist/src/zed-integration/fileSystemService.js.map +1 -1
  964. package/dist/src/zed-integration/schema.d.ts +608 -366
  965. package/dist/src/zed-integration/schema.js +13 -0
  966. package/dist/src/zed-integration/schema.js.map +1 -1
  967. package/dist/src/zed-integration/zedIntegration.d.ts +8 -1
  968. package/dist/src/zed-integration/zedIntegration.js +409 -61
  969. package/dist/src/zed-integration/zedIntegration.js.map +1 -1
  970. package/dist/tsconfig.tsbuildinfo +1 -1
  971. package/package.json +25 -12
  972. package/dist/src/ui/commands/privacyCommand.js +0 -16
  973. package/dist/src/ui/commands/privacyCommand.js.map +0 -1
  974. package/dist/src/ui/components/AuthDialog.d.ts +0 -15
  975. package/dist/src/ui/components/AuthDialog.js +0 -163
  976. package/dist/src/ui/components/AuthDialog.js.map +0 -1
  977. package/dist/src/ui/components/AuthDialog.test.js.map +0 -1
  978. package/dist/src/ui/components/AuthInProgress.js.map +0 -1
  979. package/dist/src/ui/components/ModelSelectionDialog.d.ts +0 -14
  980. package/dist/src/ui/components/ModelSelectionDialog.js +0 -26
  981. package/dist/src/ui/components/ModelSelectionDialog.js.map +0 -1
  982. package/dist/src/ui/components/ModelSelectionDialog.test.js +0 -124
  983. package/dist/src/ui/components/ModelSelectionDialog.test.js.map +0 -1
  984. package/dist/src/ui/hooks/useAuthCommand.d.ts +0 -14
  985. package/dist/src/ui/hooks/useAuthCommand.js +0 -66
  986. package/dist/src/ui/hooks/useAuthCommand.js.map +0 -1
  987. package/dist/src/ui/hooks/usePrivacySettings.d.ts +0 -16
  988. package/dist/src/ui/hooks/usePrivacySettings.js +0 -119
  989. package/dist/src/ui/hooks/usePrivacySettings.js.map +0 -1
  990. package/dist/src/ui/hooks/usePrivacySettings.test.js +0 -154
  991. package/dist/src/ui/hooks/usePrivacySettings.test.js.map +0 -1
  992. package/dist/src/ui/privacy/CloudFreePrivacyNotice.d.ts +0 -12
  993. package/dist/src/ui/privacy/CloudFreePrivacyNotice.js +0 -41
  994. package/dist/src/ui/privacy/CloudFreePrivacyNotice.js.map +0 -1
  995. package/dist/src/ui/privacy/CloudPaidPrivacyNotice.d.ts +0 -10
  996. package/dist/src/ui/privacy/CloudPaidPrivacyNotice.js +0 -18
  997. package/dist/src/ui/privacy/CloudPaidPrivacyNotice.js.map +0 -1
  998. package/dist/src/ui/privacy/GeminiPrivacyNotice.d.ts +0 -10
  999. package/dist/src/ui/privacy/GeminiPrivacyNotice.js +0 -18
  1000. package/dist/src/ui/privacy/GeminiPrivacyNotice.js.map +0 -1
  1001. package/dist/src/ui/privacy/PrivacyNotice.d.ts +0 -12
  1002. package/dist/src/ui/privacy/PrivacyNotice.js +0 -25
  1003. package/dist/src/ui/privacy/PrivacyNotice.js.map +0 -1
  1004. /package/dist/src/{ui/components/AuthDialog.test.d.ts → commands/extensions/new.test.d.ts} +0 -0
  1005. /package/dist/src/{ui/hooks/usePrivacySettings.test.d.ts → config/extensions/extensionEnablement.test.d.ts} +0 -0
  1006. /package/dist/src/ui/{components → auth}/AuthInProgress.d.ts +0 -0
  1007. /package/dist/src/ui/{components/ModelSelectionDialog.test.d.ts → hooks/useAttentionNotifications.test.d.ts} +0 -0
@@ -0,0 +1,1197 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2025 Qwen Team
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ import { describe, it, expect, beforeEach, vi } from 'vitest';
7
+ import { GeminiEventType, } from '@umsai/ums-code-core';
8
+ import { BaseJsonOutputAdapter, partsToString, partsToContentBlock, toolResultContent, extractTextFromBlocks, createExtendedUsage, } from './BaseJsonOutputAdapter.js';
9
+ /**
10
+ * Test implementation of BaseJsonOutputAdapter for unit testing.
11
+ * Captures emitted messages for verification.
12
+ */
13
+ class TestJsonOutputAdapter extends BaseJsonOutputAdapter {
14
+ emittedMessages = [];
15
+ emitMessageImpl(message) {
16
+ this.emittedMessages.push(message);
17
+ }
18
+ shouldEmitStreamEvents() {
19
+ return false;
20
+ }
21
+ finalizeAssistantMessage() {
22
+ return this.finalizeAssistantMessageInternal(this.mainAgentMessageState, null);
23
+ }
24
+ emitResult(options) {
25
+ const resultMessage = this.buildResultMessage(options, this.lastAssistantMessage);
26
+ this.emitMessageImpl(resultMessage);
27
+ }
28
+ // Expose protected methods for testing
29
+ exposeGetMessageState(parentToolUseId) {
30
+ return this.getMessageState(parentToolUseId);
31
+ }
32
+ exposeCreateMessageState() {
33
+ return this.createMessageState();
34
+ }
35
+ exposeCreateUsage(metadata) {
36
+ return this.createUsage(metadata);
37
+ }
38
+ exposeBuildMessage(parentToolUseId) {
39
+ return this.buildMessage(parentToolUseId);
40
+ }
41
+ exposeFinalizePendingBlocks(state, parentToolUseId) {
42
+ this.finalizePendingBlocks(state, parentToolUseId);
43
+ }
44
+ exposeOpenBlock(state, index, block) {
45
+ this.openBlock(state, index, block);
46
+ }
47
+ exposeCloseBlock(state, index) {
48
+ this.closeBlock(state, index);
49
+ }
50
+ exposeEnsureBlockTypeConsistency(state, targetType, parentToolUseId) {
51
+ this.ensureBlockTypeConsistency(state, targetType, parentToolUseId);
52
+ }
53
+ exposeStartAssistantMessageInternal(state) {
54
+ this.startAssistantMessageInternal(state);
55
+ }
56
+ exposeFinalizeAssistantMessageInternal(state, parentToolUseId) {
57
+ return this.finalizeAssistantMessageInternal(state, parentToolUseId);
58
+ }
59
+ exposeAppendText(state, fragment, parentToolUseId) {
60
+ this.appendText(state, fragment, parentToolUseId);
61
+ }
62
+ exposeAppendThinking(state, subject, description, parentToolUseId) {
63
+ this.appendThinking(state, subject, description, parentToolUseId);
64
+ }
65
+ exposeAppendToolUse(state, request, parentToolUseId) {
66
+ this.appendToolUse(state, request, parentToolUseId);
67
+ }
68
+ exposeEnsureMessageStarted(state, parentToolUseId) {
69
+ this.ensureMessageStarted(state, parentToolUseId);
70
+ }
71
+ exposeCreateSubagentToolUseBlock(state, toolCall, parentToolUseId) {
72
+ return this.createSubagentToolUseBlock(state, toolCall, parentToolUseId);
73
+ }
74
+ exposeBuildResultMessage(options) {
75
+ return this.buildResultMessage(options, this.lastAssistantMessage);
76
+ }
77
+ exposeBuildSubagentErrorResult(errorMessage, numTurns) {
78
+ return this.buildSubagentErrorResult(errorMessage, numTurns);
79
+ }
80
+ }
81
+ function createMockConfig() {
82
+ return {
83
+ getSessionId: vi.fn().mockReturnValue('test-session-id'),
84
+ getModel: vi.fn().mockReturnValue('test-model'),
85
+ };
86
+ }
87
+ describe('BaseJsonOutputAdapter', () => {
88
+ let adapter;
89
+ let mockConfig;
90
+ beforeEach(() => {
91
+ mockConfig = createMockConfig();
92
+ adapter = new TestJsonOutputAdapter(mockConfig);
93
+ });
94
+ describe('createMessageState', () => {
95
+ it('should create a new message state with default values', () => {
96
+ const state = adapter.exposeCreateMessageState();
97
+ expect(state.messageId).toBeNull();
98
+ expect(state.blocks).toEqual([]);
99
+ expect(state.openBlocks).toBeInstanceOf(Set);
100
+ expect(state.openBlocks.size).toBe(0);
101
+ expect(state.usage).toEqual({
102
+ input_tokens: 0,
103
+ output_tokens: 0,
104
+ });
105
+ expect(state.messageStarted).toBe(false);
106
+ expect(state.finalized).toBe(false);
107
+ expect(state.currentBlockType).toBeNull();
108
+ });
109
+ });
110
+ describe('getMessageState', () => {
111
+ it('should return main agent state for null parentToolUseId', () => {
112
+ const state = adapter.exposeGetMessageState(null);
113
+ expect(state).toBe(adapter['mainAgentMessageState']);
114
+ });
115
+ it('should create and return subagent state for non-null parentToolUseId', () => {
116
+ const parentToolUseId = 'parent-tool-1';
117
+ const state1 = adapter.exposeGetMessageState(parentToolUseId);
118
+ const state2 = adapter.exposeGetMessageState(parentToolUseId);
119
+ expect(state1).toBe(state2);
120
+ expect(state1).not.toBe(adapter['mainAgentMessageState']);
121
+ expect(adapter['subagentMessageStates'].has(parentToolUseId)).toBe(true);
122
+ });
123
+ it('should create separate states for different parentToolUseIds', () => {
124
+ const state1 = adapter.exposeGetMessageState('parent-1');
125
+ const state2 = adapter.exposeGetMessageState('parent-2');
126
+ expect(state1).not.toBe(state2);
127
+ });
128
+ });
129
+ describe('createUsage', () => {
130
+ it('should create usage with default values when metadata is not provided', () => {
131
+ const usage = adapter.exposeCreateUsage();
132
+ expect(usage).toEqual({
133
+ input_tokens: 0,
134
+ output_tokens: 0,
135
+ });
136
+ });
137
+ it('should create usage with null metadata', () => {
138
+ const usage = adapter.exposeCreateUsage(null);
139
+ expect(usage).toEqual({
140
+ input_tokens: 0,
141
+ output_tokens: 0,
142
+ });
143
+ });
144
+ it('should extract usage from metadata', () => {
145
+ const metadata = {
146
+ promptTokenCount: 100,
147
+ candidatesTokenCount: 50,
148
+ cachedContentTokenCount: 10,
149
+ totalTokenCount: 160,
150
+ };
151
+ const usage = adapter.exposeCreateUsage(metadata);
152
+ expect(usage).toEqual({
153
+ input_tokens: 100,
154
+ output_tokens: 50,
155
+ cache_read_input_tokens: 10,
156
+ total_tokens: 160,
157
+ });
158
+ });
159
+ it('should handle partial metadata', () => {
160
+ const metadata = {
161
+ promptTokenCount: 100,
162
+ // candidatesTokenCount missing
163
+ };
164
+ const usage = adapter.exposeCreateUsage(metadata);
165
+ expect(usage).toEqual({
166
+ input_tokens: 100,
167
+ output_tokens: 0,
168
+ });
169
+ });
170
+ });
171
+ describe('buildMessage', () => {
172
+ beforeEach(() => {
173
+ adapter.startAssistantMessage();
174
+ });
175
+ it('should throw error if message not started', () => {
176
+ // Manipulate the actual main agent state used by buildMessage
177
+ const state = adapter['mainAgentMessageState'];
178
+ state.messageId = null; // Explicitly set to null to test error case
179
+ state.blocks = [{ type: 'text', text: 'test' }];
180
+ expect(() => adapter.exposeBuildMessage(null)).toThrow('Message not started');
181
+ });
182
+ it('should build message with text blocks', () => {
183
+ adapter.startAssistantMessage();
184
+ adapter.processEvent({
185
+ type: GeminiEventType.Content,
186
+ value: 'Hello world',
187
+ });
188
+ const message = adapter.exposeBuildMessage(null);
189
+ expect(message.type).toBe('assistant');
190
+ expect(message.uuid).toBeTruthy();
191
+ expect(message.session_id).toBe('test-session-id');
192
+ expect(message.parent_tool_use_id).toBeNull();
193
+ expect(message.message.role).toBe('assistant');
194
+ expect(message.message.model).toBe('test-model');
195
+ expect(message.message.content).toHaveLength(1);
196
+ expect(message.message.content[0]).toMatchObject({
197
+ type: 'text',
198
+ text: 'Hello world',
199
+ });
200
+ expect(message.message.stop_reason).toBeNull();
201
+ });
202
+ it('should set stop_reason to tool_use when message contains only tool_use blocks', () => {
203
+ adapter.startAssistantMessage();
204
+ adapter.processEvent({
205
+ type: GeminiEventType.ToolCallRequest,
206
+ value: {
207
+ callId: 'tool-1',
208
+ name: 'test_tool',
209
+ args: {},
210
+ isClientInitiated: false,
211
+ prompt_id: 'prompt-1',
212
+ },
213
+ });
214
+ const message = adapter.exposeBuildMessage(null);
215
+ expect(message.message.stop_reason).toBe('tool_use');
216
+ });
217
+ it('should enforce single block type constraint', () => {
218
+ adapter.startAssistantMessage();
219
+ const state = adapter['mainAgentMessageState'];
220
+ state.messageId = 'test-id';
221
+ state.blocks = [
222
+ { type: 'text', text: 'text' },
223
+ { type: 'thinking', thinking: 'thinking', signature: 'sig' },
224
+ ];
225
+ expect(() => adapter.exposeBuildMessage(null)).toThrow('Assistant message must contain only one type of ContentBlock');
226
+ });
227
+ });
228
+ describe('finalizePendingBlocks', () => {
229
+ it('should finalize text blocks', () => {
230
+ const state = adapter.exposeCreateMessageState();
231
+ state.blocks = [{ type: 'text', text: 'test' }];
232
+ const index = 0;
233
+ adapter.exposeOpenBlock(state, index, state.blocks[0]);
234
+ adapter.exposeFinalizePendingBlocks(state);
235
+ expect(state.openBlocks.has(index)).toBe(false);
236
+ });
237
+ it('should finalize thinking blocks', () => {
238
+ const state = adapter.exposeCreateMessageState();
239
+ state.blocks = [{ type: 'thinking', thinking: 'test', signature: 'sig' }];
240
+ const index = 0;
241
+ adapter.exposeOpenBlock(state, index, state.blocks[0]);
242
+ adapter.exposeFinalizePendingBlocks(state);
243
+ expect(state.openBlocks.has(index)).toBe(false);
244
+ });
245
+ it('should do nothing if no blocks', () => {
246
+ const state = adapter.exposeCreateMessageState();
247
+ expect(() => adapter.exposeFinalizePendingBlocks(state)).not.toThrow();
248
+ });
249
+ it('should do nothing if last block is not text or thinking', () => {
250
+ const state = adapter.exposeCreateMessageState();
251
+ state.blocks = [
252
+ {
253
+ type: 'tool_use',
254
+ id: 'tool-1',
255
+ name: 'test',
256
+ input: {},
257
+ },
258
+ ];
259
+ expect(() => adapter.exposeFinalizePendingBlocks(state)).not.toThrow();
260
+ });
261
+ });
262
+ describe('openBlock and closeBlock', () => {
263
+ it('should add block index to openBlocks', () => {
264
+ const state = adapter.exposeCreateMessageState();
265
+ const block = { type: 'text', text: 'test' };
266
+ adapter.exposeOpenBlock(state, 0, block);
267
+ expect(state.openBlocks.has(0)).toBe(true);
268
+ });
269
+ it('should remove block index from openBlocks', () => {
270
+ const state = adapter.exposeCreateMessageState();
271
+ const block = { type: 'text', text: 'test' };
272
+ adapter.exposeOpenBlock(state, 0, block);
273
+ adapter.exposeCloseBlock(state, 0);
274
+ expect(state.openBlocks.has(0)).toBe(false);
275
+ });
276
+ it('should not throw when closing non-existent block', () => {
277
+ const state = adapter.exposeCreateMessageState();
278
+ expect(() => adapter.exposeCloseBlock(state, 0)).not.toThrow();
279
+ });
280
+ });
281
+ describe('ensureBlockTypeConsistency', () => {
282
+ it('should set currentBlockType if null', () => {
283
+ const state = adapter.exposeCreateMessageState();
284
+ state.currentBlockType = null;
285
+ adapter.exposeEnsureBlockTypeConsistency(state, 'text', null);
286
+ expect(state.currentBlockType).toBe('text');
287
+ });
288
+ it('should do nothing if currentBlockType matches target', () => {
289
+ const state = adapter.exposeCreateMessageState();
290
+ state.currentBlockType = 'text';
291
+ state.messageId = 'test-id';
292
+ state.blocks = [{ type: 'text', text: 'test' }];
293
+ adapter.exposeEnsureBlockTypeConsistency(state, 'text', null);
294
+ expect(state.currentBlockType).toBe('text');
295
+ expect(state.blocks).toHaveLength(1);
296
+ });
297
+ it('should finalize and start new message when block type changes', () => {
298
+ adapter.startAssistantMessage();
299
+ const state = adapter['mainAgentMessageState'];
300
+ adapter.processEvent({
301
+ type: GeminiEventType.Content,
302
+ value: 'text',
303
+ });
304
+ adapter.exposeEnsureBlockTypeConsistency(state, 'thinking', null);
305
+ expect(state.currentBlockType).toBe('thinking');
306
+ expect(state.blocks.length).toBe(0);
307
+ });
308
+ });
309
+ describe('startAssistantMessageInternal', () => {
310
+ it('should reset message state', () => {
311
+ const state = adapter.exposeCreateMessageState();
312
+ state.messageId = 'old-id';
313
+ state.blocks = [{ type: 'text', text: 'old' }];
314
+ state.openBlocks.add(0);
315
+ state.usage = { input_tokens: 100, output_tokens: 50 };
316
+ state.messageStarted = true;
317
+ state.finalized = true;
318
+ state.currentBlockType = 'text';
319
+ adapter.exposeStartAssistantMessageInternal(state);
320
+ expect(state.messageId).toBeTruthy();
321
+ expect(state.messageId).not.toBe('old-id');
322
+ expect(state.blocks).toEqual([]);
323
+ expect(state.openBlocks.size).toBe(0);
324
+ expect(state.usage).toEqual({ input_tokens: 0, output_tokens: 0 });
325
+ expect(state.messageStarted).toBe(false);
326
+ expect(state.finalized).toBe(false);
327
+ expect(state.currentBlockType).toBeNull();
328
+ });
329
+ });
330
+ describe('finalizeAssistantMessageInternal', () => {
331
+ it('should return same message if already finalized', () => {
332
+ adapter.startAssistantMessage();
333
+ const state = adapter['mainAgentMessageState'];
334
+ adapter.processEvent({
335
+ type: GeminiEventType.Content,
336
+ value: 'test',
337
+ });
338
+ const message1 = adapter.exposeFinalizeAssistantMessageInternal(state, null);
339
+ const message2 = adapter.exposeFinalizeAssistantMessageInternal(state, null);
340
+ expect(message1).toEqual(message2);
341
+ expect(state.finalized).toBe(true);
342
+ });
343
+ it('should finalize pending blocks and emit message', () => {
344
+ adapter.startAssistantMessage();
345
+ const state = adapter['mainAgentMessageState'];
346
+ adapter.processEvent({
347
+ type: GeminiEventType.Content,
348
+ value: 'test',
349
+ });
350
+ const message = adapter.exposeFinalizeAssistantMessageInternal(state, null);
351
+ expect(message).toBeDefined();
352
+ expect(state.finalized).toBe(true);
353
+ expect(adapter.emittedMessages).toContain(message);
354
+ });
355
+ it('should close all open blocks', () => {
356
+ adapter.startAssistantMessage();
357
+ const state = adapter['mainAgentMessageState'];
358
+ adapter.processEvent({
359
+ type: GeminiEventType.Content,
360
+ value: 'test',
361
+ });
362
+ state.openBlocks.add(0);
363
+ adapter.exposeFinalizeAssistantMessageInternal(state, null);
364
+ expect(state.openBlocks.size).toBe(0);
365
+ });
366
+ });
367
+ describe('appendText', () => {
368
+ it('should create new text block if none exists', () => {
369
+ const state = adapter.exposeCreateMessageState();
370
+ adapter.startAssistantMessage();
371
+ adapter.exposeAppendText(state, 'Hello', null);
372
+ expect(state.blocks).toHaveLength(1);
373
+ expect(state.blocks[0]).toMatchObject({
374
+ type: 'text',
375
+ text: 'Hello',
376
+ });
377
+ });
378
+ it('should append to existing text block', () => {
379
+ const state = adapter.exposeCreateMessageState();
380
+ adapter.startAssistantMessage();
381
+ adapter.exposeAppendText(state, 'Hello', null);
382
+ adapter.exposeAppendText(state, ' World', null);
383
+ expect(state.blocks).toHaveLength(1);
384
+ expect(state.blocks[0]).toMatchObject({
385
+ type: 'text',
386
+ text: 'Hello World',
387
+ });
388
+ });
389
+ it('should ignore empty fragments', () => {
390
+ const state = adapter.exposeCreateMessageState();
391
+ adapter.startAssistantMessage();
392
+ adapter.exposeAppendText(state, '', null);
393
+ expect(state.blocks).toHaveLength(0);
394
+ });
395
+ it('should ensure message is started', () => {
396
+ const state = adapter.exposeCreateMessageState();
397
+ adapter.startAssistantMessage();
398
+ adapter.exposeAppendText(state, 'test', null);
399
+ expect(state.messageStarted).toBe(true);
400
+ });
401
+ });
402
+ describe('appendThinking', () => {
403
+ it('should create new thinking block', () => {
404
+ const state = adapter.exposeCreateMessageState();
405
+ adapter.startAssistantMessage();
406
+ adapter.exposeAppendThinking(state, 'Planning', 'Thinking about task', null);
407
+ expect(state.blocks).toHaveLength(1);
408
+ expect(state.blocks[0]).toMatchObject({
409
+ type: 'thinking',
410
+ thinking: 'Planning: Thinking about task',
411
+ signature: 'Planning',
412
+ });
413
+ });
414
+ it('should append to existing thinking block', () => {
415
+ const state = adapter.exposeCreateMessageState();
416
+ adapter.startAssistantMessage();
417
+ adapter.exposeAppendThinking(state, 'Planning', 'First thought', null);
418
+ adapter.exposeAppendThinking(state, 'Planning', 'Second thought', null);
419
+ expect(state.blocks).toHaveLength(1);
420
+ expect(state.blocks[0].type).toBe('thinking');
421
+ const block = state.blocks[0];
422
+ expect(block.thinking).toContain('First thought');
423
+ expect(block.thinking).toContain('Second thought');
424
+ });
425
+ it('should handle only subject', () => {
426
+ const state = adapter.exposeCreateMessageState();
427
+ adapter.startAssistantMessage();
428
+ adapter.exposeAppendThinking(state, 'Planning', '', null);
429
+ expect(state.blocks).toHaveLength(1);
430
+ expect(state.blocks[0]).toMatchObject({
431
+ type: 'thinking',
432
+ signature: 'Planning',
433
+ });
434
+ });
435
+ it('should ignore empty fragments', () => {
436
+ const state = adapter.exposeCreateMessageState();
437
+ adapter.startAssistantMessage();
438
+ adapter.exposeAppendThinking(state, '', '', null);
439
+ expect(state.blocks).toHaveLength(0);
440
+ });
441
+ });
442
+ describe('appendToolUse', () => {
443
+ it('should create tool_use block', () => {
444
+ const state = adapter.exposeCreateMessageState();
445
+ adapter.startAssistantMessage();
446
+ adapter.exposeAppendToolUse(state, {
447
+ callId: 'tool-1',
448
+ name: 'test_tool',
449
+ args: { param: 'value' },
450
+ }, null);
451
+ expect(state.blocks).toHaveLength(1);
452
+ expect(state.blocks[0]).toMatchObject({
453
+ type: 'tool_use',
454
+ id: 'tool-1',
455
+ name: 'test_tool',
456
+ input: { param: 'value' },
457
+ });
458
+ });
459
+ it('should finalize pending blocks before appending tool_use', () => {
460
+ const state = adapter.exposeCreateMessageState();
461
+ adapter.startAssistantMessage();
462
+ adapter.exposeAppendText(state, 'text', null);
463
+ adapter.exposeAppendToolUse(state, {
464
+ callId: 'tool-1',
465
+ name: 'test_tool',
466
+ args: {},
467
+ }, null);
468
+ expect(state.blocks.length).toBeGreaterThan(0);
469
+ const toolUseBlock = state.blocks.find((b) => b.type === 'tool_use');
470
+ expect(toolUseBlock).toBeDefined();
471
+ });
472
+ });
473
+ describe('ensureMessageStarted', () => {
474
+ it('should set messageStarted to true', () => {
475
+ const state = adapter.exposeCreateMessageState();
476
+ adapter.startAssistantMessage();
477
+ adapter.exposeEnsureMessageStarted(state, null);
478
+ expect(state.messageStarted).toBe(true);
479
+ });
480
+ it('should do nothing if already started', () => {
481
+ const state = adapter.exposeCreateMessageState();
482
+ adapter.startAssistantMessage();
483
+ state.messageStarted = true;
484
+ adapter.exposeEnsureMessageStarted(state, null);
485
+ expect(state.messageStarted).toBe(true);
486
+ });
487
+ });
488
+ describe('startAssistantMessage', () => {
489
+ it('should reset main agent message state', () => {
490
+ adapter.startAssistantMessage();
491
+ adapter.processEvent({
492
+ type: GeminiEventType.Content,
493
+ value: 'test',
494
+ });
495
+ adapter.startAssistantMessage();
496
+ const state = adapter['mainAgentMessageState'];
497
+ expect(state.blocks).toHaveLength(0);
498
+ expect(state.messageStarted).toBe(false);
499
+ });
500
+ });
501
+ describe('processEvent', () => {
502
+ beforeEach(() => {
503
+ adapter.startAssistantMessage();
504
+ });
505
+ it('should process Content events', () => {
506
+ adapter.processEvent({
507
+ type: GeminiEventType.Content,
508
+ value: 'Hello',
509
+ });
510
+ const state = adapter['mainAgentMessageState'];
511
+ expect(state.blocks).toHaveLength(1);
512
+ expect(state.blocks[0]).toMatchObject({
513
+ type: 'text',
514
+ text: 'Hello',
515
+ });
516
+ });
517
+ it('should process Citation events', () => {
518
+ adapter.processEvent({
519
+ type: GeminiEventType.Citation,
520
+ value: 'Citation text',
521
+ });
522
+ const state = adapter['mainAgentMessageState'];
523
+ expect(state.blocks[0].type).toBe('text');
524
+ const block = state.blocks[0];
525
+ expect(block.text).toContain('Citation text');
526
+ });
527
+ it('should ignore non-string Citation values', () => {
528
+ adapter.processEvent({
529
+ type: GeminiEventType.Citation,
530
+ value: 123,
531
+ });
532
+ const state = adapter['mainAgentMessageState'];
533
+ expect(state.blocks).toHaveLength(0);
534
+ });
535
+ it('should process Thought events', () => {
536
+ adapter.processEvent({
537
+ type: GeminiEventType.Thought,
538
+ value: {
539
+ subject: 'Planning',
540
+ description: 'Thinking',
541
+ },
542
+ });
543
+ const state = adapter['mainAgentMessageState'];
544
+ expect(state.blocks).toHaveLength(1);
545
+ expect(state.blocks[0]).toMatchObject({
546
+ type: 'thinking',
547
+ thinking: 'Planning: Thinking',
548
+ signature: 'Planning',
549
+ });
550
+ });
551
+ it('should process ToolCallRequest events', () => {
552
+ adapter.processEvent({
553
+ type: GeminiEventType.ToolCallRequest,
554
+ value: {
555
+ callId: 'tool-1',
556
+ name: 'test_tool',
557
+ args: { param: 'value' },
558
+ isClientInitiated: false,
559
+ prompt_id: 'prompt-1',
560
+ },
561
+ });
562
+ const state = adapter['mainAgentMessageState'];
563
+ expect(state.blocks).toHaveLength(1);
564
+ expect(state.blocks[0]).toMatchObject({
565
+ type: 'tool_use',
566
+ id: 'tool-1',
567
+ name: 'test_tool',
568
+ input: { param: 'value' },
569
+ });
570
+ });
571
+ it('should process Finished events with usage metadata', () => {
572
+ adapter.processEvent({
573
+ type: GeminiEventType.Finished,
574
+ value: {
575
+ reason: undefined,
576
+ usageMetadata: {
577
+ promptTokenCount: 100,
578
+ candidatesTokenCount: 50,
579
+ },
580
+ },
581
+ });
582
+ const state = adapter['mainAgentMessageState'];
583
+ expect(state.usage).toEqual({
584
+ input_tokens: 100,
585
+ output_tokens: 50,
586
+ });
587
+ });
588
+ it('should ignore events after finalization', () => {
589
+ adapter.processEvent({
590
+ type: GeminiEventType.Content,
591
+ value: 'First',
592
+ });
593
+ adapter.finalizeAssistantMessage();
594
+ adapter.processEvent({
595
+ type: GeminiEventType.Content,
596
+ value: 'Second',
597
+ });
598
+ const state = adapter['mainAgentMessageState'];
599
+ expect(state.blocks[0]).toMatchObject({
600
+ type: 'text',
601
+ text: 'First',
602
+ });
603
+ });
604
+ });
605
+ describe('finalizeAssistantMessage', () => {
606
+ beforeEach(() => {
607
+ adapter.startAssistantMessage();
608
+ });
609
+ it('should build and return assistant message', () => {
610
+ adapter.processEvent({
611
+ type: GeminiEventType.Content,
612
+ value: 'Test response',
613
+ });
614
+ const message = adapter.finalizeAssistantMessage();
615
+ expect(message.type).toBe('assistant');
616
+ expect(message.message.content).toHaveLength(1);
617
+ expect(adapter.emittedMessages).toContain(message);
618
+ });
619
+ });
620
+ describe('emitUserMessage', () => {
621
+ it('should emit user message with ContentBlock array', () => {
622
+ const parts = [{ text: 'Hello user' }];
623
+ adapter.emitUserMessage(parts);
624
+ expect(adapter.emittedMessages).toHaveLength(1);
625
+ const message = adapter.emittedMessages[0];
626
+ expect(message.type).toBe('user');
627
+ if (message.type === 'user') {
628
+ expect(Array.isArray(message.message.content)).toBe(true);
629
+ if (Array.isArray(message.message.content)) {
630
+ expect(message.message.content).toHaveLength(1);
631
+ expect(message.message.content[0]).toEqual({
632
+ type: 'text',
633
+ text: 'Hello user',
634
+ });
635
+ }
636
+ expect(message.parent_tool_use_id).toBeNull();
637
+ }
638
+ });
639
+ it('should handle multiple parts and merge into single text block', () => {
640
+ const parts = [{ text: 'Hello' }, { text: ' World' }];
641
+ adapter.emitUserMessage(parts);
642
+ const message = adapter.emittedMessages[0];
643
+ if (message.type === 'user' && Array.isArray(message.message.content)) {
644
+ expect(message.message.content).toHaveLength(1);
645
+ expect(message.message.content[0]).toEqual({
646
+ type: 'text',
647
+ text: 'Hello World',
648
+ });
649
+ }
650
+ });
651
+ it('should handle non-text parts by converting to text blocks', () => {
652
+ const parts = [
653
+ { text: 'Hello' },
654
+ { functionCall: { name: 'test' } },
655
+ ];
656
+ adapter.emitUserMessage(parts);
657
+ const message = adapter.emittedMessages[0];
658
+ if (message.type === 'user' && Array.isArray(message.message.content)) {
659
+ expect(message.message.content.length).toBeGreaterThan(0);
660
+ const textBlock = message.message.content.find((block) => block.type === 'text');
661
+ expect(textBlock).toBeDefined();
662
+ if (textBlock && textBlock.type === 'text') {
663
+ expect(textBlock.text).toContain('Hello');
664
+ }
665
+ }
666
+ });
667
+ });
668
+ describe('emitToolResult', () => {
669
+ it('should emit tool result message with content', () => {
670
+ const request = {
671
+ callId: 'tool-1',
672
+ name: 'test_tool',
673
+ args: {},
674
+ isClientInitiated: false,
675
+ prompt_id: 'prompt-1',
676
+ };
677
+ const response = {
678
+ callId: 'tool-1',
679
+ responseParts: [],
680
+ resultDisplay: 'Tool executed successfully',
681
+ error: undefined,
682
+ errorType: undefined,
683
+ };
684
+ adapter.emitToolResult(request, response);
685
+ expect(adapter.emittedMessages).toHaveLength(1);
686
+ const message = adapter.emittedMessages[0];
687
+ expect(message.type).toBe('user');
688
+ if (message.type === 'user') {
689
+ expect(message.message.content).toHaveLength(1);
690
+ const block = message.message.content[0];
691
+ if (typeof block === 'object' && block !== null && 'type' in block) {
692
+ expect(block.type).toBe('tool_result');
693
+ if (block.type === 'tool_result') {
694
+ expect(block.tool_use_id).toBe('tool-1');
695
+ expect(block.content).toBe('Tool executed successfully');
696
+ expect(block.is_error).toBe(false);
697
+ }
698
+ }
699
+ }
700
+ });
701
+ it('should mark error tool results', () => {
702
+ const request = {
703
+ callId: 'tool-1',
704
+ name: 'test_tool',
705
+ args: {},
706
+ isClientInitiated: false,
707
+ prompt_id: 'prompt-1',
708
+ };
709
+ const response = {
710
+ callId: 'tool-1',
711
+ responseParts: [],
712
+ resultDisplay: undefined,
713
+ error: new Error('Tool failed'),
714
+ errorType: undefined,
715
+ };
716
+ adapter.emitToolResult(request, response);
717
+ const message = adapter.emittedMessages[0];
718
+ if (message.type === 'user') {
719
+ const block = message.message.content[0];
720
+ if (typeof block === 'object' && block !== null && 'type' in block) {
721
+ if (block.type === 'tool_result') {
722
+ expect(block.is_error).toBe(true);
723
+ }
724
+ }
725
+ }
726
+ });
727
+ it('should handle parentToolUseId', () => {
728
+ const request = {
729
+ callId: 'tool-1',
730
+ name: 'test_tool',
731
+ args: {},
732
+ isClientInitiated: false,
733
+ prompt_id: 'prompt-1',
734
+ };
735
+ const response = {
736
+ callId: 'tool-1',
737
+ responseParts: [],
738
+ resultDisplay: 'Result',
739
+ error: undefined,
740
+ errorType: undefined,
741
+ };
742
+ adapter.emitToolResult(request, response, 'parent-tool-1');
743
+ const message = adapter.emittedMessages[0];
744
+ if (message.type === 'user') {
745
+ expect(message.parent_tool_use_id).toBe('parent-tool-1');
746
+ }
747
+ });
748
+ });
749
+ describe('emitSystemMessage', () => {
750
+ it('should emit system message', () => {
751
+ adapter.emitSystemMessage('test_subtype', { data: 'value' });
752
+ expect(adapter.emittedMessages).toHaveLength(1);
753
+ const message = adapter.emittedMessages[0];
754
+ expect(message.type).toBe('system');
755
+ if (message.type === 'system') {
756
+ expect(message.subtype).toBe('test_subtype');
757
+ expect(message.data).toEqual({ data: 'value' });
758
+ }
759
+ });
760
+ it('should handle system message without data', () => {
761
+ adapter.emitSystemMessage('test_subtype');
762
+ const message = adapter.emittedMessages[0];
763
+ if (message.type === 'system') {
764
+ expect(message.subtype).toBe('test_subtype');
765
+ }
766
+ });
767
+ });
768
+ describe('buildResultMessage', () => {
769
+ beforeEach(() => {
770
+ adapter.startAssistantMessage();
771
+ adapter.processEvent({
772
+ type: GeminiEventType.Content,
773
+ value: 'Response text',
774
+ });
775
+ const message = adapter.finalizeAssistantMessage();
776
+ // Update lastAssistantMessage manually since test adapter doesn't do it automatically
777
+ adapter['lastAssistantMessage'] = message;
778
+ });
779
+ it('should build success result message', () => {
780
+ const options = {
781
+ isError: false,
782
+ durationMs: 1000,
783
+ apiDurationMs: 800,
784
+ numTurns: 1,
785
+ };
786
+ const result = adapter.exposeBuildResultMessage(options);
787
+ expect(result.type).toBe('result');
788
+ expect(result.is_error).toBe(false);
789
+ if (!result.is_error) {
790
+ expect(result.subtype).toBe('success');
791
+ expect(result.result).toBe('Response text');
792
+ expect(result.duration_ms).toBe(1000);
793
+ expect(result.duration_api_ms).toBe(800);
794
+ expect(result.num_turns).toBe(1);
795
+ }
796
+ });
797
+ it('should build error result message', () => {
798
+ const options = {
799
+ isError: true,
800
+ errorMessage: 'Test error',
801
+ durationMs: 500,
802
+ apiDurationMs: 300,
803
+ numTurns: 1,
804
+ };
805
+ const result = adapter.exposeBuildResultMessage(options);
806
+ expect(result.type).toBe('result');
807
+ expect(result.is_error).toBe(true);
808
+ if (result.is_error) {
809
+ expect(result.subtype).toBe('error_during_execution');
810
+ expect(result.error?.message).toBe('Test error');
811
+ }
812
+ });
813
+ it('should use provided summary over extracted text', () => {
814
+ const options = {
815
+ isError: false,
816
+ summary: 'Custom summary',
817
+ durationMs: 1000,
818
+ apiDurationMs: 800,
819
+ numTurns: 1,
820
+ };
821
+ const result = adapter.exposeBuildResultMessage(options);
822
+ if (!result.is_error) {
823
+ expect(result.result).toBe('Custom summary');
824
+ }
825
+ });
826
+ it('should include usage information', () => {
827
+ const usage = {
828
+ input_tokens: 100,
829
+ output_tokens: 50,
830
+ total_tokens: 150,
831
+ };
832
+ const options = {
833
+ isError: false,
834
+ usage,
835
+ durationMs: 1000,
836
+ apiDurationMs: 800,
837
+ numTurns: 1,
838
+ };
839
+ const result = adapter.exposeBuildResultMessage(options);
840
+ expect(result.usage).toEqual(usage);
841
+ });
842
+ it('should include stats when provided', () => {
843
+ const stats = {
844
+ models: {},
845
+ tools: {
846
+ totalCalls: 5,
847
+ totalSuccess: 4,
848
+ totalFail: 1,
849
+ totalDurationMs: 1000,
850
+ totalDecisions: {
851
+ accept: 3,
852
+ reject: 1,
853
+ modify: 0,
854
+ auto_accept: 1,
855
+ },
856
+ byName: {},
857
+ },
858
+ files: {
859
+ totalLinesAdded: 10,
860
+ totalLinesRemoved: 5,
861
+ },
862
+ };
863
+ const options = {
864
+ isError: false,
865
+ stats,
866
+ durationMs: 1000,
867
+ apiDurationMs: 800,
868
+ numTurns: 1,
869
+ };
870
+ const result = adapter.exposeBuildResultMessage(options);
871
+ if (!result.is_error && 'stats' in result) {
872
+ expect(result['stats']).toEqual(stats);
873
+ }
874
+ });
875
+ it('should handle result without assistant message', () => {
876
+ adapter = new TestJsonOutputAdapter(mockConfig);
877
+ const options = {
878
+ isError: false,
879
+ durationMs: 1000,
880
+ apiDurationMs: 800,
881
+ numTurns: 1,
882
+ };
883
+ const result = adapter.exposeBuildResultMessage(options);
884
+ if (!result.is_error) {
885
+ expect(result.result).toBe('');
886
+ }
887
+ });
888
+ });
889
+ describe('startSubagentAssistantMessage', () => {
890
+ it('should start subagent message', () => {
891
+ const parentToolUseId = 'parent-tool-1';
892
+ adapter.startSubagentAssistantMessage(parentToolUseId);
893
+ const state = adapter.exposeGetMessageState(parentToolUseId);
894
+ expect(state.messageId).toBeTruthy();
895
+ expect(state.blocks).toEqual([]);
896
+ });
897
+ });
898
+ describe('finalizeSubagentAssistantMessage', () => {
899
+ it('should finalize and return subagent message', () => {
900
+ const parentToolUseId = 'parent-tool-1';
901
+ adapter.startSubagentAssistantMessage(parentToolUseId);
902
+ const state = adapter.exposeGetMessageState(parentToolUseId);
903
+ adapter.exposeAppendText(state, 'Subagent response', parentToolUseId);
904
+ const message = adapter.finalizeSubagentAssistantMessage(parentToolUseId);
905
+ expect(message.type).toBe('assistant');
906
+ expect(message.parent_tool_use_id).toBe(parentToolUseId);
907
+ expect(message.message.content).toHaveLength(1);
908
+ });
909
+ });
910
+ describe('emitSubagentErrorResult', () => {
911
+ it('should emit subagent error result', () => {
912
+ const parentToolUseId = 'parent-tool-1';
913
+ adapter.startSubagentAssistantMessage(parentToolUseId);
914
+ adapter.emitSubagentErrorResult('Error occurred', 5, parentToolUseId);
915
+ expect(adapter.emittedMessages.length).toBeGreaterThan(0);
916
+ const errorResult = adapter.emittedMessages.find((msg) => msg.type === 'result' && msg.is_error === true);
917
+ expect(errorResult).toBeDefined();
918
+ if (errorResult &&
919
+ errorResult.type === 'result' &&
920
+ errorResult.is_error) {
921
+ expect(errorResult.error?.message).toBe('Error occurred');
922
+ expect(errorResult.num_turns).toBe(5);
923
+ }
924
+ });
925
+ it('should finalize pending assistant message before emitting error', () => {
926
+ const parentToolUseId = 'parent-tool-1';
927
+ adapter.startSubagentAssistantMessage(parentToolUseId);
928
+ const state = adapter.exposeGetMessageState(parentToolUseId);
929
+ adapter.exposeAppendText(state, 'Partial response', parentToolUseId);
930
+ adapter.emitSubagentErrorResult('Error', 1, parentToolUseId);
931
+ const assistantMessage = adapter.emittedMessages.find((msg) => msg.type === 'assistant');
932
+ expect(assistantMessage).toBeDefined();
933
+ });
934
+ });
935
+ describe('processSubagentToolCall', () => {
936
+ it('should process subagent tool call', () => {
937
+ const parentToolUseId = 'parent-tool-1';
938
+ adapter.startSubagentAssistantMessage(parentToolUseId);
939
+ const toolCall = {
940
+ callId: 'tool-1',
941
+ name: 'test_tool',
942
+ args: { param: 'value' },
943
+ status: 'success',
944
+ resultDisplay: 'Result',
945
+ };
946
+ adapter.processSubagentToolCall(toolCall, parentToolUseId);
947
+ // processSubagentToolCall finalizes the message and starts a new one,
948
+ // so we should check the emitted messages instead of the state
949
+ const assistantMessages = adapter.emittedMessages.filter((msg) => msg.type === 'assistant' &&
950
+ msg.parent_tool_use_id === parentToolUseId);
951
+ expect(assistantMessages.length).toBeGreaterThan(0);
952
+ const toolUseMessage = assistantMessages.find((msg) => msg.type === 'assistant' &&
953
+ msg.message.content.some((block) => block.type === 'tool_use'));
954
+ expect(toolUseMessage).toBeDefined();
955
+ });
956
+ it('should finalize text message before tool_use', () => {
957
+ const parentToolUseId = 'parent-tool-1';
958
+ adapter.startSubagentAssistantMessage(parentToolUseId);
959
+ const state = adapter.exposeGetMessageState(parentToolUseId);
960
+ adapter.exposeAppendText(state, 'Text', parentToolUseId);
961
+ const toolCall = {
962
+ callId: 'tool-1',
963
+ name: 'test_tool',
964
+ args: {},
965
+ status: 'success',
966
+ resultDisplay: 'Result',
967
+ };
968
+ adapter.processSubagentToolCall(toolCall, parentToolUseId);
969
+ const assistantMessages = adapter.emittedMessages.filter((msg) => msg.type === 'assistant');
970
+ expect(assistantMessages.length).toBeGreaterThan(0);
971
+ });
972
+ });
973
+ describe('createSubagentToolUseBlock', () => {
974
+ it('should create tool_use block for subagent', () => {
975
+ const state = adapter.exposeCreateMessageState();
976
+ adapter.startAssistantMessage();
977
+ const toolCall = {
978
+ callId: 'tool-1',
979
+ name: 'test_tool',
980
+ args: { param: 'value' },
981
+ status: 'success',
982
+ resultDisplay: 'Result',
983
+ };
984
+ const { block, index } = adapter.exposeCreateSubagentToolUseBlock(state, toolCall, 'parent-tool-1');
985
+ expect(block).toMatchObject({
986
+ type: 'tool_use',
987
+ id: 'tool-1',
988
+ name: 'test_tool',
989
+ input: { param: 'value' },
990
+ });
991
+ expect(state.blocks[index]).toBe(block);
992
+ expect(state.openBlocks.has(index)).toBe(true);
993
+ });
994
+ });
995
+ describe('buildSubagentErrorResult', () => {
996
+ it('should build subagent error result', () => {
997
+ const errorResult = adapter.exposeBuildSubagentErrorResult('Error message', 3);
998
+ expect(errorResult.type).toBe('result');
999
+ expect(errorResult.is_error).toBe(true);
1000
+ expect(errorResult.subtype).toBe('error_during_execution');
1001
+ expect(errorResult.error?.message).toBe('Error message');
1002
+ expect(errorResult.num_turns).toBe(3);
1003
+ expect(errorResult.usage).toEqual({
1004
+ input_tokens: 0,
1005
+ output_tokens: 0,
1006
+ });
1007
+ });
1008
+ });
1009
+ describe('getSessionId and getModel', () => {
1010
+ it('should return session ID from config', () => {
1011
+ expect(adapter.getSessionId()).toBe('test-session-id');
1012
+ expect(mockConfig.getSessionId).toHaveBeenCalled();
1013
+ });
1014
+ it('should return model from config', () => {
1015
+ expect(adapter.getModel()).toBe('test-model');
1016
+ expect(mockConfig.getModel).toHaveBeenCalled();
1017
+ });
1018
+ });
1019
+ describe('helper functions', () => {
1020
+ describe('partsToContentBlock', () => {
1021
+ it('should convert text parts to TextBlock array', () => {
1022
+ const parts = [{ text: 'Hello' }, { text: ' World' }];
1023
+ const result = partsToContentBlock(parts);
1024
+ expect(result).toHaveLength(1);
1025
+ expect(result[0]).toEqual({
1026
+ type: 'text',
1027
+ text: 'Hello World',
1028
+ });
1029
+ });
1030
+ it('should handle functionResponse parts by extracting output', () => {
1031
+ const parts = [
1032
+ { text: 'Result: ' },
1033
+ {
1034
+ functionResponse: {
1035
+ name: 'test',
1036
+ response: { output: 'function output' },
1037
+ },
1038
+ },
1039
+ ];
1040
+ const result = partsToContentBlock(parts);
1041
+ expect(result).toHaveLength(1);
1042
+ expect(result[0].type).toBe('text');
1043
+ if (result[0].type === 'text') {
1044
+ expect(result[0].text).toBe('Result: function output');
1045
+ }
1046
+ });
1047
+ it('should handle non-text parts by converting to JSON string', () => {
1048
+ const parts = [
1049
+ { text: 'Hello' },
1050
+ { functionCall: { name: 'test' } },
1051
+ ];
1052
+ const result = partsToContentBlock(parts);
1053
+ expect(result.length).toBeGreaterThan(0);
1054
+ const textBlock = result.find((block) => block.type === 'text');
1055
+ expect(textBlock).toBeDefined();
1056
+ if (textBlock && textBlock.type === 'text') {
1057
+ expect(textBlock.text).toContain('Hello');
1058
+ expect(textBlock.text).toContain('functionCall');
1059
+ }
1060
+ });
1061
+ it('should handle empty array', () => {
1062
+ const result = partsToContentBlock([]);
1063
+ expect(result).toEqual([]);
1064
+ });
1065
+ it('should merge consecutive text parts into single block', () => {
1066
+ const parts = [
1067
+ { text: 'Part 1' },
1068
+ { text: 'Part 2' },
1069
+ { text: 'Part 3' },
1070
+ ];
1071
+ const result = partsToContentBlock(parts);
1072
+ expect(result).toHaveLength(1);
1073
+ expect(result[0]).toEqual({
1074
+ type: 'text',
1075
+ text: 'Part 1Part 2Part 3',
1076
+ });
1077
+ });
1078
+ });
1079
+ describe('partsToString', () => {
1080
+ it('should convert text parts to string', () => {
1081
+ const parts = [{ text: 'Hello' }, { text: ' World' }];
1082
+ const result = partsToString(parts);
1083
+ expect(result).toBe('Hello World');
1084
+ });
1085
+ it('should handle non-text parts', () => {
1086
+ const parts = [
1087
+ { text: 'Hello' },
1088
+ { functionCall: { name: 'test' } },
1089
+ ];
1090
+ const result = partsToString(parts);
1091
+ expect(result).toContain('Hello');
1092
+ expect(result).toContain('functionCall');
1093
+ });
1094
+ it('should handle empty array', () => {
1095
+ const result = partsToString([]);
1096
+ expect(result).toBe('');
1097
+ });
1098
+ });
1099
+ describe('toolResultContent', () => {
1100
+ it('should extract content from resultDisplay', () => {
1101
+ const response = {
1102
+ callId: 'tool-1',
1103
+ resultDisplay: 'Tool result',
1104
+ responseParts: [],
1105
+ error: undefined,
1106
+ errorType: undefined,
1107
+ };
1108
+ const result = toolResultContent(response);
1109
+ expect(result).toBe('Tool result');
1110
+ });
1111
+ it('should extract content from responseParts', () => {
1112
+ const response = {
1113
+ callId: 'tool-1',
1114
+ resultDisplay: undefined,
1115
+ responseParts: [{ text: 'Result' }],
1116
+ error: undefined,
1117
+ errorType: undefined,
1118
+ };
1119
+ const result = toolResultContent(response);
1120
+ expect(result).toBeTruthy();
1121
+ });
1122
+ it('should extract error message', () => {
1123
+ const response = {
1124
+ callId: 'tool-1',
1125
+ resultDisplay: undefined,
1126
+ responseParts: [],
1127
+ error: new Error('Tool failed'),
1128
+ errorType: undefined,
1129
+ };
1130
+ const result = toolResultContent(response);
1131
+ expect(result).toBe('Tool failed');
1132
+ });
1133
+ it('should return undefined if no content', () => {
1134
+ const response = {
1135
+ callId: 'tool-1',
1136
+ resultDisplay: undefined,
1137
+ responseParts: [],
1138
+ error: undefined,
1139
+ errorType: undefined,
1140
+ };
1141
+ const result = toolResultContent(response);
1142
+ expect(result).toBeUndefined();
1143
+ });
1144
+ it('should ignore empty resultDisplay', () => {
1145
+ const response = {
1146
+ callId: 'tool-1',
1147
+ resultDisplay: ' ',
1148
+ responseParts: [{ text: 'Result' }],
1149
+ error: undefined,
1150
+ errorType: undefined,
1151
+ };
1152
+ const result = toolResultContent(response);
1153
+ expect(result).toBeTruthy();
1154
+ expect(result).not.toBe(' ');
1155
+ });
1156
+ });
1157
+ describe('extractTextFromBlocks', () => {
1158
+ it('should extract text from text blocks', () => {
1159
+ const blocks = [
1160
+ { type: 'text', text: 'Hello' },
1161
+ { type: 'text', text: ' World' },
1162
+ ];
1163
+ const result = extractTextFromBlocks(blocks);
1164
+ expect(result).toBe('Hello World');
1165
+ });
1166
+ it('should ignore non-text blocks', () => {
1167
+ const blocks = [
1168
+ { type: 'text', text: 'Hello' },
1169
+ { type: 'tool_use', id: 'tool-1', name: 'test', input: {} },
1170
+ ];
1171
+ const result = extractTextFromBlocks(blocks);
1172
+ expect(result).toBe('Hello');
1173
+ });
1174
+ it('should handle empty array', () => {
1175
+ const result = extractTextFromBlocks([]);
1176
+ expect(result).toBe('');
1177
+ });
1178
+ it('should handle array with no text blocks', () => {
1179
+ const blocks = [
1180
+ { type: 'tool_use', id: 'tool-1', name: 'test', input: {} },
1181
+ ];
1182
+ const result = extractTextFromBlocks(blocks);
1183
+ expect(result).toBe('');
1184
+ });
1185
+ });
1186
+ describe('createExtendedUsage', () => {
1187
+ it('should create extended usage with default values', () => {
1188
+ const usage = createExtendedUsage();
1189
+ expect(usage).toEqual({
1190
+ input_tokens: 0,
1191
+ output_tokens: 0,
1192
+ });
1193
+ });
1194
+ });
1195
+ });
1196
+ });
1197
+ //# sourceMappingURL=BaseJsonOutputAdapter.test.js.map