@vibe-forge/client 0.9.0 → 0.10.1

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 (301) hide show
  1. package/AGENTS.md +75 -0
  2. package/dist/assets/abap-DLDM7-KI.js +1 -0
  3. package/dist/assets/apex-DNDY2TF8.js +1 -0
  4. package/dist/assets/{arc-D9HxM0yv.js → arc-C1rWFTer.js} +1 -1
  5. package/dist/assets/azcli-Y6nb8tq_.js +1 -0
  6. package/dist/assets/bat-BwHxbl9M.js +1 -0
  7. package/dist/assets/bicep-CFznDFnq.js +2 -0
  8. package/dist/assets/{blockDiagram-c4efeb88-C_pTeiD4.js → blockDiagram-c4efeb88-DlZ9x70F.js} +1 -1
  9. package/dist/assets/{c4Diagram-c83219d4-_oYrCrLr.js → c4Diagram-c83219d4-BKKxi__y.js} +1 -1
  10. package/dist/assets/cameligo-Bf6VGUru.js +1 -0
  11. package/dist/assets/channel-F1aqMANO.js +1 -0
  12. package/dist/assets/{classDiagram-beda092f-9dnkgPhR.js → classDiagram-beda092f-CVGPySZq.js} +1 -1
  13. package/dist/assets/{classDiagram-v2-2358418a-BUIeZpdO.js → classDiagram-v2-2358418a-7kp8GVVj.js} +1 -1
  14. package/dist/assets/clojure-Dnu-v4kV.js +1 -0
  15. package/dist/assets/clone-B-GCuXNo.js +1 -0
  16. package/dist/assets/codicon-ngg6Pgfi.ttf +0 -0
  17. package/dist/assets/coffee-Bd8akH9Z.js +1 -0
  18. package/dist/assets/cpp-BbWJElDN.js +1 -0
  19. package/dist/assets/{createText-1719965b-DuRFplcD.js → createText-1719965b-Dykv8kT9.js} +1 -1
  20. package/dist/assets/csharp-Co3qMtFm.js +1 -0
  21. package/dist/assets/csp-D-4FJmMZ.js +1 -0
  22. package/dist/assets/css-DdJfP1eB.js +3 -0
  23. package/dist/assets/css.worker-BvV5MPou.js +93 -0
  24. package/dist/assets/cssMode-B59COYVW.js +1 -0
  25. package/dist/assets/cypher-cTPe9QuQ.js +1 -0
  26. package/dist/assets/dart-BOtBlQCF.js +1 -0
  27. package/dist/assets/dockerfile-BG73LgW2.js +1 -0
  28. package/dist/assets/ecl-BEgZUVRK.js +1 -0
  29. package/dist/assets/{edges-96097737-CTpq6Ih_.js → edges-96097737-CkZ1ZBro.js} +1 -1
  30. package/dist/assets/editor.worker-CKy7Pnvo.js +26 -0
  31. package/dist/assets/elixir-BkW5O-1t.js +1 -0
  32. package/dist/assets/{erDiagram-0228fc6a-CWFgdO1E.js → erDiagram-0228fc6a-281ADcRp.js} +1 -1
  33. package/dist/assets/flow9-BeJ5waoc.js +1 -0
  34. package/dist/assets/{flowDb-c6c81e3f-8Vdx29oZ.js → flowDb-c6c81e3f-BQjX_flP.js} +1 -1
  35. package/dist/assets/{flowDiagram-50d868cf-6S9wOVNl.js → flowDiagram-50d868cf-DMHZTjES.js} +1 -1
  36. package/dist/assets/flowDiagram-v2-4f6560a1-C5FzdVl1.js +1 -0
  37. package/dist/assets/{flowchart-elk-definition-6af322e1-DVcZ-ZBQ.js → flowchart-elk-definition-6af322e1-CI3yz4z8.js} +1 -1
  38. package/dist/assets/freemarker2-DWnWjibn.js +3 -0
  39. package/dist/assets/fsharp-PahG7c26.js +1 -0
  40. package/dist/assets/{ganttDiagram-a2739b55-DY1QSl-x.js → ganttDiagram-a2739b55-B3IING9L.js} +1 -1
  41. package/dist/assets/{gitGraphDiagram-82fe8481-BP08OBKL.js → gitGraphDiagram-82fe8481-CnArIr_T.js} +1 -1
  42. package/dist/assets/go-acbASCJo.js +1 -0
  43. package/dist/assets/{graph-D8GCszcN.js → graph-BZ1F0Yve.js} +1 -1
  44. package/dist/assets/graphql-BxJiqAUM.js +1 -0
  45. package/dist/assets/handlebars-C1QH9qTz.js +1 -0
  46. package/dist/assets/hcl-DtV1sZF8.js +1 -0
  47. package/dist/assets/html-D1NkqHjC.js +1 -0
  48. package/dist/assets/html.worker-BLJhxQJQ.js +470 -0
  49. package/dist/assets/htmlMode-DAZCE_rA.js +1 -0
  50. package/dist/assets/{index-5325376f-OOoAXU1u.js → index-5325376f-Da9zSHjA.js} +1 -1
  51. package/dist/assets/index-C0vjF3D0.js +1511 -0
  52. package/dist/assets/index-vzEbM21t.css +32 -0
  53. package/dist/assets/{infoDiagram-8eee0895-BHgkXjhJ.js → infoDiagram-8eee0895-DYbFvRM7.js} +1 -1
  54. package/dist/assets/ini-Kd9XrMLS.js +1 -0
  55. package/dist/assets/java-CXBNlu9o.js +1 -0
  56. package/dist/assets/javascript-CoMjGRHa.js +1 -0
  57. package/dist/assets/{journeyDiagram-c64418c1-BljInElp.js → journeyDiagram-c64418c1-Boebox0b.js} +1 -1
  58. package/dist/assets/json.worker-usMZ-FED.js +58 -0
  59. package/dist/assets/jsonMode-D__gAvuz.js +7 -0
  60. package/dist/assets/julia-cl7-CwDS.js +1 -0
  61. package/dist/assets/kotlin-s7OhZKlX.js +1 -0
  62. package/dist/assets/{layout-Cw-SwAFD.js → layout-CTcHNbHp.js} +1 -1
  63. package/dist/assets/less-9HpZscsL.js +2 -0
  64. package/dist/assets/lexon-OrD6JF1K.js +1 -0
  65. package/dist/assets/{line-Q-uZLuUr.js → line-4AwinCz2.js} +1 -1
  66. package/dist/assets/{linear-BahOnNn3.js → linear-CeSMLzJW.js} +1 -1
  67. package/dist/assets/liquid-DZF6egdE.js +1 -0
  68. package/dist/assets/lspLanguageFeatures-6K4lv5S2.js +4 -0
  69. package/dist/assets/lua-Cyyb5UIc.js +1 -0
  70. package/dist/assets/m3-B8OfTtLu.js +1 -0
  71. package/dist/assets/markdown-BFxVWTOG.js +1 -0
  72. package/dist/assets/mdx-Cnt4ka6w.js +1 -0
  73. package/dist/assets/{mermaid.core-BR0Qh3Rd.js → mermaid.core-B0yG5s4D.js} +6 -6
  74. package/dist/assets/{mindmap-definition-8da855dc-Brq2OJUZ.js → mindmap-definition-8da855dc-KJEvXMKj.js} +1 -1
  75. package/dist/assets/mips-CiqrrVzr.js +1 -0
  76. package/dist/assets/msdax-DmeGPVcC.js +1 -0
  77. package/dist/assets/mysql-C_tMU-Nz.js +1 -0
  78. package/dist/assets/objective-c-BDtDVThU.js +1 -0
  79. package/dist/assets/pascal-vHIfCaH5.js +1 -0
  80. package/dist/assets/pascaligo-DtZ0uQbO.js +1 -0
  81. package/dist/assets/perl-Ub6l9XKa.js +1 -0
  82. package/dist/assets/pgsql-BlNEE0v7.js +1 -0
  83. package/dist/assets/php-BBUBE1dy.js +1 -0
  84. package/dist/assets/{pieDiagram-a8764435-uhYdiXro.js → pieDiagram-a8764435-17nFAXPJ.js} +1 -1
  85. package/dist/assets/pla-DSh2-awV.js +1 -0
  86. package/dist/assets/postiats-CocnycG-.js +1 -0
  87. package/dist/assets/powerquery-tScXyioY.js +1 -0
  88. package/dist/assets/powershell-COWaemsV.js +1 -0
  89. package/dist/assets/protobuf-Brw8urJB.js +2 -0
  90. package/dist/assets/pug-8SOpv6rk.js +1 -0
  91. package/dist/assets/python-DA3TtjDv.js +1 -0
  92. package/dist/assets/qsharp-Bw9ernYp.js +1 -0
  93. package/dist/assets/{quadrantDiagram-1e28029f-TwqtEe7e.js → quadrantDiagram-1e28029f-Dt4vubi-.js} +1 -1
  94. package/dist/assets/r-j7ic8hl3.js +1 -0
  95. package/dist/assets/razor-CWDJgvX_.js +1 -0
  96. package/dist/assets/redis-Bu5POkcn.js +1 -0
  97. package/dist/assets/redshift-Bs9aos_-.js +1 -0
  98. package/dist/assets/{requirementDiagram-08caed73-DSXnPRDS.js → requirementDiagram-08caed73-H6aDyDK-.js} +1 -1
  99. package/dist/assets/restructuredtext-CqXO7rUv.js +1 -0
  100. package/dist/assets/ruby-zBfavPgS.js +1 -0
  101. package/dist/assets/rust-BzKRNQWT.js +1 -0
  102. package/dist/assets/{sankeyDiagram-a04cb91d-EADpJeAn.js → sankeyDiagram-a04cb91d-DxsVtbjI.js} +1 -1
  103. package/dist/assets/sb-BBc9UKZt.js +1 -0
  104. package/dist/assets/scala-D9hQfWCl.js +1 -0
  105. package/dist/assets/scheme-BPhDTwHR.js +1 -0
  106. package/dist/assets/scss-CBJaRo0y.js +3 -0
  107. package/dist/assets/{sequenceDiagram-c5b8d532-C8qXvt9z.js → sequenceDiagram-c5b8d532-BHa148XJ.js} +1 -1
  108. package/dist/assets/shell-DiJ1NA_G.js +1 -0
  109. package/dist/assets/solidity-Db0IVjzk.js +1 -0
  110. package/dist/assets/sophia-CnS9iZB_.js +1 -0
  111. package/dist/assets/sparql-CJmd_6j2.js +1 -0
  112. package/dist/assets/sql-ClhHkBeG.js +1 -0
  113. package/dist/assets/st-CHwy0fLd.js +1 -0
  114. package/dist/assets/{stateDiagram-1ecb1508-5W0ghy_S.js → stateDiagram-1ecb1508-DgwBm8LO.js} +1 -1
  115. package/dist/assets/{stateDiagram-v2-c2b004d7-BfwOQJw4.js → stateDiagram-v2-c2b004d7-BK7IQLVc.js} +1 -1
  116. package/dist/assets/{styles-b4e223ce-EkKH_ULb.js → styles-b4e223ce-DzW27Bc-.js} +1 -1
  117. package/dist/assets/{styles-ca3715f6-DwhrtqlU.js → styles-ca3715f6-Dex2GiLT.js} +1 -1
  118. package/dist/assets/{styles-d45a18b0-yqL8KH6x.js → styles-d45a18b0-B6fGtDKS.js} +1 -1
  119. package/dist/assets/{svgDrawCommon-b86b1483--5VjnjhC.js → svgDrawCommon-b86b1483-B4HYgfV5.js} +1 -1
  120. package/dist/assets/swift-Bqt4WxQ4.js +3 -0
  121. package/dist/assets/systemverilog-Bs9z6M-B.js +1 -0
  122. package/dist/assets/tcl-Dm6ycUr_.js +1 -0
  123. package/dist/assets/{timeline-definition-faaaa080-CWOTwik9.js → timeline-definition-faaaa080--QSbWb25.js} +1 -1
  124. package/dist/assets/ts.worker-DGHjMaqB.js +67731 -0
  125. package/dist/assets/tsMode-ZM7ocZCH.js +11 -0
  126. package/dist/assets/twig-Csy3S7wG.js +1 -0
  127. package/dist/assets/typescript-CKWDmBCc.js +1 -0
  128. package/dist/assets/typespec-Btyra-wh.js +1 -0
  129. package/dist/assets/vb-Db0cS2oM.js +1 -0
  130. package/dist/assets/wgsl-BTesnYfV.js +298 -0
  131. package/dist/assets/xml-DuEUAzPi.js +1 -0
  132. package/dist/assets/{xychartDiagram-f5964ef8-CZg47H1t.js → xychartDiagram-f5964ef8-D09Zkv2K.js} +1 -1
  133. package/dist/assets/yaml-DL7QPRYk.js +1 -0
  134. package/dist/favicon.svg +3 -3
  135. package/dist/index.html +2 -2
  136. package/package.json +14 -10
  137. package/public/favicon.svg +3 -3
  138. package/src/api/sessions.ts +36 -0
  139. package/src/api/workspace.ts +19 -0
  140. package/src/api.ts +4 -0
  141. package/src/components/NavRail.scss +9 -10
  142. package/src/components/ShortcutDisplay.scss +38 -0
  143. package/src/components/ShortcutDisplay.tsx +37 -0
  144. package/src/components/ShortcutTooltip.scss +36 -0
  145. package/src/components/ShortcutTooltip.tsx +84 -0
  146. package/src/components/Sidebar.scss +55 -13
  147. package/src/components/Sidebar.tsx +141 -52
  148. package/src/components/chat/AGENTS.md +163 -0
  149. package/src/components/chat/ChatHeader.scss +308 -49
  150. package/src/components/chat/ChatHeader.tsx +394 -80
  151. package/src/components/chat/ChatHistoryView.tsx +353 -69
  152. package/src/components/chat/ChatSettingsView.tsx +5 -3
  153. package/src/components/chat/ChatTimelineView.scss +3 -2
  154. package/src/components/chat/{sender/ThinkingStatus.tsx → ThinkingStatus.tsx} +1 -1
  155. package/src/components/chat/messages/MessageContextMenu.scss +145 -0
  156. package/src/components/chat/messages/MessageContextMenu.tsx +108 -0
  157. package/src/components/chat/messages/MessageContextMenuContent.tsx +87 -0
  158. package/src/components/chat/messages/MessageFooter.tsx +44 -24
  159. package/src/components/chat/messages/MessageItem.scss +157 -10
  160. package/src/components/chat/messages/MessageItem.tsx +382 -13
  161. package/src/components/chat/messages/build-message-context-menu-entries.ts +166 -0
  162. package/src/components/chat/messages/message-content-utils.ts +121 -0
  163. package/src/components/chat/messages/message-turns.ts +88 -0
  164. package/src/components/chat/messages/message-utils.ts +19 -1
  165. package/src/components/chat/sender/@components/adapter-select/AdapterSelectControl.scss +86 -0
  166. package/src/components/chat/sender/@components/adapter-select/AdapterSelectControl.tsx +54 -0
  167. package/src/components/chat/sender/@components/adapter-select/AdapterSelectDropdown.scss +42 -0
  168. package/src/components/chat/sender/@components/effort-select/EffortSelectControl.scss +68 -0
  169. package/src/components/chat/sender/@components/effort-select/EffortSelectControl.tsx +137 -0
  170. package/src/components/chat/sender/@components/effort-select/EffortSelectDropdown.scss +96 -0
  171. package/src/components/chat/sender/@components/model-select/ModelSelectControl.scss +82 -0
  172. package/src/components/chat/sender/@components/model-select/ModelSelectControl.tsx +171 -0
  173. package/src/components/chat/sender/@components/model-select/ModelSelectMenu.scss +95 -0
  174. package/src/components/chat/sender/@components/model-select/ModelSelectMenuLabels.scss +144 -0
  175. package/src/components/chat/sender/@components/model-select/ModelSelectOptionLabel.tsx +109 -0
  176. package/src/components/chat/sender/@components/reference-actions/ReferenceActionsControl.scss +106 -0
  177. package/src/components/chat/sender/@components/reference-actions/ReferenceActionsControl.tsx +156 -0
  178. package/src/components/chat/sender/@components/reference-actions/ReferenceActionsOption.scss +34 -0
  179. package/src/components/chat/sender/@components/reference-actions/ReferencePermissionActionsPopover.tsx +111 -0
  180. package/src/components/chat/sender/@components/sender-attachments/SenderAttachments.scss +103 -0
  181. package/src/components/chat/sender/@components/sender-attachments/SenderAttachments.tsx +47 -0
  182. package/src/components/chat/sender/@components/sender-body/SenderBody.tsx +137 -0
  183. package/src/components/chat/sender/@components/sender-interaction-panel/SenderInteractionPanel.scss +178 -0
  184. package/src/components/chat/sender/@components/sender-interaction-panel/SenderInteractionPanel.tsx +145 -0
  185. package/src/components/chat/sender/@components/sender-monaco-editor/SenderMonacoEditor.scss +47 -0
  186. package/src/components/chat/sender/@components/sender-monaco-editor/SenderMonacoEditor.tsx +121 -0
  187. package/src/components/chat/sender/@components/sender-monaco-editor/monaco-runtime.ts +99 -0
  188. package/src/components/chat/sender/@components/sender-monaco-editor/use-sender-editor-handle.ts +48 -0
  189. package/src/components/chat/sender/@components/sender-monaco-editor/use-sender-monaco-editor.ts +209 -0
  190. package/src/components/chat/sender/@components/sender-monaco-editor/use-sender-monaco-theme.ts +24 -0
  191. package/src/components/chat/sender/@components/sender-submit-action/SenderSubmitAction.scss +54 -0
  192. package/src/components/chat/sender/@components/sender-submit-action/SenderSubmitAction.tsx +80 -0
  193. package/src/components/chat/sender/@components/sender-toolbar/SenderSelectBase.scss +71 -0
  194. package/src/components/chat/sender/@components/sender-toolbar/SenderSelectShared.scss +118 -0
  195. package/src/components/chat/sender/@components/sender-toolbar/SenderToolbar.scss +99 -0
  196. package/src/components/chat/sender/@components/sender-toolbar/SenderToolbar.tsx +87 -0
  197. package/src/components/chat/sender/@core/build-sender-controller-result.ts +119 -0
  198. package/src/components/chat/sender/@core/build-sender-toolbar.ts +122 -0
  199. package/src/components/chat/sender/@core/content-attachments.ts +76 -0
  200. package/src/components/chat/sender/@core/create-sender-toolbar-handlers.ts +115 -0
  201. package/src/components/chat/sender/@core/get-sender-interaction-state.ts +18 -0
  202. package/src/components/chat/sender/@core/get-sender-runtime-state.ts +14 -0
  203. package/src/components/chat/sender/@core/sender-toolbar-bindings.ts +155 -0
  204. package/src/components/chat/sender/@hooks/use-model-select-browser.tsx +189 -0
  205. package/src/components/chat/sender/@hooks/use-sender-attachments.ts +143 -0
  206. package/src/components/chat/sender/@hooks/use-sender-autofocus.ts +34 -0
  207. package/src/components/chat/sender/@hooks/use-sender-completion.ts +62 -0
  208. package/src/components/chat/sender/@hooks/use-sender-composer-state.ts +34 -0
  209. package/src/components/chat/sender/@hooks/use-sender-controller.ts +193 -0
  210. package/src/components/chat/sender/@hooks/use-sender-focus-restore.ts +72 -0
  211. package/src/components/chat/sender/@hooks/use-sender-history.ts +79 -0
  212. package/src/components/chat/sender/@hooks/use-sender-keydown.ts +113 -0
  213. package/src/components/chat/sender/@hooks/use-sender-reference-actions.ts +191 -0
  214. package/src/components/chat/sender/@hooks/use-sender-reference-focus-restore.ts +21 -0
  215. package/src/components/chat/sender/@hooks/use-sender-refs.ts +19 -0
  216. package/src/components/chat/sender/@hooks/use-sender-select-overlays.ts +83 -0
  217. package/src/components/chat/sender/@hooks/use-sender-shortcuts.ts +78 -0
  218. package/src/components/chat/sender/@hooks/use-sender-submit.ts +81 -0
  219. package/src/components/chat/sender/@types/sender-composer.ts +19 -0
  220. package/src/components/chat/sender/@types/sender-editor.ts +12 -0
  221. package/src/components/chat/sender/@types/sender-props.ts +50 -0
  222. package/src/components/chat/sender/@types/sender-toolbar-types.ts +83 -0
  223. package/src/components/chat/sender/@types/sender-types.ts +21 -0
  224. package/src/components/chat/sender/@utils/sender-completion.ts +164 -0
  225. package/src/components/chat/sender/@utils/sender-constants.ts +18 -0
  226. package/src/components/chat/sender/@utils/sender-utils.ts +45 -0
  227. package/src/components/chat/sender/Sender.scss +6 -737
  228. package/src/components/chat/sender/Sender.tsx +53 -921
  229. package/src/components/chat/session-metadata.ts +55 -0
  230. package/src/components/chat/terminal/@hooks/use-terminal-instance.ts +152 -0
  231. package/src/components/chat/terminal/@hooks/use-terminal-session.ts +196 -0
  232. package/src/components/chat/terminal/ChatTerminalView.scss +62 -0
  233. package/src/components/chat/terminal/ChatTerminalView.tsx +114 -0
  234. package/src/components/chat/tools/core/ToolGroup.scss +7 -0
  235. package/src/components/chat/tools/core/ToolGroup.tsx +94 -44
  236. package/src/components/config/ConfigSectionForm.tsx +8 -1
  237. package/src/components/config/ConfigShortcutInput.tsx +9 -2
  238. package/src/components/config/configSchema.ts +12 -2
  239. package/src/components/config/record-editors/ModelServicesRecordEditor.tsx +0 -14
  240. package/src/components/dock-panel/DockPanel.scss +152 -0
  241. package/src/components/dock-panel/DockPanel.tsx +195 -0
  242. package/src/components/layout/AppShell.scss +40 -2
  243. package/src/components/layout/AppShell.tsx +25 -10
  244. package/src/components/sidebar/SessionContextMenu.scss +143 -0
  245. package/src/components/sidebar/SessionContextMenu.tsx +196 -0
  246. package/src/components/sidebar/SessionContextMenuContent.tsx +89 -0
  247. package/src/components/sidebar/SessionItem.scss +150 -67
  248. package/src/components/sidebar/SessionItem.tsx +183 -134
  249. package/src/components/sidebar/SessionList.scss +47 -17
  250. package/src/components/sidebar/SessionList.tsx +31 -16
  251. package/src/components/sidebar/SidebarHeader.scss +329 -49
  252. package/src/components/sidebar/SidebarHeader.tsx +108 -86
  253. package/src/components/sidebar/SidebarHeaderBatchActions.tsx +81 -0
  254. package/src/components/sidebar/SidebarHeaderSearchActions.tsx +176 -0
  255. package/src/components/sidebar/SidebarHeaderSelectField.tsx +24 -0
  256. package/src/components/sidebar/filter-utils.ts +23 -0
  257. package/src/components/workspace/ContextFilePicker.scss +64 -0
  258. package/src/components/workspace/ContextFilePicker.tsx +171 -0
  259. package/src/connectionManager.ts +4 -2
  260. package/src/hooks/chat/interaction-state.ts +67 -0
  261. package/src/hooks/chat/model-selector-data-builders.ts +146 -0
  262. package/src/hooks/chat/model-selector-data-option-utils.ts +62 -0
  263. package/src/hooks/chat/model-selector-data-types.ts +27 -0
  264. package/src/hooks/chat/model-selector-data.ts +109 -0
  265. package/src/hooks/chat/model-selector-recommendations.ts +69 -0
  266. package/src/hooks/chat/model-selector.ts +9 -0
  267. package/src/hooks/chat/use-chat-interaction.ts +13 -8
  268. package/src/hooks/chat/use-chat-model-adapter-selection.tsx +167 -164
  269. package/src/hooks/chat/use-chat-models.tsx +46 -23
  270. package/src/hooks/chat/use-chat-session-actions.ts +69 -23
  271. package/src/hooks/chat/use-chat-session-messages.ts +158 -60
  272. package/src/hooks/chat/use-chat-session.ts +34 -9
  273. package/src/hooks/chat/use-chat-view.ts +26 -6
  274. package/src/hooks/chat/use-composer-control-shortcuts.ts +69 -0
  275. package/src/hooks/chat/use-terminal-dock-visibility.ts +39 -0
  276. package/src/hooks/use-roving-focus-list.ts +104 -0
  277. package/src/hooks/use-sidebar-navigation.ts +9 -4
  278. package/src/hooks/use-sidebar-query-state.ts +79 -0
  279. package/src/main.tsx +6 -1
  280. package/src/resources/locales/en.json +140 -6
  281. package/src/resources/locales/zh.json +140 -6
  282. package/src/routes/ChatRoute.scss +159 -4
  283. package/src/routes/ChatRoute.tsx +72 -10
  284. package/src/runtime-config.ts +21 -0
  285. package/src/store/index.ts +1 -3
  286. package/src/styles/global.scss +12 -2
  287. package/src/utils/chat-links.ts +21 -0
  288. package/src/utils/copy.ts +18 -0
  289. package/src/utils/shortcutUtils.ts +111 -1
  290. package/src/vite-env.d.ts +1 -0
  291. package/src/ws.ts +6 -5
  292. package/vite.config.ts +71 -7
  293. package/dist/assets/channel-Di8KkPU4.js +0 -1
  294. package/dist/assets/clone-B065n6L-.js +0 -1
  295. package/dist/assets/flowDiagram-v2-4f6560a1-nj-oVLPK.js +0 -1
  296. package/dist/assets/index-BZe1Qtye.css +0 -1
  297. package/dist/assets/index-DV3eI2aD.js +0 -557
  298. package/src/components/chat/sender/CompletionMenu.scss +0 -70
  299. package/src/components/chat/sender/CompletionMenu.tsx +0 -58
  300. /package/src/components/chat/{sender/ThinkingStatus.scss → ThinkingStatus.scss} +0 -0
  301. /package/src/components/chat/sender/{interaction-request.ts → @core/interaction-request.ts} +0 -0
@@ -1,11 +1,14 @@
1
1
  import './SessionItem.scss'
2
2
 
3
3
  import type { Session, SessionStatus } from '@vibe-forge/core'
4
- import { Badge, Button, Checkbox, List, Tag, Tooltip } from 'antd'
4
+ import { Button, List, Tag, Tooltip } from 'antd'
5
5
  import dayjs from 'dayjs'
6
6
  import relativeTime from 'dayjs/plugin/relativeTime'
7
- import React, { useMemo } from 'react'
7
+ import { useEffect, useMemo, useRef, useState } from 'react'
8
8
  import { useTranslation } from 'react-i18next'
9
+
10
+ import { getAdapterDisplay } from '#~/resources/adapters.js'
11
+ import { SessionContextMenu } from './SessionContextMenu'
9
12
  import 'dayjs/locale/zh-cn'
10
13
 
11
14
  dayjs.extend(relativeTime)
@@ -18,11 +21,13 @@ interface SessionItemProps {
18
21
  onSelect: (session: Session) => void
19
22
  onArchive: (id: string) => void | Promise<void>
20
23
  onDelete: (id: string) => void | Promise<void>
24
+ onRename: (id: string, title: string) => Promise<void>
21
25
  onStar: (id: string, isStarred: boolean) => void | Promise<void>
22
- onUpdateTags: (id: string, tags: string[]) => void | Promise<void>
23
26
  onToggleSelect: (id: string) => void
24
27
  }
25
28
 
29
+ type PendingSessionAction = 'archive' | null
30
+
26
31
  export function SessionItem({
27
32
  session,
28
33
  isActive,
@@ -31,14 +36,37 @@ export function SessionItem({
31
36
  onSelect,
32
37
  onArchive,
33
38
  onDelete,
39
+ onRename,
34
40
  onStar,
35
- onUpdateTags,
36
41
  onToggleSelect
37
42
  }: SessionItemProps) {
38
43
  const { t, i18n } = useTranslation()
39
- const [isAddingTag, setIsAddingTag] = React.useState(false)
40
- const [newTag, setNewTag] = React.useState('')
41
44
  const automationPrefix = 'automation:'
45
+ const itemContentRef = useRef<HTMLDivElement | null>(null)
46
+ const [pendingAction, setPendingAction] = useState<PendingSessionAction>(null)
47
+
48
+ useEffect(() => {
49
+ if (pendingAction == null) {
50
+ return
51
+ }
52
+
53
+ const handlePointerDown = (event: PointerEvent) => {
54
+ const nextTarget = event.target
55
+ if (!(nextTarget instanceof Node)) {
56
+ setPendingAction(null)
57
+ return
58
+ }
59
+
60
+ if (!itemContentRef.current?.contains(nextTarget)) {
61
+ setPendingAction(null)
62
+ }
63
+ }
64
+
65
+ document.addEventListener('pointerdown', handlePointerDown, true)
66
+ return () => {
67
+ document.removeEventListener('pointerdown', handlePointerDown, true)
68
+ }
69
+ }, [pendingAction])
42
70
 
43
71
  const timeDisplay = useMemo(() => {
44
72
  const d = dayjs(session.createdAt)
@@ -53,12 +81,17 @@ export function SessionItem({
53
81
  }
54
82
  }, [session.createdAt, i18n.language])
55
83
 
84
+ const archiveActionLabel = session.isArchived ? t('common.restore') : t('common.archive')
85
+ const archiveConfirmLabel = t('common.confirmAction', { action: archiveActionLabel })
86
+
56
87
  const displayTitle = (session.title != null && session.title !== '')
57
88
  ? session.title
58
89
  : (session.lastUserMessage != null && session.lastUserMessage !== '')
59
90
  ? session.lastUserMessage
60
91
  : t('common.newChat')
61
- const messageCount = session.messageCount ?? 0
92
+ const adapterDisplay = session.adapter != null && session.adapter !== ''
93
+ ? getAdapterDisplay(session.adapter)
94
+ : undefined
62
95
 
63
96
  const lastMessageSnippet = useMemo(() => {
64
97
  if (session.lastMessage == null || session.lastMessage === '') return null
@@ -132,142 +165,158 @@ export function SessionItem({
132
165
  )
133
166
  }
134
167
 
168
+ const handleConfirmableActionClick = (action: Exclude<PendingSessionAction, null>) => {
169
+ if (pendingAction === action) {
170
+ setPendingAction(null)
171
+ void onArchive(session.id)
172
+ return
173
+ }
174
+
175
+ setPendingAction(action)
176
+ }
177
+
135
178
  return (
136
- <List.Item
137
- onClick={() => isBatchMode ? onToggleSelect(session.id) : onSelect(session)}
138
- onDoubleClick={() => {
139
- // eslint-disable-next-line no-console
140
- console.log('Session Details:', session)
141
- }}
142
- className={`session-item ${isActive ? 'active' : ''} ${isSelected ? 'selected' : ''} ${
143
- session.isStarred ? 'starred' : ''
144
- }`}
179
+ <SessionContextMenu
180
+ session={session}
181
+ onArchive={onArchive}
182
+ onDelete={onDelete}
183
+ onRename={onRename}
184
+ onStar={onStar}
145
185
  >
146
- <div className='session-item-content'>
147
- {!isBatchMode && (
148
- <div className='status-indicator'>
149
- {getStatusIcon(session.status)}
150
- </div>
151
- )}
152
- {isBatchMode && (
153
- <div className='batch-checkbox-wrapper'>
154
- <Checkbox
155
- checked={isSelected}
156
- onChange={() => onToggleSelect(session.id)}
157
- onClick={(e) => e.stopPropagation()}
158
- />
159
- </div>
160
- )}
161
- <div className={`session-info ${isBatchMode ? '' : 'with-actions'}`}>
162
- <div className='session-header'>
163
- <div className='session-title'>
164
- <span className='session-title-text'>
165
- {displayTitle}
166
- </span>
186
+ <List.Item
187
+ onClick={() => isBatchMode ? onToggleSelect(session.id) : onSelect(session)}
188
+ onMouseLeave={() => setPendingAction(null)}
189
+ onDoubleClick={() => {
190
+ // eslint-disable-next-line no-console
191
+ console.log('Session Details:', session)
192
+ }}
193
+ className={`session-item ${isActive ? 'active' : ''} ${isSelected ? 'selected' : ''} ${
194
+ session.isStarred ? 'starred' : ''
195
+ }`}
196
+ >
197
+ <div ref={itemContentRef} className='session-item-content'>
198
+ <div className={`session-leading ${adapterDisplay?.icon != null ? 'has-adapter' : ''}`}>
199
+ {adapterDisplay?.icon != null && (
200
+ <img
201
+ className='session-adapter-icon'
202
+ src={adapterDisplay.icon}
203
+ alt=''
204
+ aria-hidden='true'
205
+ />
206
+ )}
207
+ <div className={`status-indicator ${adapterDisplay?.icon != null ? 'is-overlay' : ''}`}>
208
+ {getStatusIcon(session.status)}
167
209
  </div>
168
- {!isBatchMode && (
169
- <div className='session-item-actions'>
170
- <Tooltip title={session.isStarred ? t('common.unstar') : t('common.star')}>
171
- <Button
172
- type='text'
173
- size='small'
174
- className={`action-btn ${session.isStarred ? 'starred' : ''}`}
175
- onClick={(e) => {
176
- e.stopPropagation()
177
- void onStar(session.id, !session.isStarred)
178
- }}
179
- icon={
180
- <span
181
- className={`material-symbols-rounded ${session.isStarred ? 'filled' : ''}`}
182
- >
183
- star
210
+ </div>
211
+ <div className={`session-info ${isBatchMode ? '' : 'with-actions'}`}>
212
+ <div className='session-header'>
213
+ <div className='session-title'>
214
+ <span className='session-title-text'>
215
+ {displayTitle}
216
+ </span>
217
+ </div>
218
+ <div className='session-header-side'>
219
+ {!isBatchMode && (
220
+ <>
221
+ <Tooltip title={timeDisplay.full}>
222
+ <span className='time-display'>
223
+ {timeDisplay.relative}
184
224
  </span>
185
- }
186
- />
187
- </Tooltip>
188
- <Tooltip title={t('common.archive')}>
189
- <Button
190
- type='text'
191
- size='small'
192
- className='action-btn archive-btn'
193
- onClick={(e) => {
194
- e.stopPropagation()
195
- void onArchive(session.id)
196
- }}
197
- icon={<span className='material-symbols-rounded'>archive</span>}
198
- />
199
- </Tooltip>
225
+ </Tooltip>
226
+ <div className='session-item-actions'>
227
+ <Tooltip title={session.isStarred ? t('common.unstar') : t('common.star')}>
228
+ <Button
229
+ type='text'
230
+ size='small'
231
+ className={`action-btn star-btn ${session.isStarred ? 'starred' : ''}`}
232
+ onClick={(e) => {
233
+ e.stopPropagation()
234
+ setPendingAction(null)
235
+ void onStar(session.id, !session.isStarred)
236
+ }}
237
+ icon={
238
+ <span
239
+ className={`material-symbols-rounded ${session.isStarred ? 'filled' : ''}`}
240
+ >
241
+ star
242
+ </span>
243
+ }
244
+ />
245
+ </Tooltip>
246
+ <Tooltip
247
+ title={pendingAction === 'archive' ? archiveConfirmLabel : archiveActionLabel}
248
+ >
249
+ <Button
250
+ type='text'
251
+ size='small'
252
+ className={`action-btn archive-btn ${pendingAction === 'archive' ? 'is-confirming' : ''}`}
253
+ onClick={(e) => {
254
+ e.stopPropagation()
255
+ handleConfirmableActionClick('archive')
256
+ }}
257
+ >
258
+ <span className='material-symbols-rounded'>
259
+ {session.isArchived ? 'unarchive' : 'archive'}
260
+ </span>
261
+ {pendingAction === 'archive' && (
262
+ <span className='action-btn__label'>{archiveConfirmLabel}</span>
263
+ )}
264
+ </Button>
265
+ </Tooltip>
266
+ </div>
267
+ </>
268
+ )}
200
269
  </div>
201
- )}
202
- </div>
203
- {lastMessageSnippet != null && (
204
- <div className='last-message'>
205
- {lastMessageSnippet}
206
270
  </div>
207
- )}
208
- <div className='session-meta'>
209
- {session.status && (
210
- <span
211
- className='status-text'
212
- style={{ fontSize: '11px', color: 'var(--sub-text-color)', marginRight: '8px' }}
213
- >
214
- {t(`common.status.${session.status}`)}
215
- </span>
271
+ {lastMessageSnippet != null && (
272
+ <div className='last-message'>
273
+ {lastMessageSnippet}
274
+ </div>
216
275
  )}
217
- <Tooltip title={timeDisplay.full}>
218
- <span className='time-display'>
219
- {timeDisplay.relative}
220
- </span>
221
- </Tooltip>
222
- </div>
223
- <div className='tags-container'>
224
- {session.tags?.map((tag: string) => {
225
- const automationTag = parseAutomationTag(tag)
226
- if (automationTag) {
227
- const href = `/automation?rule=${encodeURIComponent(automationTag.ruleId)}`
228
- return (
229
- <Tooltip
230
- key={tag}
231
- title={automationTag.ruleTitle}
232
- >
233
- <Tag
234
- className='session-tag session-tag--automation'
235
- onClick={(event) => event.stopPropagation()}
236
- >
237
- <a
238
- className='session-tag__link'
239
- href={href}
240
- onClick={(event) => event.stopPropagation()}
276
+ {session.tags != null && session.tags.length > 0 && (
277
+ <div className='tags-container'>
278
+ {session.tags.map((tag: string) => {
279
+ const automationTag = parseAutomationTag(tag)
280
+ if (automationTag) {
281
+ const href = `/automation?rule=${encodeURIComponent(automationTag.ruleId)}`
282
+ return (
283
+ <Tooltip
284
+ key={tag}
285
+ title={automationTag.ruleTitle}
241
286
  >
242
- {automationTag.ruleTitle}
243
- </a>
244
- </Tag>
245
- </Tooltip>
246
- )
247
- }
248
- return (
249
- <Tooltip
250
- key={tag}
251
- title={tag}
252
- >
253
- <Tag className='session-tag'>
254
- <span className='session-tag__text'>
255
- {tag}
256
- </span>
257
- </Tag>
258
- </Tooltip>
259
- )
260
- })}
287
+ <Tag
288
+ className='session-tag session-tag--automation'
289
+ onClick={(event) => event.stopPropagation()}
290
+ >
291
+ <a
292
+ className='session-tag__link'
293
+ href={href}
294
+ onClick={(event) => event.stopPropagation()}
295
+ >
296
+ {automationTag.ruleTitle}
297
+ </a>
298
+ </Tag>
299
+ </Tooltip>
300
+ )
301
+ }
302
+ return (
303
+ <Tooltip
304
+ key={tag}
305
+ title={tag}
306
+ >
307
+ <Tag className='session-tag'>
308
+ <span className='session-tag__text'>
309
+ {tag}
310
+ </span>
311
+ </Tag>
312
+ </Tooltip>
313
+ )
314
+ })}
315
+ </div>
316
+ )}
261
317
  </div>
262
318
  </div>
263
- </div>
264
-
265
- {messageCount > 0 && (
266
- <Badge
267
- count={messageCount > 99 ? '99+' : messageCount}
268
- className='session-item-badge'
269
- />
270
- )}
271
- </List.Item>
319
+ </List.Item>
320
+ </SessionContextMenu>
272
321
  )
273
322
  }
@@ -9,15 +9,15 @@
9
9
  overflow-y: auto;
10
10
 
11
11
  .session-list {
12
- padding: 12px 16px;
12
+ padding: 8px 12px;
13
13
  display: flex;
14
14
  flex-direction: column;
15
- gap: 8px;
15
+ gap: 6px;
16
16
 
17
17
  .ant-list-items {
18
18
  display: flex;
19
19
  flex-direction: column;
20
- gap: 8px;
20
+ gap: 6px;
21
21
  }
22
22
 
23
23
  .session-row {
@@ -27,30 +27,60 @@
27
27
  &::before {
28
28
  content: '';
29
29
  position: absolute;
30
- top: -8px;
31
- bottom: -8px;
32
- left: calc((var(--session-depth, 0) - 1) * 22px + 8px);
30
+ top: -6px;
31
+ bottom: -6px;
32
+ left: calc((var(--session-depth, 0) - 1) * 18px + 7px);
33
33
  width: 3px;
34
34
  background-color: var(--primary-color);
35
35
  border-radius: 2px;
36
36
  }
37
37
  }
38
38
 
39
+ .session-row-main {
40
+ display: flex;
41
+ align-items: center;
42
+ gap: 6px;
43
+ }
44
+
45
+ .session-select-toggle {
46
+ width: 28px;
47
+ height: 28px;
48
+ margin-left: calc(var(--session-depth, 0) * 18px);
49
+ display: inline-flex;
50
+ align-items: center;
51
+ justify-content: center;
52
+ flex-shrink: 0;
53
+ align-self: center;
54
+ border-radius: 6px;
55
+ background-color: var(--bg-color);
56
+ color: var(--sub-text-color);
57
+
58
+ .ant-checkbox-wrapper {
59
+ margin-inline-start: 0;
60
+ }
61
+ }
62
+
39
63
  .session-item {
40
- margin-left: calc(var(--session-depth, 0) * 22px);
64
+ flex: 1;
65
+ min-width: 0;
66
+ margin-left: calc(var(--session-depth, 0) * 18px);
67
+ }
68
+
69
+ .session-select-toggle + .session-item {
70
+ margin-left: 0;
41
71
  }
42
72
 
43
73
  .session-collapse-row {
44
- margin-top: 6px;
45
- margin-left: calc(var(--session-depth, 0) * 22px);
74
+ margin-top: 4px;
75
+ margin-left: calc(var(--session-depth, 0) * 18px);
46
76
  display: flex;
47
77
  align-items: center;
48
- gap: 6px;
78
+ gap: 4px;
49
79
  color: var(--sub-text-color);
50
80
 
51
81
  .session-tree-toggle {
52
- width: 20px;
53
- height: 20px;
82
+ width: 18px;
83
+ height: 18px;
54
84
  padding: 0;
55
85
  display: flex;
56
86
  align-items: center;
@@ -58,7 +88,7 @@
58
88
  color: var(--sub-text-color);
59
89
 
60
90
  .material-symbols-rounded {
61
- font-size: 18px;
91
+ font-size: 16px;
62
92
  transition: transform .2s ease;
63
93
  }
64
94
 
@@ -70,11 +100,11 @@
70
100
  }
71
101
 
72
102
  .session-collapse-label {
73
- font-size: 11px;
103
+ font-size: 10px;
74
104
  }
75
105
 
76
106
  .session-collapse-summary {
77
- font-size: 11px;
107
+ font-size: 10px;
78
108
  color: var(--sub-text-color);
79
109
  opacity: .8;
80
110
  }
@@ -84,9 +114,9 @@
84
114
  }
85
115
 
86
116
  .empty-text {
87
- padding: 32px 16px;
117
+ padding: 28px 12px;
88
118
  text-align: center;
89
119
  color: var(--sub-text-color);
90
- font-size: 14px;
120
+ font-size: 13px;
91
121
  }
92
122
  }
@@ -1,7 +1,7 @@
1
1
  import './SessionList.scss'
2
2
 
3
3
  import type { Session } from '@vibe-forge/core'
4
- import { Button, List } from 'antd'
4
+ import { Button, Checkbox, List } from 'antd'
5
5
  import React, { useMemo, useState } from 'react'
6
6
  import { useTranslation } from 'react-i18next'
7
7
  import { SessionItem } from './SessionItem'
@@ -9,28 +9,30 @@ import { SessionItem } from './SessionItem'
9
9
  interface SessionListProps {
10
10
  sessions: Session[]
11
11
  activeId?: string
12
+ hasActiveFilters: boolean
12
13
  isBatchMode: boolean
13
14
  selectedIds: Set<string>
14
15
  searchQuery?: string
15
16
  onSelectSession: (session: Session) => void
16
17
  onArchiveSession: (id: string) => void | Promise<void>
17
18
  onDeleteSession: (id: string) => void | Promise<void>
19
+ onRenameSession: (id: string, title: string) => Promise<void>
18
20
  onStarSession: (id: string, isStarred: boolean) => void | Promise<void>
19
- onUpdateTags: (id: string, tags: string[]) => void | Promise<void>
20
21
  onToggleSelect: (id: string) => void
21
22
  }
22
23
 
23
24
  export function SessionList({
24
25
  sessions,
25
26
  activeId,
27
+ hasActiveFilters,
26
28
  isBatchMode,
27
29
  selectedIds,
28
30
  searchQuery,
29
31
  onSelectSession,
30
32
  onArchiveSession,
31
33
  onDeleteSession,
34
+ onRenameSession,
32
35
  onStarSession,
33
- onUpdateTags,
34
36
  onToggleSelect
35
37
  }: SessionListProps) {
36
38
  const { t } = useTranslation()
@@ -115,7 +117,7 @@ export function SessionList({
115
117
  size='small'
116
118
  locale={{
117
119
  emptyText: <div className='empty-text'>
118
- {searchQuery ? t('common.noSessions') : t('common.startNewChat')}
120
+ {searchQuery || hasActiveFilters ? t('common.noSessions') : t('common.startNewChat')}
119
121
  </div>
120
122
  }}
121
123
  dataSource={flattenedSessions}
@@ -124,18 +126,31 @@ export function SessionList({
124
126
  className={`session-row ${depth > 0 ? 'has-parent' : ''}`}
125
127
  style={{ '--session-depth': depth } as React.CSSProperties}
126
128
  >
127
- <SessionItem
128
- session={s}
129
- isActive={activeId === s.id}
130
- isBatchMode={isBatchMode}
131
- isSelected={selectedIds.has(s.id)}
132
- onSelect={onSelectSession}
133
- onArchive={onArchiveSession}
134
- onDelete={onDeleteSession}
135
- onStar={onStarSession}
136
- onUpdateTags={onUpdateTags}
137
- onToggleSelect={onToggleSelect}
138
- />
129
+ <div className='session-row-main'>
130
+ {isBatchMode && (
131
+ <div
132
+ className='session-select-toggle'
133
+ onClick={(event) => event.stopPropagation()}
134
+ >
135
+ <Checkbox
136
+ checked={selectedIds.has(s.id)}
137
+ onChange={() => onToggleSelect(s.id)}
138
+ />
139
+ </div>
140
+ )}
141
+ <SessionItem
142
+ session={s}
143
+ isActive={activeId === s.id}
144
+ isBatchMode={isBatchMode}
145
+ isSelected={selectedIds.has(s.id)}
146
+ onSelect={onSelectSession}
147
+ onArchive={onArchiveSession}
148
+ onDelete={onDeleteSession}
149
+ onRename={onRenameSession}
150
+ onStar={onStarSession}
151
+ onToggleSelect={onToggleSelect}
152
+ />
153
+ </div>
139
154
  {hasChildren && !isBatchMode && (
140
155
  <div
141
156
  className='session-collapse-row'