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

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-lnVIZjVV.js} +1 -1
  3. package/dist/assets/{blockDiagram-c4efeb88-Si9lNhiR.js → blockDiagram-c4efeb88-CGc3VsM0.js} +1 -1
  4. package/dist/assets/{c4Diagram-c83219d4-CRTN1Bme.js → c4Diagram-c83219d4-KFbHuRdf.js} +1 -1
  5. package/dist/assets/channel-nqRbzJjc.js +1 -0
  6. package/dist/assets/{classDiagram-beda092f-Cn0JFKaM.js → classDiagram-beda092f-CDtKfvQN.js} +1 -1
  7. package/dist/assets/{classDiagram-v2-2358418a-CCRguPFP.js → classDiagram-v2-2358418a-DX8Wj36y.js} +1 -1
  8. package/dist/assets/clone-Dp80x0fP.js +1 -0
  9. package/dist/assets/{createText-1719965b-B7ypMies.js → createText-1719965b-BNBTbGpf.js} +1 -1
  10. package/dist/assets/{cssMode-CGqPieqo.js → cssMode-Ptqm0UgE.js} +1 -1
  11. package/dist/assets/{edges-96097737-DQTQ3TTh.js → edges-96097737-Ddj48nr8.js} +1 -1
  12. package/dist/assets/{erDiagram-0228fc6a-RWH9OCKP.js → erDiagram-0228fc6a-Ctc1Voxl.js} +1 -1
  13. package/dist/assets/{flowDb-c6c81e3f-ChBIZfFE.js → flowDb-c6c81e3f-B3LqoAaB.js} +1 -1
  14. package/dist/assets/{flowDiagram-50d868cf-B5L7Tbzq.js → flowDiagram-50d868cf-HhEHMvI3.js} +1 -1
  15. package/dist/assets/flowDiagram-v2-4f6560a1-BnkEnoEY.js +1 -0
  16. package/dist/assets/{flowchart-elk-definition-6af322e1-B7X89gyf.js → flowchart-elk-definition-6af322e1-BimqA4Ix.js} +1 -1
  17. package/dist/assets/{freemarker2-DG-xlAsn.js → freemarker2-BMLA0JoH.js} +1 -1
  18. package/dist/assets/{ganttDiagram-a2739b55-BedUmaPf.js → ganttDiagram-a2739b55-DbWekIop.js} +1 -1
  19. package/dist/assets/{gitGraphDiagram-82fe8481-B8HGnn-5.js → gitGraphDiagram-82fe8481-DugZXJxL.js} +1 -1
  20. package/dist/assets/{graph-D9-QnVc7.js → graph-BIUNEnmO.js} +1 -1
  21. package/dist/assets/{handlebars-D3MqxNWf.js → handlebars-CaH_OmK8.js} +1 -1
  22. package/dist/assets/{html-DufmGZMV.js → html-CJM7ZGkq.js} +1 -1
  23. package/dist/assets/{htmlMode-CUM_1bUX.js → htmlMode-BG64A-lN.js} +1 -1
  24. package/dist/assets/{index-5325376f-DvDnB8Ym.js → index-5325376f-DowhDAzC.js} +1 -1
  25. package/dist/assets/{index-CFwJnHev.js → index-DE5IhsLX.js} +5 -5
  26. package/dist/assets/{infoDiagram-8eee0895-CEkPslG6.js → infoDiagram-8eee0895-DCFO3Gq3.js} +1 -1
  27. package/dist/assets/{javascript-B6reuW3Q.js → javascript-WPwGMZFk.js} +1 -1
  28. package/dist/assets/{journeyDiagram-c64418c1-c8XBdi4a.js → journeyDiagram-c64418c1-DbnoY6Uo.js} +1 -1
  29. package/dist/assets/{jsonMode-srNnX9pn.js → jsonMode-C7yBbpF1.js} +1 -1
  30. package/dist/assets/{layout-XKv3I9bs.js → layout-C9lYzHQN.js} +1 -1
  31. package/dist/assets/{line-BUKiwgio.js → line-Da8bHZTb.js} +1 -1
  32. package/dist/assets/{linear-Dfad58q_.js → linear-CqRVyBRo.js} +1 -1
  33. package/dist/assets/{liquid-CEkxMSzk.js → liquid-DHZpN37G.js} +1 -1
  34. package/dist/assets/{lspLanguageFeatures-0mffeVGX.js → lspLanguageFeatures-C34m_8ti.js} +1 -1
  35. package/dist/assets/{mdx-B-Qq5FgQ.js → mdx-ChgypGoV.js} +1 -1
  36. package/dist/assets/{mermaid.core-DDK6pwbH.js → mermaid.core-4DaC4St_.js} +4 -4
  37. package/dist/assets/{mindmap-definition-8da855dc-CyIw0Vtn.js → mindmap-definition-8da855dc-hvBUs35M.js} +1 -1
  38. package/dist/assets/{pieDiagram-a8764435-DCdqfk2w.js → pieDiagram-a8764435-KKbynGsZ.js} +1 -1
  39. package/dist/assets/{python-CMoFKB7x.js → python-DssCQx-A.js} +1 -1
  40. package/dist/assets/{quadrantDiagram-1e28029f-mXna6sR0.js → quadrantDiagram-1e28029f-IItmvZDf.js} +1 -1
  41. package/dist/assets/{razor-B6DD072n.js → razor-xXXtaoJF.js} +1 -1
  42. package/dist/assets/{requirementDiagram-08caed73-DgC33PUx.js → requirementDiagram-08caed73-CYZ2UIRt.js} +1 -1
  43. package/dist/assets/{sankeyDiagram-a04cb91d-6DjDiGF1.js → sankeyDiagram-a04cb91d-BWor9f7d.js} +1 -1
  44. package/dist/assets/{sequenceDiagram-c5b8d532-BHEC8MLz.js → sequenceDiagram-c5b8d532-TWiqf82J.js} +1 -1
  45. package/dist/assets/{stateDiagram-1ecb1508-CnQIc7IJ.js → stateDiagram-1ecb1508-ITPwn2Bf.js} +1 -1
  46. package/dist/assets/{stateDiagram-v2-c2b004d7-DyYVXqRY.js → stateDiagram-v2-c2b004d7-YjTlGGeJ.js} +1 -1
  47. package/dist/assets/{styles-b4e223ce-BCRMXdaJ.js → styles-b4e223ce-BdOTgXu7.js} +1 -1
  48. package/dist/assets/{styles-ca3715f6-B0Uke183.js → styles-ca3715f6-DSryl5cS.js} +1 -1
  49. package/dist/assets/{styles-d45a18b0-CTIOlm5f.js → styles-d45a18b0-0wPNzh5D.js} +1 -1
  50. package/dist/assets/{svgDrawCommon-b86b1483-DIsUSZPw.js → svgDrawCommon-b86b1483-Bkv9XWwN.js} +1 -1
  51. package/dist/assets/{timeline-definition-faaaa080-Dioszvxi.js → timeline-definition-faaaa080-CVDgx3Ub.js} +1 -1
  52. package/dist/assets/{tsMode-C8qimCsh.js → tsMode-C7GDZM9j.js} +1 -1
  53. package/dist/assets/{typescript-DIHO7TTQ.js → typescript-B8cSShUe.js} +1 -1
  54. package/dist/assets/{xml-DE5CGUCp.js → xml-CdAKZrLj.js} +1 -1
  55. package/dist/assets/{xychartDiagram-f5964ef8-bhTIJLJy.js → xychartDiagram-f5964ef8-CtgQRYQp.js} +1 -1
  56. package/dist/assets/{yaml-Cac2zjUM.js → yaml-vZ3X6eTz.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,846 +0,0 @@
1
- /* eslint-disable max-lines -- account management keeps list, detail, and action flows in one surface. */
2
- import './AdapterAccountsManager.scss'
3
-
4
- import { App, Button, Empty, Input, Popconfirm, Spin, Tooltip } from 'antd'
5
- import { useMemo, useState } from 'react'
6
- import useSWR from 'swr'
7
-
8
- import type { AdapterAccountActionDescriptor, AdapterAccountInfo, ConfigUiObjectSchema } from '@vibe-forge/types'
9
-
10
- import { getAdapterAccountDetail, getAdapterAccounts, getApiErrorMessage, manageAdapterAccount } from '#~/api'
11
-
12
- import { getFieldDescription, getFieldLabel, getValueByPath, setValueByPath } from './configUtils'
13
- import type { TranslationFn } from './configUtils'
14
- import { SchemaObjectEditor } from './record-editors/SchemaObjectEditor'
15
-
16
- const isRecord = (value: unknown): value is Record<string, unknown> => (
17
- value != null && typeof value === 'object' && !Array.isArray(value)
18
- )
19
-
20
- const ACCOUNT_ACTION_ICON: Record<AdapterAccountActionDescriptor['key'], string> = {
21
- add: 'person_add',
22
- refresh: 'refresh',
23
- remove: 'delete'
24
- }
25
-
26
- const ACCOUNT_STATUS_ICON: Record<NonNullable<AdapterAccountInfo['status']>, string> = {
27
- ready: 'check_circle',
28
- missing: 'warning',
29
- error: 'error'
30
- }
31
-
32
- const getConfiguredAccounts = (value: Record<string, unknown>) => {
33
- const configured = getValueByPath(value, ['accounts'])
34
- return isRecord(configured) ? configured : {}
35
- }
36
-
37
- const getConfiguredAccountEntry = (value: Record<string, unknown>, accountKey: string) => {
38
- const configured = getConfiguredAccounts(value)[accountKey]
39
- return isRecord(configured) ? configured : {}
40
- }
41
-
42
- const setConfiguredAccountEntry = (
43
- value: Record<string, unknown>,
44
- accountKey: string,
45
- nextEntry: Record<string, unknown>
46
- ) => setValueByPath(value, ['accounts', accountKey], nextEntry) as Record<string, unknown>
47
-
48
- const formatStatus = (status: AdapterAccountInfo['status'], t: TranslationFn) => {
49
- switch (status) {
50
- case 'missing':
51
- return {
52
- label: t('config.accounts.status.missing'),
53
- color: 'default' as const,
54
- icon: ACCOUNT_STATUS_ICON.missing
55
- }
56
- case 'error':
57
- return {
58
- label: t('config.accounts.status.error'),
59
- color: 'error' as const,
60
- icon: ACCOUNT_STATUS_ICON.error
61
- }
62
- case 'ready':
63
- default:
64
- return {
65
- label: t('config.accounts.status.ready'),
66
- color: 'success' as const,
67
- icon: ACCOUNT_STATUS_ICON.ready
68
- }
69
- }
70
- }
71
-
72
- const getActionLabel = (action: AdapterAccountActionDescriptor, t: TranslationFn) => (
73
- t(`config.accounts.actions.${action.key}.label`, { defaultValue: action.label })
74
- )
75
-
76
- const getActionDescription = (action: AdapterAccountActionDescriptor, t: TranslationFn) => (
77
- t(`config.accounts.actions.${action.key}.description`, {
78
- defaultValue: action.description ?? action.label
79
- })
80
- )
81
-
82
- const normalizeText = (value: string | undefined) => value?.trim().toLowerCase() ?? ''
83
- const normalizeDisplayText = (value: string | undefined) => value?.trim() ?? ''
84
-
85
- const dedupeDisplayTexts = (...values: Array<string | undefined>) => {
86
- const uniqueValues = new Set<string>()
87
-
88
- return values
89
- .map(normalizeDisplayText)
90
- .filter((value) => {
91
- if (value === '' || uniqueValues.has(value)) return false
92
- uniqueValues.add(value)
93
- return true
94
- })
95
- }
96
-
97
- const parsePercentMetricValue = (value: string | undefined) => {
98
- if (value == null) return undefined
99
-
100
- const normalized = value.trim()
101
- if (!normalized.endsWith('%')) return undefined
102
-
103
- const parsed = Number(normalized.slice(0, -1))
104
- if (!Number.isFinite(parsed)) return undefined
105
-
106
- return Math.min(100, Math.max(0, parsed))
107
- }
108
-
109
- const getPercentRingColor = (percent: number) => {
110
- if (percent >= 85) return 'var(--error-color, #ff4d4f)'
111
- if (percent >= 60) return 'var(--warning-color, #faad14)'
112
- return 'var(--success-color, #52c41a)'
113
- }
114
-
115
- const compareAccountInfo = (
116
- left: Pick<AdapterAccountInfo, 'key' | 'title' | 'status' | 'isDefault'>,
117
- right: Pick<AdapterAccountInfo, 'key' | 'title' | 'status' | 'isDefault'>
118
- ) => {
119
- if (left.isDefault === true && right.isDefault !== true) return -1
120
- if (right.isDefault === true && left.isDefault !== true) return 1
121
-
122
- if (left.status !== right.status) {
123
- if (left.status === 'ready') return -1
124
- if (right.status === 'ready') return 1
125
- }
126
-
127
- const titleOrder = normalizeText(left.title).localeCompare(normalizeText(right.title))
128
- if (titleOrder !== 0) return titleOrder
129
-
130
- return left.key.localeCompare(right.key)
131
- }
132
-
133
- const renderTooltipContent = (label: string, description?: string) => {
134
- const normalizedDescription = description?.trim()
135
- if (normalizedDescription == null || normalizedDescription === '' || normalizedDescription === label) {
136
- return label
137
- }
138
-
139
- return (
140
- <div className='adapter-account-manager__tooltip'>
141
- <div className='adapter-account-manager__tooltip-title'>{label}</div>
142
- <div className='adapter-account-manager__tooltip-description'>{normalizedDescription}</div>
143
- </div>
144
- )
145
- }
146
-
147
- const IconTag = ({
148
- color,
149
- icon,
150
- label,
151
- description
152
- }: {
153
- color?: 'default' | 'success' | 'error'
154
- icon: string
155
- label: string
156
- description?: string
157
- }) => {
158
- const colorStyle = color === 'success'
159
- ? {
160
- color: 'var(--success-color, #52c41a)'
161
- }
162
- : color === 'error'
163
- ? {
164
- color: 'var(--error-color, #ff4d4f)'
165
- }
166
- : undefined
167
-
168
- return (
169
- <Tooltip title={renderTooltipContent(label, description)}>
170
- <span className='adapter-account-manager__icon-tag' style={colorStyle} aria-label={label}>
171
- <span className='material-symbols-rounded' aria-hidden='true'>{icon}</span>
172
- </span>
173
- </Tooltip>
174
- )
175
- }
176
-
177
- const AccountActionButtons = ({
178
- actions,
179
- loadingAction,
180
- onRunAction,
181
- t
182
- }: {
183
- actions: AdapterAccountActionDescriptor[]
184
- loadingAction?: string
185
- onRunAction: (action: AdapterAccountActionDescriptor) => Promise<void>
186
- t: TranslationFn
187
- }) => {
188
- if (actions.length === 0) return null
189
-
190
- return (
191
- <div className='adapter-account-manager__actions'>
192
- {actions.map((action) => {
193
- const label = getActionLabel(action, t)
194
- const description = getActionDescription(action, t)
195
- const icon = ACCOUNT_ACTION_ICON[action.key]
196
-
197
- if (action.key === 'remove') {
198
- return (
199
- <Popconfirm
200
- key={action.key}
201
- title={t('config.accounts.deleteConfirmTitle', {
202
- defaultValue: 'Delete the stored snapshot for {{account}}?',
203
- account: label
204
- })}
205
- okText={t('common.confirm')}
206
- cancelText={t('common.cancel')}
207
- onConfirm={async () => {
208
- await onRunAction(action)
209
- }}
210
- >
211
- <Tooltip title={renderTooltipContent(label, description)}>
212
- <Button
213
- type='default'
214
- size='small'
215
- danger
216
- loading={loadingAction === action.key}
217
- aria-label={label}
218
- className='adapter-account-manager__icon-button adapter-account-manager__header-action'
219
- icon={<span className='material-symbols-rounded'>{icon}</span>}
220
- />
221
- </Tooltip>
222
- </Popconfirm>
223
- )
224
- }
225
-
226
- return (
227
- <Tooltip key={action.key} title={renderTooltipContent(label, description)}>
228
- <Button
229
- type='default'
230
- size='small'
231
- loading={loadingAction === action.key}
232
- aria-label={label}
233
- className='adapter-account-manager__icon-button adapter-account-manager__header-action'
234
- icon={<span className='material-symbols-rounded'>{icon}</span>}
235
- onClick={async () => {
236
- await onRunAction(action)
237
- }}
238
- />
239
- </Tooltip>
240
- )
241
- })}
242
- </div>
243
- )
244
- }
245
-
246
- export const mergeAccounts = (
247
- configured: Record<string, unknown>,
248
- discovered: AdapterAccountInfo[],
249
- defaultAccountKey?: string
250
- ) => {
251
- const merged = new Map<string, AdapterAccountInfo>()
252
-
253
- Object.entries(configured).forEach(([key, entry]) => {
254
- const configuredEntry = isRecord(entry) ? entry : {}
255
- const title = typeof configuredEntry.title === 'string' ? configuredEntry.title.trim() : ''
256
- const description = typeof configuredEntry.description === 'string' ? configuredEntry.description.trim() : ''
257
- merged.set(key, {
258
- key,
259
- title: title !== '' ? title : key,
260
- ...(description !== '' ? { description } : {}),
261
- status: 'missing'
262
- })
263
- })
264
-
265
- discovered.forEach((account) => {
266
- const existing = merged.get(account.key)
267
- merged.set(account.key, {
268
- ...existing,
269
- ...account
270
- })
271
- })
272
-
273
- return [...merged.values()]
274
- .map(account => ({
275
- ...account,
276
- isDefault: defaultAccountKey != null && defaultAccountKey !== ''
277
- ? account.key === defaultAccountKey
278
- : account.isDefault
279
- }))
280
- .sort(compareAccountInfo)
281
- }
282
-
283
- const AccountEditor = ({
284
- adapterKey,
285
- accountKey,
286
- accountItemSchema,
287
- value,
288
- onChange,
289
- t
290
- }: {
291
- adapterKey: string
292
- accountKey: string
293
- accountItemSchema?: ConfigUiObjectSchema
294
- value: Record<string, unknown>
295
- onChange: (nextValue: Record<string, unknown>) => void
296
- t: TranslationFn
297
- }) => {
298
- if (accountItemSchema == null || accountItemSchema.fields.length === 0) {
299
- return null
300
- }
301
-
302
- const editorSchema: ConfigUiObjectSchema = {
303
- ...accountItemSchema,
304
- fields: accountItemSchema.fields.map((field) => {
305
- if (field.path.length === 1 && field.path[0] === 'description') {
306
- return {
307
- ...field,
308
- type: 'multiline'
309
- }
310
- }
311
-
312
- return field
313
- })
314
- }
315
- const defaultAuthFilePath = `.ai/.local/adapters/${adapterKey}/accounts/${accountKey}/auth.json`
316
-
317
- return (
318
- <div className='adapter-account-manager__editor'>
319
- <div className='adapter-account-manager__section-title'>
320
- <span className='material-symbols-rounded'>tune</span>
321
- <span>{t('config.accounts.settingsTitle', { defaultValue: 'Account settings' })}</span>
322
- </div>
323
- <SchemaObjectEditor
324
- value={getConfiguredAccountEntry(value, accountKey)}
325
- schema={editorSchema}
326
- onChange={(nextEntry) => onChange(setConfiguredAccountEntry(value, accountKey, nextEntry))}
327
- t={t}
328
- resolveFieldLabel={(field, fallback) => getFieldLabel(t, 'adapterAccount', field.path, fallback)}
329
- resolveFieldDescription={(field, fallback) => {
330
- const translated = getFieldDescription(t, 'adapterAccount', field.path)
331
- const baseDescription = translated !== '' ? translated : fallback
332
- if (field.path.length === 1 && field.path[0] === 'authFile') {
333
- const defaultLookupHint = t('config.accounts.authFileDefaultLookup', {
334
- defaultValue: 'Leave empty to use {{path}}.',
335
- path: defaultAuthFilePath
336
- })
337
-
338
- return [baseDescription, defaultLookupHint]
339
- .map(item => item.trim())
340
- .filter(item => item !== '')
341
- .join(' ')
342
- }
343
-
344
- return baseDescription
345
- }}
346
- />
347
- </div>
348
- )
349
- }
350
-
351
- const AccountDetailView = ({
352
- adapterKey,
353
- accountKey,
354
- accountItemSchema,
355
- value,
356
- onChange,
357
- onChanged,
358
- onRemoved,
359
- t
360
- }: {
361
- adapterKey: string
362
- accountKey: string
363
- accountItemSchema?: ConfigUiObjectSchema
364
- value: Record<string, unknown>
365
- onChange: (nextValue: Record<string, unknown>) => void
366
- onChanged: () => Promise<void>
367
- onRemoved: () => void
368
- t: TranslationFn
369
- }) => {
370
- const { message } = App.useApp()
371
- const { data, isLoading, mutate } = useSWR(
372
- `/api/adapters/${adapterKey}/accounts/${accountKey}`,
373
- () => getAdapterAccountDetail(adapterKey, accountKey)
374
- )
375
- const [loadingAction, setLoadingAction] = useState<string>()
376
- const detail = data?.account
377
- const statusMeta = formatStatus(detail?.status, t)
378
- const detailActions = (detail?.actions ?? []).filter(action => action.key !== 'refresh')
379
- const quotaMetrics = detail?.quota?.metrics?.filter((metric) => {
380
- if (typeof metric.value === 'string') return metric.value.trim() !== ''
381
- return metric.value != null
382
- }) ?? []
383
-
384
- const handleRunAction = async (action: AdapterAccountActionDescriptor) => {
385
- setLoadingAction(action.key)
386
- try {
387
- const result = await manageAdapterAccount(adapterKey, {
388
- action: action.key,
389
- account: accountKey,
390
- refresh: action.key === 'refresh'
391
- })
392
- await onChanged()
393
- if (action.key === 'remove') {
394
- void message.success(result.message ?? t('config.accounts.actionSuccess.remove'))
395
- onRemoved()
396
- return
397
- }
398
-
399
- if (result.account != null) {
400
- await mutate({ account: result.account }, { revalidate: false })
401
- } else {
402
- const next = await getAdapterAccountDetail(adapterKey, accountKey, { refresh: true })
403
- await mutate(next, { revalidate: false })
404
- }
405
- void message.success(result.message ?? t(`config.accounts.actionSuccess.${action.key}`))
406
- } catch (error) {
407
- void message.error(getApiErrorMessage(error, t(`config.accounts.actionFailed.${action.key}`)))
408
- } finally {
409
- setLoadingAction(undefined)
410
- }
411
- }
412
-
413
- return (
414
- <div className='adapter-account-manager__detail'>
415
- {isLoading && (
416
- <div className='adapter-account-manager__state'>
417
- <Spin size='small' />
418
- </div>
419
- )}
420
-
421
- {!isLoading && detail == null && (
422
- <Empty image={null} description={t('config.accounts.detailMissing')} />
423
- )}
424
-
425
- {detail != null && (
426
- <div className='adapter-account-manager__detail-body'>
427
- <div className='adapter-account-manager__hero'>
428
- <div className='adapter-account-manager__hero-body'>
429
- <div className='adapter-account-manager__hero-title-row'>
430
- <div className='adapter-account-manager__hero-title'>{detail.title}</div>
431
- <div className='adapter-account-manager__hero-meta'>
432
- <div className='adapter-account-manager__hero-badges'>
433
- <IconTag
434
- color={statusMeta.color}
435
- icon={statusMeta.icon}
436
- label={statusMeta.label}
437
- />
438
- {detail.isDefault === true && (
439
- <IconTag
440
- icon='star'
441
- label={t('config.accounts.default')}
442
- />
443
- )}
444
- </div>
445
- {detailActions.length > 0 && (
446
- <AccountActionButtons
447
- actions={detailActions}
448
- loadingAction={loadingAction}
449
- onRunAction={handleRunAction}
450
- t={t}
451
- />
452
- )}
453
- </div>
454
- </div>
455
- </div>
456
- </div>
457
-
458
- {quotaMetrics.length > 0 && (
459
- <div className='adapter-account-manager__section'>
460
- <div className='adapter-account-manager__section-title'>
461
- <span className='material-symbols-rounded'>query_stats</span>
462
- <span>{t('config.accounts.quotaTitle', { defaultValue: 'Quota' })}</span>
463
- </div>
464
- <div className='adapter-account-manager__metrics'>
465
- {quotaMetrics.map(metric => (
466
- <div key={metric.id} className='adapter-account-manager__metric'>
467
- <div className='adapter-account-manager__metric-label'>
468
- {metric.label}
469
- </div>
470
- <div className='adapter-account-manager__metric-value'>
471
- {metric.value ?? '-'}
472
- {(() => {
473
- const percent = parsePercentMetricValue(metric.value)
474
- if (percent == null) return null
475
-
476
- return (
477
- <span
478
- className='adapter-account-manager__metric-ring'
479
- aria-hidden='true'
480
- style={{
481
- background: `conic-gradient(${
482
- getPercentRingColor(percent)
483
- } ${percent}%, color-mix(in srgb, var(--border-color) 72%, transparent) 0)`
484
- }}
485
- >
486
- <span className='adapter-account-manager__metric-ring-inner' />
487
- </span>
488
- )
489
- })()}
490
- </div>
491
- {metric.description != null && metric.description.trim() !== '' && (
492
- <div className='adapter-account-manager__metric-description'>{metric.description}</div>
493
- )}
494
- </div>
495
- ))}
496
- </div>
497
- </div>
498
- )}
499
-
500
- <AccountEditor
501
- adapterKey={adapterKey}
502
- accountKey={accountKey}
503
- accountItemSchema={accountItemSchema}
504
- value={value}
505
- onChange={onChange}
506
- t={t}
507
- />
508
- </div>
509
- )}
510
- </div>
511
- )
512
- }
513
-
514
- const AccountsOverviewCard = ({
515
- accounts,
516
- onOpenAccounts,
517
- t
518
- }: {
519
- accounts: AdapterAccountInfo[]
520
- onOpenAccounts: () => void
521
- t: TranslationFn
522
- }) => {
523
- const readyCount = accounts.filter(account => account.status !== 'missing' && account.status !== 'error').length
524
- const defaultAccount = accounts.find(account => account.isDefault === true)
525
-
526
- return (
527
- <div className='adapter-account-manager__overview'>
528
- <button
529
- type='button'
530
- className='adapter-account-manager__overview-card config-view__field-row'
531
- onClick={onOpenAccounts}
532
- >
533
- <div className='config-view__field-meta'>
534
- <span className='material-symbols-rounded config-view__field-icon'>manage_accounts</span>
535
- <div className='config-view__field-text'>
536
- <div className='config-view__field-title'>{t('config.accounts.title')}</div>
537
- <div className='config-view__field-desc adapter-account-manager__overview-meta'>
538
- <span>{t('config.accounts.count', { count: accounts.length })}</span>
539
- <span>{t('config.accounts.readyCount', { count: readyCount })}</span>
540
- {defaultAccount != null && (
541
- <span>{t('config.accounts.defaultHint', { account: defaultAccount.title })}</span>
542
- )}
543
- </div>
544
- </div>
545
- </div>
546
- <div className='config-view__field-control adapter-account-manager__overview-control'>
547
- <span className='material-symbols-rounded adapter-account-manager__overview-arrow'>chevron_right</span>
548
- </div>
549
- </button>
550
- </div>
551
- )
552
- }
553
-
554
- const AccountsListView = ({
555
- accounts,
556
- actions,
557
- loadingAction,
558
- onOpenAccount,
559
- onRunAction,
560
- currentDefaultAccount,
561
- deletingAccountKey,
562
- onToggleDefaultAccount,
563
- onDeleteAccount,
564
- t
565
- }: {
566
- accounts: AdapterAccountInfo[]
567
- actions: AdapterAccountActionDescriptor[]
568
- loadingAction?: string
569
- onOpenAccount: (accountKey: string) => void
570
- onRunAction: (action: AdapterAccountActionDescriptor) => void
571
- currentDefaultAccount?: string
572
- deletingAccountKey?: string
573
- onToggleDefaultAccount: (accountKey: string) => void
574
- onDeleteAccount: (accountKey: string) => Promise<void>
575
- t: TranslationFn
576
- }) => {
577
- const [searchValue, setSearchValue] = useState('')
578
- const normalizedSearch = normalizeText(searchValue)
579
- const addAction = actions.find(action => action.key === 'add')
580
- const filteredAccounts = useMemo(() => {
581
- if (normalizedSearch === '') return accounts
582
- return accounts.filter(account => {
583
- const haystacks = [
584
- account.title,
585
- account.key,
586
- account.description,
587
- account.quota?.summary
588
- ]
589
- return haystacks.some(value => normalizeText(value).includes(normalizedSearch))
590
- })
591
- }, [accounts, normalizedSearch])
592
-
593
- return (
594
- <div className='adapter-account-manager'>
595
- <div className='adapter-account-manager__header'>
596
- <Input
597
- allowClear
598
- value={searchValue}
599
- onChange={(event) => setSearchValue(event.target.value)}
600
- className='adapter-account-manager__search'
601
- placeholder={t('config.accounts.searchPlaceholder', { defaultValue: 'Search accounts' })}
602
- prefix={<span className='material-symbols-rounded'>search</span>}
603
- />
604
- {addAction != null && (
605
- <Tooltip
606
- title={renderTooltipContent(getActionLabel(addAction, t), getActionDescription(addAction, t))}
607
- >
608
- <Button
609
- size='small'
610
- type='default'
611
- loading={loadingAction === addAction.key}
612
- aria-label={getActionLabel(addAction, t)}
613
- className='adapter-account-manager__icon-button adapter-account-manager__header-action'
614
- icon={<span className='material-symbols-rounded'>{ACCOUNT_ACTION_ICON[addAction.key]}</span>}
615
- onClick={() => onRunAction(addAction)}
616
- />
617
- </Tooltip>
618
- )}
619
- </div>
620
-
621
- {filteredAccounts.length === 0 && (
622
- <Empty
623
- image={null}
624
- description={accounts.length === 0
625
- ? t('config.accounts.empty')
626
- : t('config.accounts.searchEmpty', { defaultValue: 'No matching accounts' })}
627
- />
628
- )}
629
-
630
- {filteredAccounts.length > 0 && (
631
- <div className='adapter-account-manager__list'>
632
- {filteredAccounts.map((account) => {
633
- const isDefault = currentDefaultAccount === account.key || account.isDefault === true
634
- const showDeleteAction = account.status !== 'missing'
635
-
636
- return (
637
- <div key={account.key} className='adapter-account-manager__item'>
638
- <button
639
- type='button'
640
- className='adapter-account-manager__item-trigger'
641
- onClick={() => onOpenAccount(account.key)}
642
- >
643
- <div className='adapter-account-manager__item-main'>
644
- <div className='adapter-account-manager__item-title'>{account.title}</div>
645
- {account.quota?.summary != null && account.quota.summary !== '' && (
646
- <div className='adapter-account-manager__item-description'>
647
- <span className='material-symbols-rounded'>speed</span>
648
- <span>{account.quota.summary}</span>
649
- </div>
650
- )}
651
- </div>
652
- </button>
653
- <div className='adapter-account-manager__item-actions'>
654
- <Tooltip
655
- title={isDefault
656
- ? t('config.accounts.rowActions.clearDefault', { defaultValue: 'Clear default account' })
657
- : t('config.accounts.rowActions.setDefault', { defaultValue: 'Set as default account' })}
658
- >
659
- <Button
660
- type='text'
661
- size='small'
662
- aria-label={isDefault
663
- ? t('config.accounts.rowActions.clearDefault', { defaultValue: 'Clear default account' })
664
- : t('config.accounts.rowActions.setDefault', { defaultValue: 'Set as default account' })}
665
- className={`adapter-account-manager__row-action ${
666
- isDefault ? 'adapter-account-manager__row-action--active' : ''
667
- }`}
668
- icon={<span className='material-symbols-rounded'>star</span>}
669
- onClick={(event) => {
670
- event.stopPropagation()
671
- onToggleDefaultAccount(account.key)
672
- }}
673
- />
674
- </Tooltip>
675
- {showDeleteAction && (
676
- <Popconfirm
677
- title={t('config.accounts.deleteConfirmTitle', {
678
- defaultValue: 'Delete the stored snapshot for {{account}}?',
679
- account: account.title
680
- })}
681
- okText={t('common.confirm')}
682
- cancelText={t('common.cancel')}
683
- onConfirm={async (event) => {
684
- event?.stopPropagation?.()
685
- await onDeleteAccount(account.key)
686
- }}
687
- >
688
- <Button
689
- type='text'
690
- size='small'
691
- danger
692
- loading={deletingAccountKey === account.key}
693
- aria-label={t('config.accounts.rowActions.delete', { defaultValue: 'Delete account snapshot' })}
694
- className='adapter-account-manager__row-action'
695
- icon={<span className='material-symbols-rounded'>delete</span>}
696
- onClick={(event) => {
697
- event.stopPropagation()
698
- }}
699
- />
700
- </Popconfirm>
701
- )}
702
- </div>
703
- </div>
704
- )
705
- })}
706
- </div>
707
- )}
708
- </div>
709
- )
710
- }
711
-
712
- export const AdapterAccountsManager = ({
713
- adapterKey,
714
- value,
715
- accountItemSchema,
716
- nestedPath = [],
717
- onChange,
718
- onOpenNestedPath,
719
- t
720
- }: {
721
- adapterKey: string
722
- value: Record<string, unknown>
723
- accountItemSchema?: ConfigUiObjectSchema
724
- nestedPath?: string[]
725
- onChange: (nextValue: Record<string, unknown>) => void
726
- onOpenNestedPath: (nextPath: string[]) => void
727
- t: TranslationFn
728
- }) => {
729
- const { message } = App.useApp()
730
- const configuredDefaultAccount = typeof value.defaultAccount === 'string' && value.defaultAccount.trim() !== ''
731
- ? value.defaultAccount.trim()
732
- : undefined
733
- const { data, isLoading, mutate } = useSWR(
734
- `/api/adapters/${adapterKey}/accounts`,
735
- () => getAdapterAccounts(adapterKey)
736
- )
737
- const [loadingAction, setLoadingAction] = useState<string>()
738
- const [deletingAccountKey, setDeletingAccountKey] = useState<string>()
739
- const configuredAccounts = useMemo(() => getConfiguredAccounts(value), [value])
740
- const accounts = useMemo(
741
- () => mergeAccounts(configuredAccounts, data?.accounts ?? [], configuredDefaultAccount),
742
- [configuredAccounts, configuredDefaultAccount, data?.accounts]
743
- )
744
- const actionDescriptors = data?.actions ?? []
745
- const isAccountsView = nestedPath[0] === 'accounts'
746
- const activeAccountKey = isAccountsView ? nestedPath[1] : undefined
747
-
748
- const refreshAccounts = async () => {
749
- await mutate()
750
- }
751
-
752
- const handleToggleDefaultAccount = (accountKey: string) => {
753
- const nextValue = { ...value }
754
- if (configuredDefaultAccount === accountKey) {
755
- delete nextValue.defaultAccount
756
- } else {
757
- nextValue.defaultAccount = accountKey
758
- }
759
- onChange(nextValue)
760
- }
761
-
762
- const handleRunListAction = async (action: AdapterAccountActionDescriptor) => {
763
- if (action.key !== 'add') return
764
-
765
- setLoadingAction(action.key)
766
- try {
767
- const result = await manageAdapterAccount(adapterKey, { action: 'add' })
768
- await refreshAccounts()
769
- void message.success(result.message ?? t('config.accounts.actionSuccess.add'))
770
- if (result.accountKey != null && result.accountKey.trim() !== '') {
771
- onOpenNestedPath(['accounts', result.accountKey])
772
- } else {
773
- onOpenNestedPath(['accounts'])
774
- }
775
- } catch (error) {
776
- void message.error(getApiErrorMessage(error, t('config.accounts.actionFailed.add')))
777
- } finally {
778
- setLoadingAction(undefined)
779
- }
780
- }
781
-
782
- const handleDeleteAccount = async (accountKey: string) => {
783
- setDeletingAccountKey(accountKey)
784
- try {
785
- const result = await manageAdapterAccount(adapterKey, {
786
- action: 'remove',
787
- account: accountKey,
788
- refresh: true
789
- })
790
- await refreshAccounts()
791
- void message.success(result.message ?? t('config.accounts.actionSuccess.remove'))
792
- } catch (error) {
793
- void message.error(getApiErrorMessage(error, t('config.accounts.actionFailed.remove')))
794
- } finally {
795
- setDeletingAccountKey(undefined)
796
- }
797
- }
798
-
799
- if (isLoading && accounts.length === 0) {
800
- return (
801
- <div className='adapter-account-manager__state'>
802
- <Spin size='small' />
803
- </div>
804
- )
805
- }
806
-
807
- if (isAccountsView && activeAccountKey != null && activeAccountKey !== '') {
808
- return (
809
- <AccountDetailView
810
- adapterKey={adapterKey}
811
- accountKey={activeAccountKey}
812
- accountItemSchema={accountItemSchema}
813
- value={value}
814
- onChange={onChange}
815
- onChanged={refreshAccounts}
816
- onRemoved={() => onOpenNestedPath(['accounts'])}
817
- t={t}
818
- />
819
- )
820
- }
821
-
822
- if (isAccountsView) {
823
- return (
824
- <AccountsListView
825
- accounts={accounts}
826
- actions={actionDescriptors}
827
- loadingAction={loadingAction}
828
- onOpenAccount={(accountKey) => onOpenNestedPath(['accounts', accountKey])}
829
- onRunAction={handleRunListAction}
830
- currentDefaultAccount={configuredDefaultAccount}
831
- deletingAccountKey={deletingAccountKey}
832
- onToggleDefaultAccount={handleToggleDefaultAccount}
833
- onDeleteAccount={handleDeleteAccount}
834
- t={t}
835
- />
836
- )
837
- }
838
-
839
- return (
840
- <AccountsOverviewCard
841
- accounts={accounts}
842
- onOpenAccounts={() => onOpenNestedPath(['accounts'])}
843
- t={t}
844
- />
845
- )
846
- }