@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,347 +0,0 @@
1
- import React, { useCallback, useEffect, useMemo, useState } from 'react'
2
- import { useTranslation } from 'react-i18next'
3
- import useSWR from 'swr'
4
-
5
- import type {
6
- AdapterBuiltinModel,
7
- ConfigResponse,
8
- ModelMetadataConfig,
9
- ModelServiceConfig,
10
- RecommendedModelConfig
11
- } from '@vibe-forge/types'
12
-
13
- import { getConfig } from '#~/api.js'
14
- import {
15
- buildServiceModelSelector,
16
- listServiceModels,
17
- resolveChatModelSelection,
18
- resolveDefaultChatModelSelection,
19
- resolveModelDisplayMetadata,
20
- resolveModelServiceTitle,
21
- resolveServiceModelSelector
22
- } from './model-selector'
23
-
24
- export interface ModelSelectOption {
25
- value: string
26
- label: React.ReactNode
27
- searchText: string
28
- displayLabel: string
29
- }
30
-
31
- export interface ModelSelectGroup {
32
- label: React.ReactNode
33
- options: ModelSelectOption[]
34
- }
35
-
36
- export function useChatModels({
37
- selectedAdapter
38
- }: {
39
- selectedAdapter?: string
40
- } = {}) {
41
- const { t } = useTranslation()
42
- const [selectedModel, setSelectedModel] = useState<string | undefined>(() => {
43
- try {
44
- const raw = localStorage.getItem('vf_chat_selected_model')
45
- return raw == null || raw.trim() === '' ? undefined : raw
46
- } catch {
47
- return undefined
48
- }
49
- })
50
- const { data: configRes } = useSWR<ConfigResponse>('/api/config', getConfig)
51
-
52
- const mergedModelServices = useMemo(() => {
53
- const services = configRes?.sources?.merged?.modelServices
54
- return (services ?? {}) as Record<string, ModelServiceConfig>
55
- }, [configRes?.sources?.merged?.modelServices])
56
-
57
- const mergedModels = useMemo(() => {
58
- const models = configRes?.sources?.merged?.models
59
- return (models ?? {}) as Record<string, ModelMetadataConfig>
60
- }, [configRes?.sources?.merged?.models])
61
-
62
- const recommendedModels = useMemo(() => {
63
- const raw = configRes?.sources?.merged?.general?.recommendedModels
64
- if (!Array.isArray(raw)) return []
65
- return raw.filter((item): item is RecommendedModelConfig => (
66
- item != null && typeof item === 'object' && typeof item.model === 'string' && item.model.trim() !== ''
67
- ))
68
- }, [configRes?.sources?.merged?.general?.recommendedModels])
69
-
70
- const adapterBuiltinModels = useMemo(() => {
71
- const raw = configRes?.sources?.merged?.adapterBuiltinModels
72
- return (raw ?? {}) as Record<string, AdapterBuiltinModel[]>
73
- }, [configRes?.sources?.merged?.adapterBuiltinModels])
74
-
75
- const activeBuiltinModels = useMemo(() => {
76
- if (selectedAdapter && adapterBuiltinModels[selectedAdapter]) {
77
- return { [selectedAdapter]: adapterBuiltinModels[selectedAdapter] }
78
- }
79
- return adapterBuiltinModels
80
- }, [adapterBuiltinModels, selectedAdapter])
81
-
82
- const activeBuiltinModelValues = useMemo(() => (
83
- Object.values(activeBuiltinModels).flat().map(model => model.value)
84
- ), [activeBuiltinModels])
85
-
86
- const builtinModelSet = useMemo(() => {
87
- const set = new Set<string>()
88
- for (const models of Object.values(activeBuiltinModels)) {
89
- for (const m of models) set.add(m.value)
90
- }
91
- return set
92
- }, [activeBuiltinModels])
93
-
94
- const modelServiceEntries = useMemo(() => Object.entries(mergedModelServices), [mergedModelServices])
95
-
96
- const availableServiceModels = useMemo(() => listServiceModels(mergedModelServices), [mergedModelServices])
97
- const hasAvailableModels = availableServiceModels.length > 0 || builtinModelSet.size > 0
98
- const modelToService = useMemo(() => {
99
- const map = new Map<string, { key: string; title: string }>()
100
- for (const entry of availableServiceModels) {
101
- const serviceValue = mergedModelServices[entry.serviceKey]
102
- const serviceTitle = resolveModelServiceTitle({
103
- serviceKey: entry.serviceKey,
104
- service: serviceValue
105
- })
106
- if (!map.has(entry.model)) {
107
- map.set(entry.model, { key: entry.serviceKey, title: serviceTitle })
108
- }
109
- }
110
- return map
111
- }, [availableServiceModels, mergedModelServices])
112
- const defaultModelService = configRes?.sources?.merged?.general?.defaultModelService
113
- const defaultModel = configRes?.sources?.merged?.general?.defaultModel
114
- const formatModelWithService = useCallback((model: string | undefined) => {
115
- return resolveChatModelSelection({
116
- value: model,
117
- builtinModels: activeBuiltinModelValues,
118
- serviceModels: availableServiceModels,
119
- defaultModelService
120
- })
121
- }, [activeBuiltinModelValues, availableServiceModels, defaultModelService])
122
- const resolvedDefaultModel = useMemo(() => {
123
- return resolveDefaultChatModelSelection({
124
- defaultModel,
125
- defaultModelService,
126
- builtinModels: activeBuiltinModelValues,
127
- serviceModels: availableServiceModels
128
- })
129
- }, [
130
- activeBuiltinModelValues,
131
- availableServiceModels,
132
- defaultModel,
133
- defaultModelService
134
- ])
135
- const selectedModelWithService = useMemo(() => (
136
- formatModelWithService(selectedModel) ?? resolvedDefaultModel
137
- ), [formatModelWithService, resolvedDefaultModel, selectedModel])
138
-
139
- const resolveSelectableModel = useCallback((value?: string) => {
140
- return resolveChatModelSelection({
141
- value,
142
- builtinModels: activeBuiltinModelValues,
143
- serviceModels: availableServiceModels,
144
- defaultModelService
145
- }) ?? resolvedDefaultModel
146
- }, [activeBuiltinModelValues, availableServiceModels, defaultModelService, resolvedDefaultModel])
147
-
148
- const updateSelectedModel = useCallback((value?: string) => {
149
- setSelectedModel((prev) => {
150
- const nextValue = resolveSelectableModel(value)
151
- return nextValue === prev ? prev : nextValue
152
- })
153
- }, [resolveSelectableModel])
154
-
155
- useEffect(() => {
156
- if (!hasAvailableModels) {
157
- setSelectedModel(undefined)
158
- return
159
- }
160
- setSelectedModel((prev) => resolveSelectableModel(prev))
161
- }, [hasAvailableModels, resolveSelectableModel, selectedAdapter])
162
-
163
- useEffect(() => {
164
- try {
165
- if (selectedModel == null || selectedModel.trim() === '') {
166
- localStorage.removeItem('vf_chat_selected_model')
167
- } else {
168
- localStorage.setItem('vf_chat_selected_model', selectedModel)
169
- }
170
- } catch {
171
- }
172
- }, [selectedModel])
173
-
174
- const modelOptions = useMemo<ModelSelectGroup[]>(() => {
175
- const buildOption = (params: {
176
- value: string
177
- title: string
178
- description?: string
179
- serviceKey?: string
180
- serviceTitle?: string
181
- }) => {
182
- const description = params.description?.trim()
183
- const label = (
184
- <div className='model-option'>
185
- <div className='model-option-title'>{params.title}</div>
186
- {description && <div className='model-option-desc'>{description}</div>}
187
- </div>
188
- )
189
- const searchText = [
190
- params.title,
191
- params.value,
192
- params.serviceTitle,
193
- params.serviceKey,
194
- description
195
- ]
196
- .filter(Boolean)
197
- .join(' ')
198
- return {
199
- value: params.value,
200
- label,
201
- searchText,
202
- displayLabel: params.title
203
- }
204
- }
205
-
206
- const serviceGroups = modelServiceEntries
207
- .map(([serviceKey, serviceValue]) => {
208
- const service = (serviceValue != null && typeof serviceValue === 'object')
209
- ? serviceValue as ModelServiceConfig
210
- : undefined
211
- const serviceTitle = resolveModelServiceTitle({
212
- serviceKey,
213
- service
214
- })
215
- const groupTitle = serviceTitle?.trim() !== '' ? serviceTitle : serviceKey
216
- const serviceDescription = service?.description
217
- const models = Array.isArray(service?.models)
218
- ? service.models.filter((item: unknown): item is string => typeof item === 'string')
219
- : []
220
- if (models.length === 0) return null
221
- const options = models.map((model: string) => {
222
- const value = buildServiceModelSelector(serviceKey, model)
223
- const metadata = resolveModelDisplayMetadata({
224
- model: value,
225
- models: mergedModels
226
- })
227
- const title = metadata?.title ?? metadata?.aliases[0] ?? model
228
- const description = metadata?.description ?? serviceTitle
229
- return buildOption({
230
- value,
231
- title,
232
- description,
233
- serviceKey,
234
- serviceTitle
235
- })
236
- })
237
- return {
238
- label: (
239
- <div className='model-group-label'>
240
- <div className='model-group-title'>{groupTitle}</div>
241
- {serviceDescription && <div className='model-group-desc'>{serviceDescription}</div>}
242
- </div>
243
- ),
244
- options
245
- }
246
- })
247
- .filter((item): item is NonNullable<typeof item> => item != null)
248
-
249
- const recommendedOptions = recommendedModels
250
- .filter((item) => {
251
- if (item.placement && item.placement !== 'modelSelector') return false
252
- return resolveServiceModelSelector({
253
- value: item.service ? buildServiceModelSelector(item.service, item.model) : item.model,
254
- serviceModels: availableServiceModels,
255
- preferredServiceKey: item.service ?? defaultModelService
256
- }) != null
257
- })
258
- .map((item) => {
259
- const serviceInfo = item.service ? mergedModelServices[item.service] : undefined
260
- const serviceTitle = item.service
261
- ? resolveModelServiceTitle({
262
- serviceKey: item.service,
263
- service: serviceInfo
264
- })
265
- : modelToService.get(item.model)?.title
266
- const resolvedModel = item.service ? buildServiceModelSelector(item.service, item.model) : item.model
267
- const metadata = resolveModelDisplayMetadata({
268
- model: resolvedModel,
269
- models: mergedModels
270
- })
271
- const title = item.title?.trim() !== ''
272
- ? item.title ?? ''
273
- : (metadata?.title ?? metadata?.aliases[0] ?? item.model)
274
- const description = item.description?.trim() !== ''
275
- ? item.description
276
- : (metadata?.description ?? serviceTitle)
277
- const value = resolveServiceModelSelector({
278
- value: resolvedModel,
279
- serviceModels: availableServiceModels,
280
- preferredServiceKey: item.service ?? defaultModelService
281
- }) ?? item.model
282
- return buildOption({
283
- value,
284
- title,
285
- description,
286
- serviceKey: item.service ?? modelToService.get(item.model)?.key,
287
- serviceTitle
288
- })
289
- })
290
-
291
- const groups = []
292
- if (recommendedOptions.length > 0) {
293
- const recommendedTitle = t('chat.modelGroupRecommended', { defaultValue: '推荐模型' })
294
- groups.push({
295
- label: (
296
- <div className='model-group-label'>
297
- <div className='model-group-title'>{recommendedTitle}</div>
298
- </div>
299
- ),
300
- options: recommendedOptions
301
- })
302
- }
303
-
304
- // Adapter builtin model groups (filtered to active adapter)
305
- for (const [adapterKey, models] of Object.entries(activeBuiltinModels)) {
306
- if (!Array.isArray(models) || models.length === 0) continue
307
- const adapterTitle = t('chat.modelGroupBuiltin', {
308
- adapter: adapterKey,
309
- defaultValue: `${adapterKey} (Default)`
310
- })
311
- groups.push({
312
- label: (
313
- <div className='model-group-label'>
314
- <div className='model-group-title'>{adapterTitle}</div>
315
- </div>
316
- ),
317
- options: models.map(m =>
318
- buildOption({
319
- value: m.value,
320
- title: m.title,
321
- description: m.description
322
- })
323
- )
324
- })
325
- }
326
-
327
- return [...groups, ...serviceGroups]
328
- }, [
329
- activeBuiltinModels,
330
- availableServiceModels,
331
- defaultModelService,
332
- modelToService,
333
- mergedModels,
334
- mergedModelServices,
335
- modelServiceEntries,
336
- recommendedModels,
337
- t
338
- ])
339
-
340
- return {
341
- selectedModel,
342
- selectedModelWithService,
343
- setSelectedModel: updateSelectedModel,
344
- modelOptions,
345
- hasAvailableModels
346
- }
347
- }
@@ -1,55 +0,0 @@
1
- import { useEffect, useMemo, useState } from 'react'
2
- import type { ReactNode } from 'react'
3
-
4
- export type PermissionMode = 'default' | 'acceptEdits' | 'plan' | 'dontAsk' | 'bypassPermissions'
5
-
6
- const PERMISSION_MODE_STORAGE_KEY = 'vf_chat_permission_mode'
7
-
8
- export const isPermissionMode = (value: string): value is PermissionMode => {
9
- return value === 'default' ||
10
- value === 'acceptEdits' ||
11
- value === 'plan' ||
12
- value === 'dontAsk' ||
13
- value === 'bypassPermissions'
14
- }
15
-
16
- export function useChatPermissionMode() {
17
- const [permissionMode, setPermissionMode] = useState<PermissionMode>('default')
18
-
19
- const updatePermissionMode = (value?: string) => {
20
- if (value != null && isPermissionMode(value)) {
21
- setPermissionMode(value)
22
- return
23
- }
24
- setPermissionMode('default')
25
- }
26
-
27
- useEffect(() => {
28
- try {
29
- const raw = localStorage.getItem(PERMISSION_MODE_STORAGE_KEY)
30
- if (raw && isPermissionMode(raw)) {
31
- updatePermissionMode(raw)
32
- }
33
- } catch {}
34
- }, [])
35
-
36
- useEffect(() => {
37
- try {
38
- localStorage.setItem(PERMISSION_MODE_STORAGE_KEY, permissionMode)
39
- } catch {}
40
- }, [permissionMode])
41
-
42
- const permissionModeOptions = useMemo<Array<{ value: PermissionMode; label: ReactNode }>>(() => [
43
- { value: 'default', label: '默认' },
44
- { value: 'acceptEdits', label: '接受编辑' },
45
- { value: 'plan', label: '计划' },
46
- { value: 'dontAsk', label: '不询问' },
47
- { value: 'bypassPermissions', label: '跳过权限' }
48
- ], [])
49
-
50
- return {
51
- permissionMode,
52
- setPermissionMode: updatePermissionMode,
53
- permissionModeOptions
54
- }
55
- }
@@ -1,181 +0,0 @@
1
- import { useEffect, useState } from 'react'
2
-
3
- import type { Session } from '@vibe-forge/core'
4
-
5
- import { updateSession } from '#~/api'
6
-
7
- import {
8
- normalizeWorkspaceFileState,
9
- toSessionWorkspaceFileState,
10
- uniqueNonEmptyPaths
11
- } from './workspace-file-panel-state'
12
- import type { WorkspaceFilePanelState } from './workspace-file-panel-state'
13
-
14
- export type ChatBottomPanelView = 'file' | 'terminal'
15
-
16
- export function useChatRouteBottomPanel({
17
- isTerminalOpen,
18
- session,
19
- setIsTerminalOpen
20
- }: {
21
- isTerminalOpen: boolean
22
- session?: Session
23
- setIsTerminalOpen: (isOpen: boolean) => void
24
- }) {
25
- const initialWorkspaceFileState = normalizeWorkspaceFileState(session?.workspaceFileState)
26
- const [bottomPanelView, setBottomPanelView] = useState<ChatBottomPanelView>('terminal')
27
- const [selectedWorkspaceFilePath, setSelectedWorkspaceFilePath] = useState<string | null>(
28
- initialWorkspaceFileState.selectedPath
29
- )
30
- const [openWorkspaceFilePaths, setOpenWorkspaceFilePaths] = useState<string[]>(initialWorkspaceFileState.openPaths)
31
- const [isWorkspaceFileEditorOpen, setIsWorkspaceFileEditorOpen] = useState(initialWorkspaceFileState.isOpen)
32
- const shouldShowTerminal = isTerminalOpen && bottomPanelView === 'terminal'
33
- const shouldShowFileEditor = isWorkspaceFileEditorOpen && selectedWorkspaceFilePath != null &&
34
- bottomPanelView === 'file'
35
- const shouldShowBottomPanel = shouldShowTerminal || shouldShowFileEditor
36
- const persistedWorkspaceFileStateKey = JSON.stringify(session?.workspaceFileState ?? null)
37
-
38
- useEffect(() => {
39
- const nextState = normalizeWorkspaceFileState(session?.workspaceFileState)
40
- setOpenWorkspaceFilePaths(nextState.openPaths)
41
- setSelectedWorkspaceFilePath(nextState.selectedPath)
42
- setIsWorkspaceFileEditorOpen(nextState.isOpen)
43
- setBottomPanelView(current => {
44
- if (nextState.isOpen && nextState.selectedPath != null) {
45
- return 'file'
46
- }
47
- return current === 'file' ? 'terminal' : current
48
- })
49
- }, [persistedWorkspaceFileStateKey, session?.id])
50
-
51
- const commitWorkspaceFileState = (state: WorkspaceFilePanelState) => {
52
- const nextState = normalizeWorkspaceFileState(state)
53
- setOpenWorkspaceFilePaths(nextState.openPaths)
54
- setSelectedWorkspaceFilePath(nextState.selectedPath)
55
- setIsWorkspaceFileEditorOpen(nextState.isOpen)
56
-
57
- if (session?.id != null) {
58
- void updateSession(session.id, {
59
- workspaceFileState: toSessionWorkspaceFileState(nextState)
60
- }).catch((err: unknown) => {
61
- console.error('[chat] failed to persist workspace file state:', err)
62
- })
63
- }
64
- }
65
-
66
- const handleToggleTerminal = () => {
67
- if (bottomPanelView !== 'terminal') {
68
- setBottomPanelView('terminal')
69
- setIsTerminalOpen(true)
70
- return
71
- }
72
-
73
- setIsTerminalOpen(!isTerminalOpen)
74
- }
75
- const handleOpenWorkspaceFile = (path: string) => {
76
- commitWorkspaceFileState({
77
- openPaths: uniqueNonEmptyPaths([...openWorkspaceFilePaths, path]),
78
- selectedPath: path,
79
- isOpen: true
80
- })
81
- setBottomPanelView('file')
82
- }
83
- const handleCloseWorkspaceFile = () => {
84
- commitWorkspaceFileState({
85
- openPaths: openWorkspaceFilePaths,
86
- selectedPath: selectedWorkspaceFilePath,
87
- isOpen: false
88
- })
89
- if (isTerminalOpen) {
90
- setBottomPanelView('terminal')
91
- }
92
- }
93
- const handleCloseAllWorkspaceFileTabs = () => {
94
- commitWorkspaceFileState({
95
- openPaths: [],
96
- selectedPath: null,
97
- isOpen: false
98
- })
99
- if (isTerminalOpen) {
100
- setBottomPanelView('terminal')
101
- }
102
- }
103
- const handleSelectWorkspaceFile = (path: string) => {
104
- commitWorkspaceFileState({
105
- openPaths: uniqueNonEmptyPaths([...openWorkspaceFilePaths, path]),
106
- selectedPath: path,
107
- isOpen: true
108
- })
109
- setBottomPanelView('file')
110
- }
111
- const handleCloseWorkspaceFileTab = (path: string) => {
112
- const nextPaths = openWorkspaceFilePaths.filter(item => item !== path)
113
- const closedIndex = openWorkspaceFilePaths.indexOf(path)
114
- const nextPath = selectedWorkspaceFilePath === path
115
- ? nextPaths[Math.min(Math.max(closedIndex - 1, 0), nextPaths.length - 1)] ?? null
116
- : selectedWorkspaceFilePath
117
-
118
- commitWorkspaceFileState({
119
- openPaths: nextPaths,
120
- selectedPath: nextPath,
121
- isOpen: isWorkspaceFileEditorOpen && nextPath != null
122
- })
123
-
124
- if (nextPath == null && isTerminalOpen) {
125
- setBottomPanelView('terminal')
126
- }
127
- }
128
- const handleCloseOtherWorkspaceFileTabs = (path: string) => {
129
- if (!openWorkspaceFilePaths.includes(path)) {
130
- return
131
- }
132
-
133
- commitWorkspaceFileState({
134
- openPaths: [path],
135
- selectedPath: path,
136
- isOpen: true
137
- })
138
- setBottomPanelView('file')
139
- }
140
- const handleCloseWorkspaceFileTabsToRight = (path: string) => {
141
- const tabIndex = openWorkspaceFilePaths.indexOf(path)
142
- if (tabIndex < 0) {
143
- return
144
- }
145
-
146
- const nextPaths = openWorkspaceFilePaths.slice(0, tabIndex + 1)
147
- const nextPath = selectedWorkspaceFilePath != null && nextPaths.includes(selectedWorkspaceFilePath)
148
- ? selectedWorkspaceFilePath
149
- : path
150
- commitWorkspaceFileState({
151
- openPaths: nextPaths,
152
- selectedPath: nextPath,
153
- isOpen: isWorkspaceFileEditorOpen && nextPath != null
154
- })
155
- }
156
- const handleCloseTerminal = () => {
157
- setIsTerminalOpen(false)
158
- if (isWorkspaceFileEditorOpen && selectedWorkspaceFilePath != null) {
159
- setBottomPanelView('file')
160
- }
161
- }
162
-
163
- return {
164
- handleCloseAllWorkspaceFileTabs,
165
- handleCloseTerminal,
166
- handleCloseWorkspaceFile,
167
- handleCloseOtherWorkspaceFileTabs,
168
- handleCloseWorkspaceFileTab,
169
- handleCloseWorkspaceFileTabsToRight,
170
- handleOpenWorkspaceFile,
171
- handleSelectWorkspaceFile,
172
- handleToggleTerminal,
173
- openWorkspaceFilePaths,
174
- selectedWorkspaceFilePath,
175
- shouldShowBottomPanel,
176
- shouldShowFileEditor,
177
- shouldShowTerminal
178
- }
179
- }
180
-
181
- export type ChatRouteBottomPanelState = ReturnType<typeof useChatRouteBottomPanel>
@@ -1,33 +0,0 @@
1
- import { useEffect, useRef } from 'react'
2
-
3
- import type { ChatHeaderView } from '#~/components/chat/ChatHeader.js'
4
-
5
- export function useChatRouteDeepLinkView({
6
- activeView,
7
- setActiveView,
8
- targetMessageId,
9
- targetToolUseId
10
- }: {
11
- activeView: ChatHeaderView
12
- setActiveView: (view: ChatHeaderView) => void
13
- targetMessageId?: string
14
- targetToolUseId?: string
15
- }) {
16
- const handledDeepLinkTargetRef = useRef('')
17
- const deepLinkTargetKey = targetToolUseId?.trim()
18
- ? `tool:${targetToolUseId.trim()}`
19
- : targetMessageId?.trim()
20
- ? `message:${targetMessageId.trim()}`
21
- : ''
22
-
23
- useEffect(() => {
24
- if (deepLinkTargetKey === '') {
25
- handledDeepLinkTargetRef.current = ''
26
- } else if (handledDeepLinkTargetRef.current !== deepLinkTargetKey) {
27
- handledDeepLinkTargetRef.current = deepLinkTargetKey
28
- if (activeView !== 'history') {
29
- setActiveView('history')
30
- }
31
- }
32
- }, [activeView, deepLinkTargetKey, setActiveView])
33
- }
@@ -1,68 +0,0 @@
1
- import { useCallback, useEffect, useRef, useState } from 'react'
2
-
3
- const SCROLL_THRESHOLD = 80
4
-
5
- export function useChatScroll({ contentVersion }: { contentVersion: number }) {
6
- const messagesEndRef = useRef<HTMLDivElement>(null)
7
- const messagesContainerRef = useRef<HTMLDivElement>(null)
8
- const messagesContentRef = useRef<HTMLDivElement>(null)
9
- const scrollTimeoutRef = useRef<number | null>(null)
10
- const [showScrollBottom, setShowScrollBottom] = useState(false)
11
-
12
- const updateScrollState = useCallback(() => {
13
- const container = messagesContainerRef.current
14
- if (!container) return
15
- const distanceToBottom = container.scrollHeight - (container.scrollTop + container.clientHeight)
16
- setShowScrollBottom(distanceToBottom > SCROLL_THRESHOLD)
17
- }, [])
18
-
19
- const clearScrollTimeout = useCallback(() => {
20
- if (scrollTimeoutRef.current == null) {
21
- return
22
- }
23
-
24
- window.clearTimeout(scrollTimeoutRef.current)
25
- scrollTimeoutRef.current = null
26
- }, [])
27
-
28
- const scrollToBottom = useCallback((behavior: ScrollBehavior = 'smooth') => {
29
- clearScrollTimeout()
30
- scrollTimeoutRef.current = window.setTimeout(() => {
31
- const container = messagesContainerRef.current
32
- scrollTimeoutRef.current = null
33
- if (!container) {
34
- return
35
- }
36
-
37
- container.scrollTo({
38
- top: container.scrollHeight,
39
- behavior
40
- })
41
- }, 50)
42
- }, [clearScrollTimeout])
43
-
44
- useEffect(() => {
45
- const container = messagesContainerRef.current
46
- if (!container) return
47
- updateScrollState()
48
- const handleScroll = () => updateScrollState()
49
- container.addEventListener('scroll', handleScroll, { passive: true })
50
- return () => {
51
- container.removeEventListener('scroll', handleScroll)
52
- }
53
- }, [updateScrollState])
54
-
55
- useEffect(() => {
56
- updateScrollState()
57
- }, [contentVersion, updateScrollState])
58
-
59
- useEffect(() => clearScrollTimeout, [clearScrollTimeout])
60
-
61
- return {
62
- messagesEndRef,
63
- messagesContainerRef,
64
- messagesContentRef,
65
- showScrollBottom,
66
- scrollToBottom
67
- }
68
- }