@vibe-forge/client 3.0.0-alpha.6 → 3.0.0-alpha.7

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 (612) hide show
  1. package/cli.cjs +55 -12
  2. package/dist/assets/{arc-CKcDlk7m.js → arc-BSmt4B2L.js} +1 -1
  3. package/dist/assets/{blockDiagram-c4efeb88-Si9lNhiR.js → blockDiagram-c4efeb88-CMloXPoq.js} +1 -1
  4. package/dist/assets/{c4Diagram-c83219d4-CRTN1Bme.js → c4Diagram-c83219d4-Cylc1eLZ.js} +1 -1
  5. package/dist/assets/channel-m79NtBIL.js +1 -0
  6. package/dist/assets/{classDiagram-beda092f-Cn0JFKaM.js → classDiagram-beda092f-BKPTtrKA.js} +1 -1
  7. package/dist/assets/{classDiagram-v2-2358418a-CCRguPFP.js → classDiagram-v2-2358418a-DDp5VQdl.js} +1 -1
  8. package/dist/assets/clone-BWgcAtDw.js +1 -0
  9. package/dist/assets/{createText-1719965b-B7ypMies.js → createText-1719965b-B4dHTOBF.js} +1 -1
  10. package/dist/assets/{cssMode-CGqPieqo.js → cssMode-DiwCtD5c.js} +1 -1
  11. package/dist/assets/{edges-96097737-DQTQ3TTh.js → edges-96097737-ytyiKXTw.js} +1 -1
  12. package/dist/assets/{erDiagram-0228fc6a-RWH9OCKP.js → erDiagram-0228fc6a-DmL6zY48.js} +1 -1
  13. package/dist/assets/{flowDb-c6c81e3f-ChBIZfFE.js → flowDb-c6c81e3f-BCSZkN1T.js} +1 -1
  14. package/dist/assets/{flowDiagram-50d868cf-B5L7Tbzq.js → flowDiagram-50d868cf-uwjrIJD-.js} +1 -1
  15. package/dist/assets/flowDiagram-v2-4f6560a1-cwXzaLSf.js +1 -0
  16. package/dist/assets/{flowchart-elk-definition-6af322e1-B7X89gyf.js → flowchart-elk-definition-6af322e1-W_vSjYDz.js} +1 -1
  17. package/dist/assets/{freemarker2-DG-xlAsn.js → freemarker2-BQf1HvOR.js} +1 -1
  18. package/dist/assets/{ganttDiagram-a2739b55-BedUmaPf.js → ganttDiagram-a2739b55-CGeIfDSH.js} +1 -1
  19. package/dist/assets/{gitGraphDiagram-82fe8481-B8HGnn-5.js → gitGraphDiagram-82fe8481-26OgN5Ry.js} +1 -1
  20. package/dist/assets/{graph-D9-QnVc7.js → graph-2CS6-29E.js} +1 -1
  21. package/dist/assets/{handlebars-D3MqxNWf.js → handlebars-DFgyCEY2.js} +1 -1
  22. package/dist/assets/{html-DufmGZMV.js → html-BV8g5c9v.js} +1 -1
  23. package/dist/assets/{htmlMode-CUM_1bUX.js → htmlMode-JyRqPjN0.js} +1 -1
  24. package/dist/assets/{index-5325376f-DvDnB8Ym.js → index-5325376f-ClAEncJa.js} +1 -1
  25. package/dist/assets/{index-CFwJnHev.js → index-CZrkUnI3.js} +5 -5
  26. package/dist/assets/{infoDiagram-8eee0895-CEkPslG6.js → infoDiagram-8eee0895-CSgc-EfH.js} +1 -1
  27. package/dist/assets/{javascript-B6reuW3Q.js → javascript-BqCcEQX1.js} +1 -1
  28. package/dist/assets/{journeyDiagram-c64418c1-c8XBdi4a.js → journeyDiagram-c64418c1-DT-HZm5B.js} +1 -1
  29. package/dist/assets/{jsonMode-srNnX9pn.js → jsonMode-COyDpXxP.js} +1 -1
  30. package/dist/assets/{layout-XKv3I9bs.js → layout-CWQTznjY.js} +1 -1
  31. package/dist/assets/{line-BUKiwgio.js → line-D9dEs7Yu.js} +1 -1
  32. package/dist/assets/{linear-Dfad58q_.js → linear-B_kP7XTY.js} +1 -1
  33. package/dist/assets/{liquid-CEkxMSzk.js → liquid-Bz_nlZQO.js} +1 -1
  34. package/dist/assets/{lspLanguageFeatures-0mffeVGX.js → lspLanguageFeatures-Bfs5KZ7t.js} +1 -1
  35. package/dist/assets/{mdx-B-Qq5FgQ.js → mdx-DREXNfTL.js} +1 -1
  36. package/dist/assets/{mermaid.core-DDK6pwbH.js → mermaid.core-Qb_9exf_.js} +4 -4
  37. package/dist/assets/{mindmap-definition-8da855dc-CyIw0Vtn.js → mindmap-definition-8da855dc-BVneYgpV.js} +1 -1
  38. package/dist/assets/{pieDiagram-a8764435-DCdqfk2w.js → pieDiagram-a8764435-BnFEaAoD.js} +1 -1
  39. package/dist/assets/{python-CMoFKB7x.js → python-BaegM-qN.js} +1 -1
  40. package/dist/assets/{quadrantDiagram-1e28029f-mXna6sR0.js → quadrantDiagram-1e28029f-DwwRhwu5.js} +1 -1
  41. package/dist/assets/{razor-B6DD072n.js → razor-EZlNrkt1.js} +1 -1
  42. package/dist/assets/{requirementDiagram-08caed73-DgC33PUx.js → requirementDiagram-08caed73-CrOXjwl9.js} +1 -1
  43. package/dist/assets/{sankeyDiagram-a04cb91d-6DjDiGF1.js → sankeyDiagram-a04cb91d-BmrPbz9p.js} +1 -1
  44. package/dist/assets/{sequenceDiagram-c5b8d532-BHEC8MLz.js → sequenceDiagram-c5b8d532-KIdevHfA.js} +1 -1
  45. package/dist/assets/{stateDiagram-1ecb1508-CnQIc7IJ.js → stateDiagram-1ecb1508-Bvt_x0JW.js} +1 -1
  46. package/dist/assets/{stateDiagram-v2-c2b004d7-DyYVXqRY.js → stateDiagram-v2-c2b004d7-Ch7JhULG.js} +1 -1
  47. package/dist/assets/{styles-b4e223ce-BCRMXdaJ.js → styles-b4e223ce-CGsc8vM4.js} +1 -1
  48. package/dist/assets/{styles-ca3715f6-B0Uke183.js → styles-ca3715f6-D-kXthxO.js} +1 -1
  49. package/dist/assets/{styles-d45a18b0-CTIOlm5f.js → styles-d45a18b0-ByiElCZx.js} +1 -1
  50. package/dist/assets/{svgDrawCommon-b86b1483-DIsUSZPw.js → svgDrawCommon-b86b1483-BBAC26Ym.js} +1 -1
  51. package/dist/assets/{timeline-definition-faaaa080-Dioszvxi.js → timeline-definition-faaaa080-yHkv8c9O.js} +1 -1
  52. package/dist/assets/{tsMode-C8qimCsh.js → tsMode-CxUP_h7m.js} +1 -1
  53. package/dist/assets/{typescript-DIHO7TTQ.js → typescript-DK75tgf9.js} +1 -1
  54. package/dist/assets/{xml-DE5CGUCp.js → xml-CKJB1DbG.js} +1 -1
  55. package/dist/assets/{xychartDiagram-f5964ef8-bhTIJLJy.js → xychartDiagram-f5964ef8-BBHC7Rzd.js} +1 -1
  56. package/dist/assets/{yaml-Cac2zjUM.js → yaml-CJFgfFzM.js} +1 -1
  57. package/dist/index.html +1 -1
  58. package/package.json +22 -16
  59. package/preview-runtime.cjs +128 -0
  60. package/preview-server.cjs +198 -0
  61. package/AGENTS.md +0 -115
  62. package/dist/assets/channel-_Q_52ef7.js +0 -1
  63. package/dist/assets/clone-BicNByr8.js +0 -1
  64. package/dist/assets/flowDiagram-v2-4f6560a1-CWSRSwc1.js +0 -1
  65. package/index.html +0 -18
  66. package/public/favicon.svg +0 -5
  67. package/public/manifest.webmanifest +0 -30
  68. package/public/pwa-icon-192.png +0 -0
  69. package/public/pwa-icon-512.png +0 -0
  70. package/public/sw.js +0 -105
  71. package/src/App.tsx +0 -40
  72. package/src/api/README.md +0 -27
  73. package/src/api/adapters.ts +0 -63
  74. package/src/api/auth-token.ts +0 -51
  75. package/src/api/auth.ts +0 -46
  76. package/src/api/automation.ts +0 -98
  77. package/src/api/base.ts +0 -166
  78. package/src/api/benchmark.ts +0 -50
  79. package/src/api/config.ts +0 -29
  80. package/src/api/git.ts +0 -90
  81. package/src/api/knowledge.ts +0 -131
  82. package/src/api/projects.ts +0 -15
  83. package/src/api/sessions.ts +0 -281
  84. package/src/api/skill-hub.ts +0 -126
  85. package/src/api/types.ts +0 -21
  86. package/src/api/workspace.ts +0 -51
  87. package/src/api/worktree-environments.ts +0 -53
  88. package/src/api.ts +0 -142
  89. package/src/assets/fonts/material-symbols-rounded.woff2 +0 -0
  90. package/src/client-build-info.ts +0 -19
  91. package/src/components/ArchiveView.scss +0 -257
  92. package/src/components/ArchiveView.tsx +0 -313
  93. package/src/components/CodeBlock.scss +0 -92
  94. package/src/components/CodeBlock.tsx +0 -181
  95. package/src/components/ConfigView.scss +0 -864
  96. package/src/components/ConfigView.tsx +0 -788
  97. package/src/components/MarkdownContent.tsx +0 -50
  98. package/src/components/NavRail.scss +0 -317
  99. package/src/components/NavRail.tsx +0 -198
  100. package/src/components/NavRailCompact.tsx +0 -107
  101. package/src/components/NavRailCompactMoreSheet.tsx +0 -141
  102. package/src/components/ShortcutDisplay.scss +0 -38
  103. package/src/components/ShortcutDisplay.tsx +0 -37
  104. package/src/components/ShortcutTooltip.scss +0 -36
  105. package/src/components/ShortcutTooltip.tsx +0 -86
  106. package/src/components/Sidebar.scss +0 -161
  107. package/src/components/Sidebar.tsx +0 -480
  108. package/src/components/auth/AuthGate.scss +0 -79
  109. package/src/components/auth/AuthGate.tsx +0 -174
  110. package/src/components/automation-view/@components/AutomationTaskComposer.tsx +0 -220
  111. package/src/components/automation-view/@components/AutomationTriggerRow.tsx +0 -192
  112. package/src/components/automation-view/@hooks/use-automation-startup-options-data.tsx +0 -289
  113. package/src/components/automation-view/@hooks/use-automation-startup-static-options.ts +0 -51
  114. package/src/components/automation-view/@utils/sender-model-options.tsx +0 -52
  115. package/src/components/automation-view/@utils/startup-options.ts +0 -26
  116. package/src/components/automation-view/AutomationEmptyGuide.tsx +0 -61
  117. package/src/components/automation-view/AutomationEmptyLanding.scss +0 -165
  118. package/src/components/automation-view/AutomationEmptyLanding.tsx +0 -211
  119. package/src/components/automation-view/AutomationRuleDetailPreview.tsx +0 -179
  120. package/src/components/automation-view/PanelTitleActions.tsx +0 -66
  121. package/src/components/automation-view/RuleFormPanel.scss +0 -279
  122. package/src/components/automation-view/RuleFormPanel.tsx +0 -365
  123. package/src/components/automation-view/RuleSidebar.scss +0 -332
  124. package/src/components/automation-view/RuleSidebar.tsx +0 -338
  125. package/src/components/automation-view/RunHistoryPanel.scss +0 -649
  126. package/src/components/automation-view/RunHistoryPanel.tsx +0 -382
  127. package/src/components/automation-view/TaskList.scss +0 -223
  128. package/src/components/automation-view/TaskList.tsx +0 -67
  129. package/src/components/automation-view/TriggerList.scss +0 -267
  130. package/src/components/automation-view/TriggerList.tsx +0 -68
  131. package/src/components/automation-view/index.scss +0 -230
  132. package/src/components/automation-view/index.tsx +0 -369
  133. package/src/components/automation-view/types.ts +0 -34
  134. package/src/components/benchmark-view/BenchmarkCasePanel.scss +0 -287
  135. package/src/components/benchmark-view/BenchmarkCasePanel.tsx +0 -309
  136. package/src/components/benchmark-view/BenchmarkSidebar.scss +0 -206
  137. package/src/components/benchmark-view/BenchmarkSidebar.tsx +0 -269
  138. package/src/components/benchmark-view/BenchmarkView.scss +0 -121
  139. package/src/components/benchmark-view/index.tsx +0 -237
  140. package/src/components/benchmark-view/types.ts +0 -11
  141. package/src/components/benchmark-view/utils.ts +0 -20
  142. package/src/components/chat/AGENTS.md +0 -177
  143. package/src/components/chat/ChatComposerCard.scss +0 -77
  144. package/src/components/chat/ChatComposerCard.tsx +0 -59
  145. package/src/components/chat/ChatHeader.scss +0 -865
  146. package/src/components/chat/ChatHeader.tsx +0 -832
  147. package/src/components/chat/ChatHistoryView.tsx +0 -887
  148. package/src/components/chat/ChatSettingsView.tsx +0 -24
  149. package/src/components/chat/ChatTimelineView.scss +0 -147
  150. package/src/components/chat/ChatTimelineView.tsx +0 -200
  151. package/src/components/chat/CurrentTodoList.scss +0 -256
  152. package/src/components/chat/CurrentTodoList.tsx +0 -171
  153. package/src/components/chat/NewSessionGuide.scss +0 -416
  154. package/src/components/chat/NewSessionGuide.tsx +0 -69
  155. package/src/components/chat/NewSessionGuideStarterList.tsx +0 -190
  156. package/src/components/chat/NewSessionGuideStarterSection.tsx +0 -121
  157. package/src/components/chat/QueuedMessagesCard.scss +0 -195
  158. package/src/components/chat/QueuedMessagesCard.tsx +0 -170
  159. package/src/components/chat/bottom-dock-constants.ts +0 -4
  160. package/src/components/chat/conversation-starter-apply.ts +0 -181
  161. package/src/components/chat/git-controls/BranchSwitcherDropdown.tsx +0 -162
  162. package/src/components/chat/git-controls/BranchSwitcherResults.tsx +0 -167
  163. package/src/components/chat/git-controls/BranchTreeEntries.tsx +0 -99
  164. package/src/components/chat/git-controls/ChatGitControls.scss +0 -1113
  165. package/src/components/chat/git-controls/ChatGitControls.tsx +0 -178
  166. package/src/components/chat/git-controls/DraftGitControls.tsx +0 -105
  167. package/src/components/chat/git-controls/DraftWorktreeEnvironmentDropdown.tsx +0 -115
  168. package/src/components/chat/git-controls/GitCommitModal.tsx +0 -199
  169. package/src/components/chat/git-controls/GitCommitModalParts.tsx +0 -151
  170. package/src/components/chat/git-controls/GitOperationsDropdown.tsx +0 -131
  171. package/src/components/chat/git-controls/GitPushModal.tsx +0 -106
  172. package/src/components/chat/git-controls/GitWorktreeDropdown.tsx +0 -341
  173. package/src/components/chat/git-controls/git-branch-tree.ts +0 -148
  174. package/src/components/chat/git-controls/git-branch-utils.ts +0 -88
  175. package/src/components/chat/git-controls/git-commit-utils.ts +0 -79
  176. package/src/components/chat/git-controls/git-mutation-utils.ts +0 -69
  177. package/src/components/chat/git-controls/git-operation-utils.ts +0 -98
  178. package/src/components/chat/git-controls/git-worktree-utils.ts +0 -49
  179. package/src/components/chat/git-controls/use-chat-draft-git-controls.ts +0 -168
  180. package/src/components/chat/git-controls/use-chat-git-commit.ts +0 -185
  181. package/src/components/chat/git-controls/use-chat-git-controls.ts +0 -273
  182. package/src/components/chat/git-controls/use-chat-git-push-state.ts +0 -19
  183. package/src/components/chat/git-controls/use-chat-git-worktrees.ts +0 -39
  184. package/src/components/chat/messages/MessageContextMenu.scss +0 -145
  185. package/src/components/chat/messages/MessageContextMenu.tsx +0 -110
  186. package/src/components/chat/messages/MessageContextMenuContent.tsx +0 -87
  187. package/src/components/chat/messages/MessageFooter.tsx +0 -68
  188. package/src/components/chat/messages/MessageItem.scss +0 -486
  189. package/src/components/chat/messages/MessageItem.tsx +0 -529
  190. package/src/components/chat/messages/MessageStatusNotice.scss +0 -163
  191. package/src/components/chat/messages/MessageStatusNotice.tsx +0 -56
  192. package/src/components/chat/messages/build-chat-history-status-notices.ts +0 -143
  193. package/src/components/chat/messages/build-message-context-menu-entries.ts +0 -166
  194. package/src/components/chat/messages/message-action-utils.ts +0 -29
  195. package/src/components/chat/messages/message-content-utils.ts +0 -121
  196. package/src/components/chat/messages/message-turns.ts +0 -88
  197. package/src/components/chat/messages/message-utils.ts +0 -189
  198. package/src/components/chat/new-session-guide-config.ts +0 -19
  199. package/src/components/chat/new-session-guide-items.ts +0 -172
  200. package/src/components/chat/new-session-guide-list-order.ts +0 -58
  201. package/src/components/chat/sender/@components/account-select/AccountSelectControl.scss +0 -112
  202. package/src/components/chat/sender/@components/account-select/AccountSelectControl.tsx +0 -280
  203. package/src/components/chat/sender/@components/account-select/AccountSelectDropdown.scss +0 -155
  204. package/src/components/chat/sender/@components/adapter-select/AdapterSelectControl.scss +0 -148
  205. package/src/components/chat/sender/@components/adapter-select/AdapterSelectControl.tsx +0 -54
  206. package/src/components/chat/sender/@components/adapter-select/AdapterSelectDropdown.scss +0 -56
  207. package/src/components/chat/sender/@components/effort-select/EffortSelectControl.scss +0 -104
  208. package/src/components/chat/sender/@components/effort-select/EffortSelectControl.tsx +0 -142
  209. package/src/components/chat/sender/@components/effort-select/EffortSelectDropdown.scss +0 -96
  210. package/src/components/chat/sender/@components/model-select/ModelSelectControl.scss +0 -144
  211. package/src/components/chat/sender/@components/model-select/ModelSelectControl.tsx +0 -176
  212. package/src/components/chat/sender/@components/model-select/ModelSelectMenu.scss +0 -97
  213. package/src/components/chat/sender/@components/model-select/ModelSelectMenuLabels.scss +0 -168
  214. package/src/components/chat/sender/@components/model-select/ModelSelectOptionLabel.tsx +0 -109
  215. package/src/components/chat/sender/@components/permission-mode-control/PermissionModeControl.scss +0 -199
  216. package/src/components/chat/sender/@components/permission-mode-control/PermissionModeControl.tsx +0 -172
  217. package/src/components/chat/sender/@components/reference-actions/ReferenceActionsControl.scss +0 -114
  218. package/src/components/chat/sender/@components/reference-actions/ReferenceActionsControl.tsx +0 -107
  219. package/src/components/chat/sender/@components/reference-actions/ReferenceActionsOption.scss +0 -34
  220. package/src/components/chat/sender/@components/sender-attachments/SenderAttachments.scss +0 -240
  221. package/src/components/chat/sender/@components/sender-attachments/SenderAttachments.tsx +0 -119
  222. package/src/components/chat/sender/@components/sender-body/SenderBody.tsx +0 -135
  223. package/src/components/chat/sender/@components/sender-header-controls/SenderHeaderControls.tsx +0 -157
  224. package/src/components/chat/sender/@components/sender-interaction-panel/SenderInteractionPanel.scss +0 -294
  225. package/src/components/chat/sender/@components/sender-interaction-panel/SenderInteractionPanel.tsx +0 -384
  226. package/src/components/chat/sender/@components/sender-monaco-editor/SenderMonacoEditor.scss +0 -47
  227. package/src/components/chat/sender/@components/sender-monaco-editor/SenderMonacoEditor.tsx +0 -139
  228. package/src/components/chat/sender/@components/sender-monaco-editor/monaco-runtime.ts +0 -83
  229. package/src/components/chat/sender/@components/sender-monaco-editor/use-sender-editor-handle.ts +0 -48
  230. package/src/components/chat/sender/@components/sender-monaco-editor/use-sender-monaco-editor.ts +0 -286
  231. package/src/components/chat/sender/@components/sender-monaco-editor/use-sender-monaco-theme.ts +0 -73
  232. package/src/components/chat/sender/@components/sender-submit-action/SenderSubmitAction.scss +0 -163
  233. package/src/components/chat/sender/@components/sender-submit-action/SenderSubmitAction.tsx +0 -200
  234. package/src/components/chat/sender/@components/sender-toolbar/SenderSelectBase.scss +0 -108
  235. package/src/components/chat/sender/@components/sender-toolbar/SenderSelectShared.scss +0 -156
  236. package/src/components/chat/sender/@components/sender-toolbar/SenderToolbar.scss +0 -164
  237. package/src/components/chat/sender/@components/sender-toolbar/SenderToolbar.tsx +0 -93
  238. package/src/components/chat/sender/@components/session-target/SenderSessionTargetBar.scss +0 -215
  239. package/src/components/chat/sender/@components/session-target/SenderSessionTargetBar.tsx +0 -185
  240. package/src/components/chat/sender/@core/build-sender-controller-result.ts +0 -119
  241. package/src/components/chat/sender/@core/build-sender-toolbar.ts +0 -151
  242. package/src/components/chat/sender/@core/content-attachments.ts +0 -76
  243. package/src/components/chat/sender/@core/create-sender-toolbar-handlers.ts +0 -142
  244. package/src/components/chat/sender/@core/get-sender-interaction-state.ts +0 -18
  245. package/src/components/chat/sender/@core/get-sender-runtime-state.ts +0 -15
  246. package/src/components/chat/sender/@core/interaction-request.ts +0 -5
  247. package/src/components/chat/sender/@core/sender-toolbar-bindings.ts +0 -191
  248. package/src/components/chat/sender/@hooks/use-model-select-browser.tsx +0 -191
  249. package/src/components/chat/sender/@hooks/use-sender-attachments.ts +0 -143
  250. package/src/components/chat/sender/@hooks/use-sender-autofocus.ts +0 -34
  251. package/src/components/chat/sender/@hooks/use-sender-completion.ts +0 -62
  252. package/src/components/chat/sender/@hooks/use-sender-composer-state.ts +0 -34
  253. package/src/components/chat/sender/@hooks/use-sender-controller.ts +0 -291
  254. package/src/components/chat/sender/@hooks/use-sender-focus-restore.ts +0 -72
  255. package/src/components/chat/sender/@hooks/use-sender-history.ts +0 -79
  256. package/src/components/chat/sender/@hooks/use-sender-keydown.ts +0 -177
  257. package/src/components/chat/sender/@hooks/use-sender-reference-actions.ts +0 -134
  258. package/src/components/chat/sender/@hooks/use-sender-reference-focus-restore.ts +0 -21
  259. package/src/components/chat/sender/@hooks/use-sender-refs.ts +0 -19
  260. package/src/components/chat/sender/@hooks/use-sender-select-overlays.ts +0 -83
  261. package/src/components/chat/sender/@hooks/use-sender-shortcuts.ts +0 -93
  262. package/src/components/chat/sender/@hooks/use-sender-submit.ts +0 -89
  263. package/src/components/chat/sender/@types/sender-composer.ts +0 -19
  264. package/src/components/chat/sender/@types/sender-editor.ts +0 -12
  265. package/src/components/chat/sender/@types/sender-props.ts +0 -82
  266. package/src/components/chat/sender/@types/sender-toolbar-types.ts +0 -101
  267. package/src/components/chat/sender/@types/sender-types.ts +0 -19
  268. package/src/components/chat/sender/@utils/sender-completion.ts +0 -164
  269. package/src/components/chat/sender/@utils/sender-constants.ts +0 -18
  270. package/src/components/chat/sender/@utils/sender-utils.ts +0 -45
  271. package/src/components/chat/sender/Sender.scss +0 -299
  272. package/src/components/chat/sender/Sender.tsx +0 -55
  273. package/src/components/chat/session-metadata.ts +0 -55
  274. package/src/components/chat/session-timeline-panel/EventList.scss +0 -146
  275. package/src/components/chat/session-timeline-panel/EventList.tsx +0 -264
  276. package/src/components/chat/session-timeline-panel/gantt.ts +0 -193
  277. package/src/components/chat/session-timeline-panel/git-graph.ts +0 -530
  278. package/src/components/chat/session-timeline-panel/index.scss +0 -41
  279. package/src/components/chat/session-timeline-panel/index.tsx +0 -197
  280. package/src/components/chat/session-timeline-panel/mermaid.ts +0 -4
  281. package/src/components/chat/session-timeline-panel/types.ts +0 -68
  282. package/src/components/chat/session-timeline-panel/utils.ts +0 -20
  283. package/src/components/chat/status-bar/ChatStatusBar.scss +0 -112
  284. package/src/components/chat/status-bar/ChatStatusBar.tsx +0 -87
  285. package/src/components/chat/terminal/@components/TerminalManagerList.tsx +0 -191
  286. package/src/components/chat/terminal/@components/TerminalPane.scss +0 -71
  287. package/src/components/chat/terminal/@components/TerminalPane.tsx +0 -137
  288. package/src/components/chat/terminal/@components/TerminalPanelActions.tsx +0 -75
  289. package/src/components/chat/terminal/@hooks/use-terminal-instance.ts +0 -188
  290. package/src/components/chat/terminal/@hooks/use-terminal-session.ts +0 -193
  291. package/src/components/chat/terminal/@hooks/use-terminal-title-editor.ts +0 -72
  292. package/src/components/chat/terminal/@utils/terminal-keyboard.ts +0 -141
  293. package/src/components/chat/terminal/@utils/terminal-panes.ts +0 -123
  294. package/src/components/chat/terminal/ChatTerminalView.scss +0 -334
  295. package/src/components/chat/terminal/ChatTerminalView.tsx +0 -192
  296. package/src/components/chat/tools/DefaultTool.tsx +0 -102
  297. package/src/components/chat/tools/adapter-claude/BashTool.scss +0 -87
  298. package/src/components/chat/tools/adapter-claude/BashTool.tsx +0 -116
  299. package/src/components/chat/tools/adapter-claude/ClaudeEditDiff.tsx +0 -30
  300. package/src/components/chat/tools/adapter-claude/GenericClaudeTool.scss +0 -128
  301. package/src/components/chat/tools/adapter-claude/GenericClaudeTool.tsx +0 -119
  302. package/src/components/chat/tools/adapter-claude/GlobTool.scss +0 -9
  303. package/src/components/chat/tools/adapter-claude/GlobTool.tsx +0 -65
  304. package/src/components/chat/tools/adapter-claude/GrepTool.scss +0 -9
  305. package/src/components/chat/tools/adapter-claude/GrepTool.tsx +0 -95
  306. package/src/components/chat/tools/adapter-claude/LSTool.scss +0 -6
  307. package/src/components/chat/tools/adapter-claude/LSTool.tsx +0 -94
  308. package/src/components/chat/tools/adapter-claude/ReadTool.scss +0 -1
  309. package/src/components/chat/tools/adapter-claude/ReadTool.tsx +0 -65
  310. package/src/components/chat/tools/adapter-claude/TodoTool.scss +0 -63
  311. package/src/components/chat/tools/adapter-claude/TodoTool.tsx +0 -73
  312. package/src/components/chat/tools/adapter-claude/WriteTool.scss +0 -44
  313. package/src/components/chat/tools/adapter-claude/WriteTool.tsx +0 -50
  314. package/src/components/chat/tools/adapter-claude/claude-tool-edit-builders.ts +0 -109
  315. package/src/components/chat/tools/adapter-claude/claude-tool-field-sections.tsx +0 -83
  316. package/src/components/chat/tools/adapter-claude/claude-tool-operation-builders.ts +0 -135
  317. package/src/components/chat/tools/adapter-claude/claude-tool-presentation.ts +0 -61
  318. package/src/components/chat/tools/adapter-claude/claude-tool-shared.ts +0 -185
  319. package/src/components/chat/tools/adapter-claude/claude-tool-summary.ts +0 -76
  320. package/src/components/chat/tools/adapter-claude/claude-tool-system-builders.ts +0 -125
  321. package/src/components/chat/tools/adapter-claude/claude-tool-task-builders.ts +0 -148
  322. package/src/components/chat/tools/adapter-claude/components/FileList.scss +0 -67
  323. package/src/components/chat/tools/adapter-claude/components/FileList.tsx +0 -185
  324. package/src/components/chat/tools/adapter-claude/index.ts +0 -31
  325. package/src/components/chat/tools/adapter-claude/utils.ts +0 -54
  326. package/src/components/chat/tools/core/ToolCallBox.scss +0 -700
  327. package/src/components/chat/tools/core/ToolCallBox.tsx +0 -77
  328. package/src/components/chat/tools/core/ToolDiffViewer.scss +0 -138
  329. package/src/components/chat/tools/core/ToolDiffViewer.tsx +0 -166
  330. package/src/components/chat/tools/core/ToolGroup.scss +0 -171
  331. package/src/components/chat/tools/core/ToolGroup.tsx +0 -156
  332. package/src/components/chat/tools/core/ToolRenderer.tsx +0 -47
  333. package/src/components/chat/tools/core/ToolResultContent.tsx +0 -66
  334. package/src/components/chat/tools/core/ToolSummaryHeader.tsx +0 -67
  335. package/src/components/chat/tools/core/generic-tool-presentation.ts +0 -661
  336. package/src/components/chat/tools/core/tool-content-presence.ts +0 -57
  337. package/src/components/chat/tools/core/tool-display.ts +0 -203
  338. package/src/components/chat/tools/core/tool-field-sections.tsx +0 -132
  339. package/src/components/chat/tools/core/tool-result-content-utils.ts +0 -171
  340. package/src/components/chat/tools/core/tool-summary.ts +0 -206
  341. package/src/components/chat/tools/defineToolRender.ts +0 -28
  342. package/src/components/chat/tools/plugin-chrome-devtools/ChromeDevtoolsTool.scss +0 -11
  343. package/src/components/chat/tools/plugin-chrome-devtools/ChromeDevtoolsTool.tsx +0 -81
  344. package/src/components/chat/tools/plugin-chrome-devtools/index.ts +0 -45
  345. package/src/components/chat/tools/task/GetTaskInfoTool.scss +0 -25
  346. package/src/components/chat/tools/task/GetTaskInfoTool.tsx +0 -115
  347. package/src/components/chat/tools/task/ListTasksTool.scss +0 -31
  348. package/src/components/chat/tools/task/ListTasksTool.tsx +0 -99
  349. package/src/components/chat/tools/task/StartTasksTool.scss +0 -31
  350. package/src/components/chat/tools/task/StartTasksTool.tsx +0 -106
  351. package/src/components/chat/tools/task/components/TaskRow.scss +0 -105
  352. package/src/components/chat/tools/task/components/TaskRow.tsx +0 -163
  353. package/src/components/chat/tools/task/components/TaskToolCard.scss +0 -185
  354. package/src/components/chat/tools/task/components/TaskToolCard.tsx +0 -179
  355. package/src/components/chat/tools/task/index.ts +0 -15
  356. package/src/components/chat/workspace-drawer/ChatWorkspaceDrawer.scss +0 -778
  357. package/src/components/chat/workspace-drawer/ChatWorkspaceDrawer.tsx +0 -112
  358. package/src/components/chat/workspace-drawer/ChatWorkspaceDrawerToolbar.tsx +0 -183
  359. package/src/components/chat/workspace-drawer/WorkspaceDrawerChangedFileRow.tsx +0 -75
  360. package/src/components/chat/workspace-drawer/WorkspaceDrawerChangedFiles.tsx +0 -161
  361. package/src/components/chat/workspace-drawer/WorkspaceDrawerChangedFolderTree.tsx +0 -191
  362. package/src/components/chat/workspace-drawer/WorkspaceDrawerTree.tsx +0 -35
  363. package/src/components/chat/workspace-drawer/WorkspaceDrawerTreeState.tsx +0 -17
  364. package/src/components/chat/workspace-drawer/changed-files-model.ts +0 -152
  365. package/src/components/chat/workspace-drawer/workspace-drawer-icons.ts +0 -110
  366. package/src/components/chat/workspace-file-editor/WorkspaceFileBreadcrumb.tsx +0 -17
  367. package/src/components/chat/workspace-file-editor/WorkspaceFileEditorView.scss +0 -283
  368. package/src/components/chat/workspace-file-editor/WorkspaceFileEditorView.tsx +0 -165
  369. package/src/components/chat/workspace-file-editor/WorkspaceFileTabs.tsx +0 -135
  370. package/src/components/chat/workspace-file-editor/use-workspace-file-editor-state.ts +0 -113
  371. package/src/components/chat/workspace-file-editor/workspace-file-editor-language.ts +0 -55
  372. package/src/components/composer-landing/ComposerLanding.scss +0 -75
  373. package/src/components/composer-landing/ComposerLanding.tsx +0 -47
  374. package/src/components/config/AGENTS.md +0 -45
  375. package/src/components/config/AdapterAccountsManager.scss +0 -540
  376. package/src/components/config/AdapterAccountsManager.tsx +0 -846
  377. package/src/components/config/AppSettingsPanel.tsx +0 -109
  378. package/src/components/config/ConfigAboutSection.scss +0 -117
  379. package/src/components/config/ConfigAboutSection.tsx +0 -104
  380. package/src/components/config/ConfigDisplayValue.scss +0 -22
  381. package/src/components/config/ConfigDisplayValue.tsx +0 -62
  382. package/src/components/config/ConfigEditors.scss +0 -91
  383. package/src/components/config/ConfigEditors.tsx +0 -98
  384. package/src/components/config/ConfigFieldRow.scss +0 -221
  385. package/src/components/config/ConfigFieldRow.tsx +0 -36
  386. package/src/components/config/ConfigSectionForm.scss +0 -185
  387. package/src/components/config/ConfigSectionForm.tsx +0 -1264
  388. package/src/components/config/ConfigSectionPanel.tsx +0 -250
  389. package/src/components/config/ConfigShortcutInput.scss +0 -11
  390. package/src/components/config/ConfigShortcutInput.tsx +0 -59
  391. package/src/components/config/ConfigSourceSwitch.tsx +0 -49
  392. package/src/components/config/DetailCollectionFieldActions.tsx +0 -63
  393. package/src/components/config/DetailListField.tsx +0 -413
  394. package/src/components/config/McpServerItemEditor.tsx +0 -154
  395. package/src/components/config/RecommendedModelsItemEditor.tsx +0 -146
  396. package/src/components/config/WorktreeEnvironmentDetailView.tsx +0 -126
  397. package/src/components/config/WorktreeEnvironmentListView.tsx +0 -126
  398. package/src/components/config/WorktreeEnvironmentPanel.scss +0 -430
  399. package/src/components/config/WorktreeEnvironmentPanel.tsx +0 -147
  400. package/src/components/config/WorktreeEnvironmentScriptEditorCard.tsx +0 -125
  401. package/src/components/config/WorktreeEnvironmentScriptEditors.tsx +0 -189
  402. package/src/components/config/channelDefinitions.ts +0 -6
  403. package/src/components/config/configConflict.ts +0 -41
  404. package/src/components/config/configDetail.ts +0 -381
  405. package/src/components/config/configSchema.ts +0 -1017
  406. package/src/components/config/configUtils.ts +0 -83
  407. package/src/components/config/index.tsx +0 -5
  408. package/src/components/config/record-editors/BooleanRecordEditor.scss +0 -1
  409. package/src/components/config/record-editors/BooleanRecordEditor.tsx +0 -75
  410. package/src/components/config/record-editors/ChannelRecordEditor.scss +0 -1
  411. package/src/components/config/record-editors/ChannelRecordEditor.tsx +0 -397
  412. package/src/components/config/record-editors/KeyValueEditor.scss +0 -1
  413. package/src/components/config/record-editors/KeyValueEditor.tsx +0 -97
  414. package/src/components/config/record-editors/McpServersRecordEditor.scss +0 -1
  415. package/src/components/config/record-editors/McpServersRecordEditor.tsx +0 -260
  416. package/src/components/config/record-editors/ModelServicesRecordEditor.scss +0 -1
  417. package/src/components/config/record-editors/ModelServicesRecordEditor.tsx +0 -265
  418. package/src/components/config/record-editors/RecordEditors.scss +0 -335
  419. package/src/components/config/record-editors/RecordJsonEditor.scss +0 -1
  420. package/src/components/config/record-editors/RecordJsonEditor.tsx +0 -140
  421. package/src/components/config/record-editors/SchemaObjectEditor.tsx +0 -183
  422. package/src/components/config/record-editors/SchemaRecordEditor.tsx +0 -184
  423. package/src/components/config/record-editors/index.tsx +0 -7
  424. package/src/components/config/record-editors/schemaRecordUtils.ts +0 -55
  425. package/src/components/config/use-worktree-environment-auto-save.ts +0 -386
  426. package/src/components/config/worktree-environment-panel-model.ts +0 -108
  427. package/src/components/dock-panel/DockPanel.scss +0 -223
  428. package/src/components/dock-panel/DockPanel.tsx +0 -194
  429. package/src/components/dock-panel/DockPanelHeader.tsx +0 -65
  430. package/src/components/dock-panel/use-dock-panel-fullscreen.ts +0 -51
  431. package/src/components/knowledge-base/KnowledgeBaseView.scss +0 -431
  432. package/src/components/knowledge-base/KnowledgeBaseView.tsx +0 -512
  433. package/src/components/knowledge-base/components/@hooks/use-skills-cli-modal-controller.ts +0 -157
  434. package/src/components/knowledge-base/components/@hooks/use-skills-tab-actions.ts +0 -63
  435. package/src/components/knowledge-base/components/ActionButton.scss +0 -35
  436. package/src/components/knowledge-base/components/ActionButton.tsx +0 -19
  437. package/src/components/knowledge-base/components/CreateSkillModal.tsx +0 -59
  438. package/src/components/knowledge-base/components/EmptyState.scss +0 -18
  439. package/src/components/knowledge-base/components/EmptyState.tsx +0 -42
  440. package/src/components/knowledge-base/components/EntitiesTab.scss +0 -5
  441. package/src/components/knowledge-base/components/EntitiesTab.tsx +0 -86
  442. package/src/components/knowledge-base/components/EntityItem.scss +0 -89
  443. package/src/components/knowledge-base/components/EntityItem.tsx +0 -79
  444. package/src/components/knowledge-base/components/EntityList.scss +0 -8
  445. package/src/components/knowledge-base/components/EntityList.tsx +0 -70
  446. package/src/components/knowledge-base/components/FilterBar.scss +0 -33
  447. package/src/components/knowledge-base/components/FilterBar.tsx +0 -55
  448. package/src/components/knowledge-base/components/FlowsTab.scss +0 -5
  449. package/src/components/knowledge-base/components/FlowsTab.tsx +0 -86
  450. package/src/components/knowledge-base/components/KnowledgeBaseHeader.scss +0 -6
  451. package/src/components/knowledge-base/components/KnowledgeBaseHeader.tsx +0 -25
  452. package/src/components/knowledge-base/components/KnowledgeContentControls.tsx +0 -35
  453. package/src/components/knowledge-base/components/KnowledgeList.scss +0 -39
  454. package/src/components/knowledge-base/components/KnowledgeList.tsx +0 -19
  455. package/src/components/knowledge-base/components/KnowledgeMobilePanel.tsx +0 -122
  456. package/src/components/knowledge-base/components/KnowledgeSidebar.tsx +0 -97
  457. package/src/components/knowledge-base/components/LoadingState.scss +0 -10
  458. package/src/components/knowledge-base/components/LoadingState.tsx +0 -11
  459. package/src/components/knowledge-base/components/MetaList.scss +0 -19
  460. package/src/components/knowledge-base/components/MetaList.tsx +0 -18
  461. package/src/components/knowledge-base/components/ProjectSkillsList.tsx +0 -79
  462. package/src/components/knowledge-base/components/RuleItem.scss +0 -86
  463. package/src/components/knowledge-base/components/RuleItem.tsx +0 -81
  464. package/src/components/knowledge-base/components/RuleList.scss +0 -8
  465. package/src/components/knowledge-base/components/RuleList.tsx +0 -70
  466. package/src/components/knowledge-base/components/RulesTab.scss +0 -5
  467. package/src/components/knowledge-base/components/RulesTab.tsx +0 -81
  468. package/src/components/knowledge-base/components/SectionHeader.scss +0 -19
  469. package/src/components/knowledge-base/components/SectionHeader.tsx +0 -19
  470. package/src/components/knowledge-base/components/SkillArchiveInput.tsx +0 -43
  471. package/src/components/knowledge-base/components/SkillHubResultItem.tsx +0 -112
  472. package/src/components/knowledge-base/components/SkillMarketResults.tsx +0 -98
  473. package/src/components/knowledge-base/components/SkillMarketView.tsx +0 -198
  474. package/src/components/knowledge-base/components/SkillMarketView.types.ts +0 -28
  475. package/src/components/knowledge-base/components/SkillRegistryErrors.tsx +0 -21
  476. package/src/components/knowledge-base/components/SkillRegistryModal.tsx +0 -74
  477. package/src/components/knowledge-base/components/SkillsCliModal.tsx +0 -154
  478. package/src/components/knowledge-base/components/SkillsTab.scss +0 -429
  479. package/src/components/knowledge-base/components/SkillsTab.tsx +0 -185
  480. package/src/components/knowledge-base/components/SkillsTabActions.tsx +0 -88
  481. package/src/components/knowledge-base/components/SpecItem.scss +0 -147
  482. package/src/components/knowledge-base/components/SpecItem.tsx +0 -131
  483. package/src/components/knowledge-base/components/SpecList.scss +0 -8
  484. package/src/components/knowledge-base/components/SpecList.tsx +0 -70
  485. package/src/components/knowledge-base/components/TabContent.scss +0 -9
  486. package/src/components/knowledge-base/components/TabContent.tsx +0 -17
  487. package/src/components/knowledge-base/components/TabLabel.scss +0 -10
  488. package/src/components/knowledge-base/components/TabLabel.tsx +0 -15
  489. package/src/components/knowledge-base/components/skill-hub-utils.ts +0 -108
  490. package/src/components/knowledge-base/components/use-skill-market-filters.ts +0 -37
  491. package/src/components/knowledge-base/components/use-skill-market-query-input.ts +0 -44
  492. package/src/components/knowledge-base/components/use-skill-market-search.ts +0 -49
  493. package/src/components/knowledge-base/components/use-skill-registry-modal.ts +0 -68
  494. package/src/components/knowledge-base/index.tsx +0 -1
  495. package/src/components/layout/@hooks/use-mobile-sidebar-modal.ts +0 -190
  496. package/src/components/layout/AppShell.scss +0 -157
  497. package/src/components/layout/AppShell.tsx +0 -168
  498. package/src/components/layout/PageShell.scss +0 -41
  499. package/src/components/layout/PageShell.tsx +0 -32
  500. package/src/components/layout/mobile-sidebar-constants.ts +0 -1
  501. package/src/components/monaco/monaco-runtime.ts +0 -44
  502. package/src/components/monaco/use-monaco-theme.ts +0 -63
  503. package/src/components/nav-rail-account-actions.tsx +0 -104
  504. package/src/components/nav-rail-compact-config.ts +0 -114
  505. package/src/components/nav-rail-items.tsx +0 -181
  506. package/src/components/server-connection/ServerConnectionGate.scss +0 -356
  507. package/src/components/server-connection/ServerConnectionGate.tsx +0 -238
  508. package/src/components/server-connection/ServerConnectionProfileModal.tsx +0 -145
  509. package/src/components/server-connection/ServerConnectionProfiles.tsx +0 -113
  510. package/src/components/server-connection/ServerConnectionUrlInput.tsx +0 -85
  511. package/src/components/sidebar/SessionContextMenu.scss +0 -143
  512. package/src/components/sidebar/SessionContextMenu.tsx +0 -198
  513. package/src/components/sidebar/SessionContextMenuContent.tsx +0 -89
  514. package/src/components/sidebar/SessionItem.scss +0 -417
  515. package/src/components/sidebar/SessionItem.tsx +0 -367
  516. package/src/components/sidebar/SessionList.scss +0 -122
  517. package/src/components/sidebar/SessionList.tsx +0 -187
  518. package/src/components/sidebar/SidebarHeader.scss +0 -372
  519. package/src/components/sidebar/SidebarHeader.tsx +0 -198
  520. package/src/components/sidebar/SidebarHeaderBatchActions.tsx +0 -85
  521. package/src/components/sidebar/SidebarHeaderSearchActions.tsx +0 -175
  522. package/src/components/sidebar/SidebarHeaderSelectField.tsx +0 -24
  523. package/src/components/sidebar/SidebarUtilityFooter.tsx +0 -69
  524. package/src/components/sidebar/filter-utils.ts +0 -23
  525. package/src/components/sidebar/sidebar-search-visibility.ts +0 -18
  526. package/src/components/sidebar-list/SidebarListHeader.scss +0 -246
  527. package/src/components/sidebar-list/SidebarListHeader.tsx +0 -146
  528. package/src/components/workspace/ContextFilePicker.scss +0 -47
  529. package/src/components/workspace/ContextFilePicker.tsx +0 -97
  530. package/src/components/workspace/context-file-types.ts +0 -36
  531. package/src/components/workspace/project-file-tree/ProjectFileTree.scss +0 -298
  532. package/src/components/workspace/project-file-tree/ProjectFileTree.tsx +0 -138
  533. package/src/components/workspace/project-file-tree/ProjectFileTreeRow.tsx +0 -167
  534. package/src/components/workspace/project-file-tree/ProjectFileTreeRowContextMenu.tsx +0 -106
  535. package/src/components/workspace/project-file-tree/ProjectFileTreeRows.tsx +0 -139
  536. package/src/components/workspace/project-file-tree/project-file-tree-helpers.ts +0 -101
  537. package/src/components/workspace/project-file-tree/project-file-tree-icons.ts +0 -93
  538. package/src/components/workspace/project-file-tree/project-file-tree-types.ts +0 -27
  539. package/src/components/workspace/project-file-tree/use-project-file-tree-data.ts +0 -197
  540. package/src/components/workspace/project-file-tree/use-project-file-tree-selection.ts +0 -144
  541. package/src/connectionManager.ts +0 -174
  542. package/src/hooks/chat/chat-session-target.ts +0 -69
  543. package/src/hooks/chat/chat-session-workspace-draft.ts +0 -32
  544. package/src/hooks/chat/interaction-state.ts +0 -125
  545. package/src/hooks/chat/model-selector-data-builders.ts +0 -146
  546. package/src/hooks/chat/model-selector-data-option-utils.ts +0 -62
  547. package/src/hooks/chat/model-selector-data-types.ts +0 -27
  548. package/src/hooks/chat/model-selector-data.ts +0 -109
  549. package/src/hooks/chat/model-selector-recommendations.ts +0 -69
  550. package/src/hooks/chat/model-selector.ts +0 -153
  551. package/src/hooks/chat/optimistic-session-creation.ts +0 -189
  552. package/src/hooks/chat/session-view-cache.ts +0 -83
  553. package/src/hooks/chat/use-chat-adapter-account-selection.tsx +0 -156
  554. package/src/hooks/chat/use-chat-adapter.ts +0 -97
  555. package/src/hooks/chat/use-chat-effort.ts +0 -55
  556. package/src/hooks/chat/use-chat-interaction.ts +0 -31
  557. package/src/hooks/chat/use-chat-model-adapter-selection.tsx +0 -562
  558. package/src/hooks/chat/use-chat-models.tsx +0 -347
  559. package/src/hooks/chat/use-chat-permission-mode.ts +0 -55
  560. package/src/hooks/chat/use-chat-route-bottom-panel.ts +0 -181
  561. package/src/hooks/chat/use-chat-route-deep-link-view.ts +0 -33
  562. package/src/hooks/chat/use-chat-scroll.ts +0 -68
  563. package/src/hooks/chat/use-chat-session-actions.ts +0 -520
  564. package/src/hooks/chat/use-chat-session-messages.ts +0 -607
  565. package/src/hooks/chat/use-chat-session.ts +0 -183
  566. package/src/hooks/chat/use-chat-view.ts +0 -59
  567. package/src/hooks/chat/use-composer-control-shortcuts.ts +0 -69
  568. package/src/hooks/chat/use-terminal-dock-visibility.ts +0 -39
  569. package/src/hooks/chat/workspace-file-panel-state.ts +0 -43
  570. package/src/hooks/session-subscription-cache.ts +0 -25
  571. package/src/hooks/use-app-preferences.ts +0 -51
  572. package/src/hooks/use-chat-layout-query-state.ts +0 -29
  573. package/src/hooks/use-responsive-layout.ts +0 -115
  574. package/src/hooks/use-roving-focus-list.ts +0 -104
  575. package/src/hooks/use-sender-header-query-state.ts +0 -35
  576. package/src/hooks/use-session-subscription.ts +0 -144
  577. package/src/hooks/use-sidebar-navigation.ts +0 -40
  578. package/src/hooks/use-sidebar-query-state.ts +0 -79
  579. package/src/hooks/useGlobalShortcut.ts +0 -26
  580. package/src/hooks/useQueryParams.ts +0 -124
  581. package/src/i18n-resources.ts +0 -44
  582. package/src/i18n.ts +0 -37
  583. package/src/main.tsx +0 -60
  584. package/src/pwa.ts +0 -46
  585. package/src/resources/adapters.ts +0 -46
  586. package/src/resources/locales/en.json +0 -1972
  587. package/src/resources/locales/zh.json +0 -1973
  588. package/src/routes/AppRoutes.tsx +0 -22
  589. package/src/routes/ArchiveRoute.tsx +0 -5
  590. package/src/routes/AutomationRoute.tsx +0 -5
  591. package/src/routes/BenchmarkRoute.tsx +0 -5
  592. package/src/routes/ChatRoute.scss +0 -529
  593. package/src/routes/ChatRoute.tsx +0 -40
  594. package/src/routes/ChatRouteBottomPanel.tsx +0 -47
  595. package/src/routes/ChatRouteView.tsx +0 -199
  596. package/src/routes/ConfigRoute.tsx +0 -5
  597. package/src/routes/KnowledgeRoute.tsx +0 -5
  598. package/src/runtime-config.ts +0 -239
  599. package/src/server-connection-history.ts +0 -179
  600. package/src/store/index.ts +0 -173
  601. package/src/styles/global.scss +0 -113
  602. package/src/styles/material-symbols-rounded.scss +0 -23
  603. package/src/utils/chat-links.ts +0 -21
  604. package/src/utils/copy.ts +0 -18
  605. package/src/utils/mobile-viewport.ts +0 -67
  606. package/src/utils/safe-serialize.ts +0 -84
  607. package/src/utils/shortcutUtils.ts +0 -198
  608. package/src/utils/strip-ansi.ts +0 -26
  609. package/src/version-compatibility.ts +0 -37
  610. package/src/vite-env.d.ts +0 -33
  611. package/src/ws.ts +0 -47
  612. package/vite.config.ts +0 -127
@@ -1,206 +0,0 @@
1
- /* eslint-disable max-lines */
2
-
3
- import type { ChatMessageContent } from '@vibe-forge/core'
4
-
5
- import {
6
- buildClaudeToolPresentation,
7
- getClaudeToolBaseName,
8
- isClaudeToolName
9
- } from '../adapter-claude/claude-tool-presentation'
10
- import { getClaudeToolSummaryText } from '../adapter-claude/claude-tool-summary'
11
- import { buildGenericToolPresentation } from './generic-tool-presentation'
12
-
13
- export type ToolUseItem = Extract<ChatMessageContent, { type: 'tool_use' }>
14
- type Translate = (key: string, options?: Record<string, unknown>) => string
15
-
16
- const HUMANIZED_SEGMENT_SEPARATOR = /[_:-]+/g
17
- const GENERIC_TOOL_NAMESPACE_PREFIXES = new Set(['adapter', 'agent', 'mcp', 'plugin', 'tool'])
18
-
19
- const humanizeToolSegment = (value: string) =>
20
- value
21
- .replace(HUMANIZED_SEGMENT_SEPARATOR, ' ')
22
- .replace(/([a-z0-9])([A-Z])/g, '$1 $2')
23
- .trim()
24
-
25
- const getToolNameSegments = (name: string) => (
26
- name.includes('__') ? name.split('__').filter(Boolean) : name.split(':').filter(Boolean)
27
- )
28
-
29
- export const formatToolName = (name: string) => {
30
- if (name.startsWith('mcp__ChromeDevtools__')) {
31
- return name.replace('mcp__ChromeDevtools__', '')
32
- }
33
-
34
- const namespaceSegments = name.includes('__') ? name.split('__').filter(Boolean) : []
35
- const lastSegment = namespaceSegments.length > 0
36
- ? namespaceSegments[namespaceSegments.length - 1]
37
- : name.split(':').pop() ?? name
38
- return humanizeToolSegment(lastSegment)
39
- }
40
-
41
- export const getToolInputPreview = (input: unknown) => {
42
- if (input == null || typeof input !== 'object' || Array.isArray(input)) {
43
- return undefined
44
- }
45
-
46
- const record = input as Record<string, unknown>
47
- const preferredKeys = [
48
- 'file_path',
49
- 'path',
50
- 'url',
51
- 'query',
52
- 'pattern',
53
- 'command',
54
- 'selector',
55
- 'taskId',
56
- 'subject',
57
- 'skill',
58
- 'title'
59
- ]
60
-
61
- for (const key of preferredKeys) {
62
- const value = record[key]
63
- if (typeof value === 'string' && value.trim() !== '') {
64
- return value.trim().split('\n')[0]
65
- }
66
- }
67
-
68
- for (const value of Object.values(record)) {
69
- if (typeof value === 'string' && value.trim() !== '') {
70
- return value.trim().split('\n')[0]
71
- }
72
- }
73
-
74
- return undefined
75
- }
76
-
77
- export function getToolSummaryText(item: ToolUseItem, t: Translate) {
78
- if (isClaudeToolName(item.name)) {
79
- return getClaudeToolSummaryText(item.name, item.input, t)
80
- }
81
-
82
- const presentation = buildGenericToolPresentation(item.name, item.input)
83
- const displayName = presentation.titleKey != null
84
- ? t(presentation.titleKey, { defaultValue: presentation.fallbackTitle })
85
- : presentation.fallbackTitle
86
- const preview = presentation.primary ?? getToolInputPreview(item.input)
87
- return preview != null && preview !== '' ? `${displayName} ${preview}` : displayName
88
- }
89
-
90
- export function getToolTitleText(item: ToolUseItem, t: Translate) {
91
- if (isClaudeToolName(item.name)) {
92
- const presentation = buildClaudeToolPresentation(item.name, item.input)
93
- return t(presentation.titleKey, { defaultValue: presentation.fallbackTitle })
94
- }
95
-
96
- const presentation = buildGenericToolPresentation(item.name, item.input)
97
- return presentation.titleKey != null
98
- ? t(presentation.titleKey, { defaultValue: presentation.fallbackTitle })
99
- : presentation.fallbackTitle
100
- }
101
-
102
- export function getToolPrimaryText(item: ToolUseItem) {
103
- if (isClaudeToolName(item.name)) {
104
- return buildClaudeToolPresentation(item.name, item.input).primary
105
- }
106
-
107
- return buildGenericToolPresentation(item.name, item.input).primary ?? getToolInputPreview(item.input)
108
- }
109
-
110
- const getToolNamespaceLabel = (name: string) => {
111
- const namespaceSegments = getToolNameSegments(name)
112
- .slice(0, -1)
113
- .filter((segment, index) => !(index === 0 && GENERIC_TOOL_NAMESPACE_PREFIXES.has(segment.toLowerCase())))
114
- .map(humanizeToolSegment)
115
- .filter(Boolean)
116
-
117
- return namespaceSegments.length > 0 ? namespaceSegments.join(' ') : undefined
118
- }
119
-
120
- const getToolQualifiedLabel = (name: string, fallbackLabel: string) => {
121
- const namespaceLabel = getToolNamespaceLabel(name)
122
- return namespaceLabel != null && namespaceLabel !== ''
123
- ? `${namespaceLabel} ${fallbackLabel}`
124
- : fallbackLabel
125
- }
126
-
127
- interface ToolGroupDescriptor {
128
- key: string
129
- label: string
130
- qualifiedLabel: string
131
- }
132
-
133
- function getToolGroupDescriptor(item: ToolUseItem, t: Translate): ToolGroupDescriptor {
134
- if (isClaudeToolName(item.name)) {
135
- const baseName = getClaudeToolBaseName(item.name)
136
- const presentation = buildClaudeToolPresentation(item.name, item.input)
137
- const label = t(presentation.titleKey, { defaultValue: presentation.fallbackTitle })
138
- return {
139
- key: `claude:${baseName}`,
140
- label,
141
- qualifiedLabel: label
142
- }
143
- }
144
-
145
- const presentation = buildGenericToolPresentation(item.name, item.input)
146
- const label = presentation.titleKey != null
147
- ? t(presentation.titleKey, { defaultValue: presentation.fallbackTitle })
148
- : presentation.fallbackTitle
149
- return {
150
- key: item.name,
151
- label,
152
- qualifiedLabel: getToolQualifiedLabel(item.name, label)
153
- }
154
- }
155
-
156
- export function getToolGroupSummaryText(
157
- items: Array<{
158
- item: ToolUseItem
159
- }>,
160
- t: Translate
161
- ) {
162
- const groupedTools = new Map<string, { label: string; qualifiedLabel: string; count: number }>()
163
-
164
- for (const { item } of items) {
165
- const descriptor = getToolGroupDescriptor(item, t)
166
- const label = descriptor.label
167
- if (label === '') continue
168
-
169
- const current = groupedTools.get(descriptor.key)
170
- if (current != null) {
171
- current.count += 1
172
- continue
173
- }
174
-
175
- groupedTools.set(descriptor.key, {
176
- label,
177
- qualifiedLabel: descriptor.qualifiedLabel,
178
- count: 1
179
- })
180
- }
181
-
182
- const groups = Array.from(groupedTools.values())
183
- const labelCounts = groups.reduce((map, group) => {
184
- map.set(group.label, (map.get(group.label) ?? 0) + 1)
185
- return map
186
- }, new Map<string, number>())
187
-
188
- if (groups.length === 0) {
189
- return t('chat.usedTools', { count: items.length })
190
- }
191
-
192
- const summaries = groups.map((group) => {
193
- const name = (labelCounts.get(group.label) ?? 0) > 1 ? group.qualifiedLabel : group.label
194
- return {
195
- count: group.count,
196
- text: t('chat.tools.groupSummaryCount', { name, count: group.count })
197
- }
198
- })
199
-
200
- const visible = summaries.slice(0, 2).map(summary => summary.text)
201
- const hiddenCallCount = summaries.slice(2).reduce((count, summary) => count + summary.count, 0)
202
-
203
- return hiddenCallCount > 0
204
- ? [...visible, t('chat.tools.groupSummaryMoreCount', { count: hiddenCallCount })].join(' · ')
205
- : visible.join(' · ')
206
- }
@@ -1,28 +0,0 @@
1
- import type { ChatMessageContent } from '@vibe-forge/core'
2
- import type React from 'react'
3
-
4
- export interface ToolRenderProps {
5
- item: Extract<ChatMessageContent, { type: 'tool_use' }>
6
- resultItem?: Extract<ChatMessageContent, { type: 'tool_result' }>
7
- }
8
-
9
- export type ToolRenderComponent = React.ComponentType<ToolRenderProps>
10
-
11
- export function defineToolRender<T extends ToolRenderComponent>(render: T) {
12
- return render
13
- }
14
-
15
- export function defineToolRenders(
16
- renders: Record<string, ToolRenderComponent>,
17
- options?: { namespace?: string }
18
- ) {
19
- const namespace = options?.namespace
20
- const entries = Object.entries(renders).flatMap(([name, renderer]) => {
21
- const current: Array<[string, ToolRenderComponent]> = [[name, renderer]]
22
- if (namespace) {
23
- current.push([`${namespace}${name}`, renderer])
24
- }
25
- return current
26
- })
27
- return Object.fromEntries(entries) as Record<string, ToolRenderComponent>
28
- }
@@ -1,11 +0,0 @@
1
- .chrome-devtools-tool {
2
- &__icon {
3
- color: unset;
4
- }
5
-
6
- .tool-content {
7
- display: flex;
8
- flex-direction: column;
9
- gap: 12px;
10
- }
11
- }
@@ -1,81 +0,0 @@
1
- import './ChromeDevtoolsTool.scss'
2
- import { Tooltip } from 'antd'
3
- import React from 'react'
4
- import { useTranslation } from 'react-i18next'
5
-
6
- import { CodeBlock } from '#~/components/CodeBlock'
7
- import { safeJsonStringify } from '#~/utils/safe-serialize'
8
- import { ToolCallBox } from '../core/ToolCallBox'
9
- import { ToolResultContent } from '../core/ToolResultContent'
10
- import { ToolSummaryHeader } from '../core/ToolSummaryHeader'
11
- import { hasMeaningfulToolValue } from '../core/tool-content-presence'
12
- import { TOOL_TOOLTIP_PROPS, getToolSectionIcon, getToolTargetPresentation } from '../core/tool-display'
13
- import { getToolPrimaryText, getToolTitleText } from '../core/tool-summary'
14
- import { defineToolRender } from '../defineToolRender'
15
-
16
- export const ChromeDevtoolsTool = defineToolRender(({ item, resultItem }) => {
17
- const { t } = useTranslation()
18
- const input = item.input != null ? item.input : {}
19
- const hasCallDetails = hasMeaningfulToolValue(input)
20
- const hasResultDetails = resultItem != null && hasMeaningfulToolValue(resultItem.content)
21
- const hasDetails = hasCallDetails || hasResultDetails
22
- const titleText = getToolTitleText(item, t)
23
- const targetPresentation = getToolTargetPresentation(getToolPrimaryText(item))
24
- const errorMeta = resultItem?.is_error === true
25
- ? (
26
- <span className='tool-status tool-status--error'>
27
- <span className='material-symbols-rounded'>error</span>
28
- </span>
29
- )
30
- : undefined
31
-
32
- return (
33
- <div className='tool-group tool-group--compact chrome-devtools-tool'>
34
- <ToolCallBox
35
- variant='inline'
36
- defaultExpanded={false}
37
- collapsible={hasDetails}
38
- header={({ isExpanded, isCollapsible }) => (
39
- <ToolSummaryHeader
40
- icon={<i className='devicon-chrome-plain colored' />}
41
- title={titleText}
42
- target={targetPresentation.text}
43
- targetTitle={targetPresentation.title}
44
- targetMonospace={targetPresentation.monospace}
45
- expanded={isExpanded}
46
- collapsible={isCollapsible}
47
- meta={errorMeta}
48
- metaTitle={errorMeta == null ? undefined : t('chat.result')}
49
- />
50
- )}
51
- content={hasDetails
52
- ? (
53
- <div className='tool-detail-sections'>
54
- {hasCallDetails && (
55
- <div className='tool-detail-section'>
56
- <div className='tool-detail-section__header'>
57
- <Tooltip title={t('chat.tools.call')} {...TOOL_TOOLTIP_PROPS}>
58
- <span className='tool-detail-section__icon material-symbols-rounded'>
59
- {getToolSectionIcon('call')}
60
- </span>
61
- </Tooltip>
62
- </div>
63
- <CodeBlock
64
- code={safeJsonStringify(input, 2)}
65
- lang='json'
66
- hideHeader={true}
67
- />
68
- </div>
69
- )}
70
- {hasResultDetails && resultItem != null && (
71
- <div className='tool-detail-section'>
72
- <ToolResultContent content={resultItem.content} />
73
- </div>
74
- )}
75
- </div>
76
- )
77
- : null}
78
- />
79
- </div>
80
- )
81
- })
@@ -1,45 +0,0 @@
1
- import type { ChromeDevtoolsToolName } from '@vibe-forge/plugin-chrome-devtools/schema'
2
-
3
- import type { ToolRenderComponent } from '../defineToolRender'
4
- import { defineToolRenders } from '../defineToolRender'
5
- import { ChromeDevtoolsTool } from './ChromeDevtoolsTool'
6
-
7
- const chromeDevtoolsToolNames: ChromeDevtoolsToolName[] = [
8
- 'mcp__ChromeDevtools__click',
9
- 'mcp__ChromeDevtools__close_page',
10
- 'mcp__ChromeDevtools__drag',
11
- 'mcp__ChromeDevtools__emulate',
12
- 'mcp__ChromeDevtools__evaluate_script',
13
- 'mcp__ChromeDevtools__fill',
14
- 'mcp__ChromeDevtools__fill_form',
15
- 'mcp__ChromeDevtools__get_console_message',
16
- 'mcp__ChromeDevtools__get_network_request',
17
- 'mcp__ChromeDevtools__handle_dialog',
18
- 'mcp__ChromeDevtools__hover',
19
- 'mcp__ChromeDevtools__list_console_messages',
20
- 'mcp__ChromeDevtools__list_network_requests',
21
- 'mcp__ChromeDevtools__list_pages',
22
- 'mcp__ChromeDevtools__navigate_page',
23
- 'mcp__ChromeDevtools__new_page',
24
- 'mcp__ChromeDevtools__performance_analyze_insight',
25
- 'mcp__ChromeDevtools__performance_start_trace',
26
- 'mcp__ChromeDevtools__performance_stop_trace',
27
- 'mcp__ChromeDevtools__press_key',
28
- 'mcp__ChromeDevtools__resize_page',
29
- 'mcp__ChromeDevtools__select_page',
30
- 'mcp__ChromeDevtools__take_memory_snapshot',
31
- 'mcp__ChromeDevtools__take_screenshot',
32
- 'mcp__ChromeDevtools__take_snapshot',
33
- 'mcp__ChromeDevtools__type_text',
34
- 'mcp__ChromeDevtools__upload_file',
35
- 'mcp__ChromeDevtools__wait_for'
36
- ]
37
-
38
- const chromeDevtoolsToolEntries = chromeDevtoolsToolNames.reduce<Record<string, ToolRenderComponent>>((acc, name) => {
39
- acc[name] = ChromeDevtoolsTool
40
- return acc
41
- }, {})
42
-
43
- export const chromeDevtoolsToolRenders = defineToolRenders(chromeDevtoolsToolEntries)
44
-
45
- export { ChromeDevtoolsTool }
@@ -1,25 +0,0 @@
1
- .tool-group.get-task-info-tool {
2
- border-color: color-mix(
3
- in srgb,
4
- var(--border-color) 55%,
5
- var(--primary-color) 45%
6
- );
7
-
8
- & .tool-call-header {
9
- background: linear-gradient(
10
- 90deg,
11
- color-mix(in srgb, var(--tag-bg) 80%, var(--primary-color) 20%),
12
- var(--tag-bg)
13
- );
14
- }
15
-
16
- &__empty {
17
- margin: 0;
18
- padding: 8px 10px;
19
- border: 1px dashed var(--border-color);
20
- border-radius: 8px;
21
- font-size: 12px;
22
- color: var(--sub-text-color);
23
- background: var(--bg-color);
24
- }
25
- }
@@ -1,115 +0,0 @@
1
- import './GetTaskInfoTool.scss'
2
-
3
- import type { ToolInputs } from '@vibe-forge/core'
4
- import React, { useMemo } from 'react'
5
- import { useTranslation } from 'react-i18next'
6
-
7
- import { ToolCallBox } from '../core/ToolCallBox'
8
- import { ToolSummaryHeader } from '../core/ToolSummaryHeader'
9
- import { getToolTargetPresentation } from '../core/tool-display'
10
- import { defineToolRender } from '../defineToolRender'
11
- import { TaskRow } from './components/TaskRow'
12
-
13
- interface TaskResult {
14
- taskId: string
15
- status?: 'running' | 'completed' | 'failed'
16
- exitCode?: number | null
17
- description?: string
18
- type?: 'default' | 'spec' | 'entity'
19
- name?: string | null
20
- adapter?: string | null
21
- background?: boolean
22
- logs?: string[] | null
23
- }
24
-
25
- export const GetTaskInfoTool = defineToolRender(({ item, resultItem }) => {
26
- const { t } = useTranslation()
27
-
28
- const input = (item.input != null ? item.input : {}) as Partial<ToolInputs['GetTaskInfo']>
29
- const inputTaskId = input.taskId
30
-
31
- const taskResult = useMemo(() => {
32
- if (!resultItem?.content) {
33
- return null
34
- }
35
- const text = resultItem.content[0].text.trim()
36
- const parsed = JSON.parse(text) as TaskResult[]
37
- return parsed[0] ?? null
38
- }, [resultItem?.content])
39
-
40
- const metaChips = taskResult
41
- ? (() => {
42
- const { exitCode, ...cardMeta } = taskResult
43
- return [
44
- cardMeta.adapter,
45
- cardMeta.type === 'default' ? undefined : cardMeta.type,
46
- cardMeta.name,
47
- cardMeta.status,
48
- exitCode != null ? t('chat.tools.taskExitCode', { code: exitCode }) : undefined,
49
- cardMeta.background === false
50
- ? t('chat.tools.startTasksForeground')
51
- : cardMeta.background === true
52
- ? t('chat.tools.startTasksBackground')
53
- : undefined
54
- ]
55
- })()
56
- : []
57
- const titleFallback = t('chat.tools.task')
58
- const taskIdPresentation = getToolTargetPresentation(taskResult?.taskId ?? inputTaskId)
59
- const errorMeta = resultItem?.is_error === true
60
- ? (
61
- <span className='tool-status tool-status--error'>
62
- <span className='material-symbols-rounded'>error</span>
63
- </span>
64
- )
65
- : undefined
66
-
67
- return (
68
- <div className='tool-group tool-group--compact get-task-info-tool'>
69
- <ToolCallBox
70
- variant='inline'
71
- defaultExpanded={false}
72
- header={({ isExpanded, isCollapsible }) => (
73
- <ToolSummaryHeader
74
- icon={<span className='material-symbols-rounded'>info</span>}
75
- title={t('chat.tools.getTaskInfo')}
76
- target={taskIdPresentation.text}
77
- targetTitle={taskIdPresentation.title}
78
- targetMonospace={taskIdPresentation.monospace}
79
- expanded={isExpanded}
80
- collapsible={isCollapsible}
81
- meta={errorMeta}
82
- metaTitle={errorMeta == null ? undefined : t('chat.result')}
83
- />
84
- )}
85
- content={
86
- <div className='tool-content'>
87
- {taskResult
88
- ? (
89
- (() => {
90
- const { taskId, exitCode, ...cardProps } = taskResult
91
- return (
92
- <TaskRow
93
- description={cardProps.description}
94
- status={cardProps.status}
95
- background={cardProps.background}
96
- sessionId={taskId || inputTaskId}
97
- logs={cardProps.logs}
98
- titleFallback={titleFallback}
99
- metaChips={metaChips}
100
- showExecutionIcon={false}
101
- />
102
- )
103
- })()
104
- )
105
- : (
106
- <div className='get-task-info-tool__empty'>
107
- {t('chat.tools.startTasksEmpty')}
108
- </div>
109
- )}
110
- </div>
111
- }
112
- />
113
- </div>
114
- )
115
- })
@@ -1,31 +0,0 @@
1
- .list-tasks-tool {
2
- border-color: color-mix(
3
- in srgb,
4
- var(--border-color) 55%,
5
- var(--primary-color) 45%
6
- );
7
-
8
- & .tool-call-header {
9
- background: linear-gradient(
10
- 90deg,
11
- color-mix(in srgb, var(--tag-bg) 80%, var(--primary-color) 20%),
12
- var(--tag-bg)
13
- );
14
- }
15
-
16
- &__list {
17
- padding: 0;
18
- display: flex;
19
- flex-direction: column;
20
- gap: 0;
21
- }
22
-
23
- &__empty {
24
- padding: 8px 10px;
25
- border: 1px dashed var(--border-color);
26
- border-radius: 8px;
27
- font-size: 12px;
28
- color: var(--sub-text-color);
29
- background: var(--bg-color);
30
- }
31
- }
@@ -1,99 +0,0 @@
1
- import './ListTasksTool.scss'
2
-
3
- import React, { useMemo } from 'react'
4
- import { useTranslation } from 'react-i18next'
5
-
6
- import { ToolCallBox } from '../core/ToolCallBox'
7
- import { ToolSummaryHeader } from '../core/ToolSummaryHeader'
8
- import { defineToolRender } from '../defineToolRender'
9
- import { TaskRow } from './components/TaskRow'
10
-
11
- interface TaskResult {
12
- taskId: string
13
- status?: 'running' | 'completed' | 'failed'
14
- exitCode?: number | null
15
- description?: string
16
- type?: 'default' | 'spec' | 'entity'
17
- name?: string | null
18
- adapter?: string | null
19
- background?: boolean
20
- logs?: string[] | null
21
- }
22
-
23
- export const ListTasksTool = defineToolRender(({ resultItem }) => {
24
- const { t } = useTranslation()
25
-
26
- const taskResults = useMemo(() => {
27
- if (!resultItem?.content) {
28
- return []
29
- }
30
- const text = resultItem.content[0].text.trim()
31
- return JSON.parse(text) as TaskResult[]
32
- }, [resultItem?.content])
33
- const errorMeta = resultItem?.is_error === true
34
- ? (
35
- <span className='tool-status tool-status--error'>
36
- <span className='material-symbols-rounded'>error</span>
37
- </span>
38
- )
39
- : undefined
40
-
41
- return (
42
- <div className='tool-group tool-group--compact list-tasks-tool'>
43
- <ToolCallBox
44
- variant='inline'
45
- defaultExpanded={false}
46
- header={({ isExpanded, isCollapsible }) => (
47
- <ToolSummaryHeader
48
- icon={<span className='material-symbols-rounded'>list_alt</span>}
49
- title={t('chat.tools.listTasks')}
50
- target={t('chat.tools.taskCount', { count: taskResults.length })}
51
- expanded={isExpanded}
52
- collapsible={isCollapsible}
53
- meta={errorMeta}
54
- metaTitle={errorMeta == null ? undefined : t('chat.result')}
55
- />
56
- )}
57
- content={
58
- <div className='tool-content'>
59
- <div className='list-tasks-tool__list'>
60
- {taskResults.map((task) => {
61
- const { taskId, exitCode, ...cardProps } = task
62
- const metaChips = [
63
- cardProps.adapter,
64
- cardProps.type === 'default' ? undefined : cardProps.type,
65
- cardProps.name,
66
- cardProps.status,
67
- exitCode != null ? t('chat.tools.taskExitCode', { code: exitCode }) : undefined,
68
- cardProps.background === false
69
- ? t('chat.tools.startTasksForeground')
70
- : cardProps.background === true
71
- ? t('chat.tools.startTasksBackground')
72
- : undefined
73
- ]
74
- return (
75
- <TaskRow
76
- key={taskId}
77
- description={cardProps.description}
78
- status={cardProps.status}
79
- background={cardProps.background}
80
- sessionId={taskId}
81
- logs={cardProps.logs}
82
- titleFallback={t('chat.tools.task')}
83
- metaChips={metaChips}
84
- showExecutionIcon={false}
85
- />
86
- )
87
- })}
88
- {taskResults.length === 0 && (
89
- <div className='list-tasks-tool__empty'>
90
- {t('chat.tools.listTasksEmpty')}
91
- </div>
92
- )}
93
- </div>
94
- </div>
95
- }
96
- />
97
- </div>
98
- )
99
- })
@@ -1,31 +0,0 @@
1
- .start-tasks-tool {
2
- border-color: color-mix(
3
- in srgb,
4
- var(--border-color) 55%,
5
- var(--primary-color) 45%
6
- );
7
-
8
- & .tool-call-header {
9
- background: linear-gradient(
10
- 90deg,
11
- color-mix(in srgb, var(--tag-bg) 80%, var(--primary-color) 20%),
12
- var(--tag-bg)
13
- );
14
- }
15
-
16
- &__list {
17
- padding: 0;
18
- display: flex;
19
- flex-direction: column;
20
- gap: 0;
21
- }
22
-
23
- &__empty {
24
- padding: 8px 10px;
25
- border: 1px dashed var(--border-color);
26
- border-radius: 8px;
27
- font-size: 12px;
28
- color: var(--sub-text-color);
29
- background: var(--bg-color);
30
- }
31
- }