@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,83 +0,0 @@
1
- export type EditorValueType = 'string' | 'number' | 'boolean' | 'object' | 'array'
2
-
3
- export type TranslationFn = (key: string, options?: Record<string, unknown> & { defaultValue?: string }) => string
4
-
5
- export const isEmptyValue = (value: unknown) => {
6
- if (value == null) return true
7
- if (Array.isArray(value)) return value.length === 0
8
- if (typeof value === 'object') return Object.keys(value as Record<string, unknown>).length === 0
9
- return false
10
- }
11
-
12
- export const cloneValue = (value: unknown) => {
13
- if (value == null) return value
14
- return JSON.parse(JSON.stringify(value)) as unknown
15
- }
16
-
17
- export const getValueType = (value: unknown): EditorValueType => {
18
- if (Array.isArray(value)) return 'array'
19
- if (value != null && typeof value === 'object') return 'object'
20
- if (typeof value === 'number') return 'number'
21
- if (typeof value === 'boolean') return 'boolean'
22
- return 'string'
23
- }
24
-
25
- export const getTypeIcon = (valueType: EditorValueType) => {
26
- if (valueType === 'string') return 'text_fields'
27
- if (valueType === 'number') return 'numbers'
28
- if (valueType === 'boolean') return 'toggle_on'
29
- if (valueType === 'array') return 'view_list'
30
- return 'account_tree'
31
- }
32
-
33
- export const getFieldLabel = (
34
- t: TranslationFn,
35
- sectionKey: string,
36
- path: string[],
37
- fallback: string
38
- ) => {
39
- if (path.length === 0) return fallback
40
- const key = `config.fields.${sectionKey}.${path.join('.')}.label`
41
- return t(key, { defaultValue: fallback })
42
- }
43
-
44
- export const getFieldDescription = (
45
- t: TranslationFn,
46
- sectionKey: string,
47
- path: string[]
48
- ) => {
49
- if (path.length === 0) return ''
50
- const key = `config.fields.${sectionKey}.${path.join('.')}.desc`
51
- return t(key, { defaultValue: '' })
52
- }
53
-
54
- export const isSensitiveKey = (key: string) => /key|token|secret|password/i.test(key)
55
-
56
- export const getValueByPath = (value: unknown, path: string[]) => {
57
- if (path.length === 0) return value
58
- let current = value
59
- for (const key of path) {
60
- if (current == null || typeof current !== 'object') return undefined
61
- current = (current as Record<string, unknown>)[key]
62
- }
63
- return current
64
- }
65
-
66
- export const setValueByPath = (value: unknown, path: string[], nextValue: unknown) => {
67
- if (path.length === 0) return nextValue
68
- const root = (value != null && typeof value === 'object' && !Array.isArray(value))
69
- ? { ...(value as Record<string, unknown>) }
70
- : {}
71
- let current: Record<string, unknown> = root
72
- for (let index = 0; index < path.length - 1; index += 1) {
73
- const key = path[index]
74
- const existing = current[key]
75
- const next = (existing != null && typeof existing === 'object' && !Array.isArray(existing))
76
- ? { ...(existing as Record<string, unknown>) }
77
- : {}
78
- current[key] = next
79
- current = next
80
- }
81
- current[path[path.length - 1]] = nextValue
82
- return root
83
- }
@@ -1,5 +0,0 @@
1
- export { AboutSection } from './ConfigAboutSection'
2
- export { DisplayValue } from './ConfigDisplayValue'
3
- export { SectionForm } from './ConfigSectionForm'
4
- export { ConfigSectionPanel } from './ConfigSectionPanel'
5
- export { ConfigSourceSwitch } from './ConfigSourceSwitch'
@@ -1 +0,0 @@
1
- @use './RecordEditors.scss';
@@ -1,75 +0,0 @@
1
- import './BooleanRecordEditor.scss'
2
-
3
- import { Button, Input, Switch, Tooltip } from 'antd'
4
- import { useState } from 'react'
5
-
6
- import type { TranslationFn } from '../configUtils'
7
-
8
- export const BooleanRecordEditor = ({
9
- value,
10
- onChange,
11
- t,
12
- keyPlaceholder
13
- }: {
14
- value: Record<string, boolean>
15
- onChange: (nextValue: Record<string, boolean>) => void
16
- t: TranslationFn
17
- keyPlaceholder: string
18
- }) => {
19
- const [newKey, setNewKey] = useState('')
20
- const entries = Object.entries(value)
21
-
22
- return (
23
- <div className='config-view__record-list'>
24
- {entries.map(([key, itemValue]) => (
25
- <div key={key} className='config-view__record-row'>
26
- <div className='config-view__record-key'>{key}</div>
27
- <Switch
28
- checked={Boolean(itemValue)}
29
- onChange={(next) => {
30
- onChange({ ...value, [key]: next })
31
- }}
32
- />
33
- <Tooltip title={t('config.editor.remove')}>
34
- <Button
35
- size='small'
36
- type='text'
37
- danger
38
- className='config-view__icon-button config-view__icon-button--compact'
39
- aria-label={t('config.editor.remove')}
40
- icon={<span className='material-symbols-rounded'>delete</span>}
41
- onClick={() => {
42
- const updated = { ...value }
43
- delete updated[key]
44
- onChange(updated)
45
- }}
46
- />
47
- </Tooltip>
48
- </div>
49
- ))}
50
- <div className='config-view__record-add'>
51
- <div className='config-view__record-add-inputs'>
52
- <Input
53
- value={newKey}
54
- placeholder={keyPlaceholder}
55
- onChange={(event) => setNewKey(event.target.value)}
56
- />
57
- <Tooltip title={t('common.confirm')}>
58
- <Button
59
- size='small'
60
- type='primary'
61
- className='config-view__icon-button'
62
- aria-label={t('common.confirm')}
63
- icon={<span className='material-symbols-rounded'>check</span>}
64
- disabled={newKey.trim() === '' || Object.hasOwn(value, newKey)}
65
- onClick={() => {
66
- onChange({ ...value, [newKey]: true })
67
- setNewKey('')
68
- }}
69
- />
70
- </Tooltip>
71
- </div>
72
- </div>
73
- </div>
74
- )
75
- }
@@ -1 +0,0 @@
1
- @use './RecordEditors.scss';
@@ -1,397 +0,0 @@
1
- import './ChannelRecordEditor.scss'
2
-
3
- import { Button, Input, InputNumber, Select, Switch, Tooltip } from 'antd'
4
- import { useEffect, useMemo, useState } from 'react'
5
- import type { ZodRawShape, ZodTypeAny } from 'zod'
6
- import { z } from 'zod'
7
-
8
- import type { ChannelDescriptor } from '@vibe-forge/core/channel'
9
- import { channelBaseSchema } from '@vibe-forge/core/channel'
10
-
11
- import { ComplexTextEditor, StringArrayEditor } from '../ConfigEditors'
12
- import { FieldRow } from '../ConfigFieldRow'
13
- import { channelDefinitions } from '../channelDefinitions'
14
- import { getTypeIcon, isSensitiveKey } from '../configUtils'
15
- import type { TranslationFn } from '../configUtils'
16
-
17
- type ChannelRecordValue = Record<string, unknown>
18
-
19
- const getObjectShape = (schema: ZodTypeAny): ZodRawShape => {
20
- if (schema instanceof z.ZodObject) return schema.shape
21
- if (schema instanceof z.ZodEffects) return getObjectShape(schema.innerType())
22
- if (schema instanceof z.ZodOptional) return getObjectShape(schema.unwrap())
23
- if (schema instanceof z.ZodDefault) return getObjectShape(schema.removeDefault())
24
- if (schema instanceof z.ZodNullable) return getObjectShape(schema.unwrap())
25
- return {}
26
- }
27
-
28
- const unwrapSchema = (schema: ZodTypeAny): ZodTypeAny => {
29
- if (schema instanceof z.ZodEffects) return unwrapSchema(schema.innerType())
30
- if (schema instanceof z.ZodOptional) return unwrapSchema(schema.unwrap())
31
- if (schema instanceof z.ZodDefault) return unwrapSchema(schema.removeDefault())
32
- if (schema instanceof z.ZodNullable) return unwrapSchema(schema.unwrap())
33
- return schema
34
- }
35
-
36
- const getDefaultValue = (schema: ZodTypeAny): unknown => {
37
- if (schema instanceof z.ZodDefault) return schema._def.defaultValue()
38
- if (schema instanceof z.ZodOptional) return undefined
39
- if (schema instanceof z.ZodNullable) return null
40
- if (schema instanceof z.ZodLiteral) return schema.value
41
- if (schema instanceof z.ZodEnum) return schema.options[0]
42
- if (schema instanceof z.ZodNativeEnum) {
43
- const values = Object.values(schema.enum)
44
- return values.length > 0 ? values[0] : undefined
45
- }
46
- if (schema instanceof z.ZodString) return ''
47
- if (schema instanceof z.ZodNumber) return 0
48
- if (schema instanceof z.ZodBoolean) return false
49
- if (schema instanceof z.ZodArray) return []
50
- if (schema instanceof z.ZodObject) {
51
- const shape = getObjectShape(schema)
52
- return Object.fromEntries(Object.entries(shape).map(([key, value]) => [key, getDefaultValue(value)]))
53
- }
54
- if (schema instanceof z.ZodRecord) return {}
55
- if (schema instanceof z.ZodEffects) return getDefaultValue(schema.innerType())
56
- return undefined
57
- }
58
-
59
- const toLabel = (key: string) =>
60
- key
61
- .replace(/_/g, ' ')
62
- .replace(/([a-z0-9])([A-Z])/g, '$1 $2')
63
- .replace(/\b\w/g, char => char.toUpperCase())
64
-
65
- const buildRecordDefaults = (definition: ChannelDescriptor) => {
66
- const shape = getObjectShape(definition.configSchema)
67
- const entries = Object.entries(shape)
68
- return entries.reduce<Record<string, unknown>>((acc, [key, schema]) => {
69
- acc[key] = getDefaultValue(schema)
70
- return acc
71
- }, {})
72
- }
73
-
74
- const getChannelDefinition = (type: string | undefined) =>
75
- channelDefinitions.find(definition => definition.type === type)
76
-
77
- export const ChannelRecordEditor = ({
78
- value,
79
- onChange,
80
- t,
81
- keyPlaceholder
82
- }: {
83
- value: Record<string, unknown>
84
- onChange: (nextValue: Record<string, unknown>) => void
85
- t: TranslationFn
86
- keyPlaceholder: string
87
- }) => {
88
- const [newKey, setNewKey] = useState('')
89
- const [newType, setNewType] = useState(channelDefinitions[0]?.type ?? '')
90
- const entries = useMemo(() => Object.entries(value), [value])
91
- const [collapsedKeys, setCollapsedKeys] = useState<Record<string, boolean>>(() => (
92
- Object.fromEntries(entries.map(([key]) => [key, true]))
93
- ))
94
- const baseKeys = useMemo(() => new Set(Object.keys(getObjectShape(channelBaseSchema))), [])
95
- const typeOptions = useMemo(() =>
96
- channelDefinitions.map(definition => ({
97
- value: definition.type,
98
- label: definition.label
99
- })), [])
100
-
101
- useEffect(() => {
102
- setCollapsedKeys(prev => {
103
- const next: Record<string, boolean> = {}
104
- for (const [key] of entries) {
105
- next[key] = prev[key] ?? true
106
- }
107
- return next
108
- })
109
- }, [entries])
110
-
111
- const updateChannel = (key: string, nextValue: ChannelRecordValue) => {
112
- onChange({ ...value, [key]: nextValue })
113
- }
114
-
115
- const renderField = (
116
- channelKey: string,
117
- recordValue: ChannelRecordValue,
118
- fieldKey: string,
119
- fieldSchema: ZodTypeAny
120
- ) => {
121
- const rawSchema = unwrapSchema(fieldSchema)
122
- const description = rawSchema.description ?? ''
123
- const label = toLabel(fieldKey)
124
- const currentValue = recordValue[fieldKey]
125
- const valueToUse = currentValue !== undefined ? currentValue : getDefaultValue(fieldSchema)
126
-
127
- if (rawSchema instanceof z.ZodString) {
128
- const isSensitive = isSensitiveKey(fieldKey)
129
- return (
130
- <FieldRow key={fieldKey} title={label} description={description} icon={getTypeIcon('string')}>
131
- {isSensitive
132
- ? (
133
- <Input.Password
134
- value={typeof valueToUse === 'string' ? valueToUse : ''}
135
- onChange={(event) => {
136
- updateChannel(channelKey, { ...recordValue, [fieldKey]: event.target.value })
137
- }}
138
- placeholder={t('config.editor.secretPlaceholder')}
139
- />
140
- )
141
- : (
142
- <Input
143
- value={typeof valueToUse === 'string' ? valueToUse : ''}
144
- onChange={(event) => {
145
- updateChannel(channelKey, { ...recordValue, [fieldKey]: event.target.value })
146
- }}
147
- />
148
- )}
149
- </FieldRow>
150
- )
151
- }
152
-
153
- if (rawSchema instanceof z.ZodNumber) {
154
- return (
155
- <FieldRow key={fieldKey} title={label} description={description} icon={getTypeIcon('number')}>
156
- <InputNumber
157
- value={typeof valueToUse === 'number' ? valueToUse : 0}
158
- onChange={(nextValue) => {
159
- updateChannel(channelKey, { ...recordValue, [fieldKey]: nextValue ?? 0 })
160
- }}
161
- />
162
- </FieldRow>
163
- )
164
- }
165
-
166
- if (rawSchema instanceof z.ZodBoolean) {
167
- return (
168
- <FieldRow key={fieldKey} title={label} description={description} icon={getTypeIcon('boolean')}>
169
- <Switch
170
- checked={Boolean(valueToUse)}
171
- onChange={(checked) => {
172
- updateChannel(channelKey, { ...recordValue, [fieldKey]: checked })
173
- }}
174
- />
175
- </FieldRow>
176
- )
177
- }
178
-
179
- if (rawSchema instanceof z.ZodEnum || rawSchema instanceof z.ZodNativeEnum) {
180
- const optionValues: string[] = (
181
- rawSchema instanceof z.ZodEnum
182
- ? rawSchema.options
183
- : Object.values(rawSchema.enum)
184
- ).map((option: string | number) => String(option))
185
- return (
186
- <FieldRow key={fieldKey} title={label} description={description} icon={getTypeIcon('string')}>
187
- <Select
188
- value={typeof valueToUse === 'string' ? valueToUse : undefined}
189
- options={optionValues.map((option) => ({ value: option, label: option }))}
190
- onChange={(nextValue) => {
191
- updateChannel(channelKey, { ...recordValue, [fieldKey]: nextValue })
192
- }}
193
- />
194
- </FieldRow>
195
- )
196
- }
197
-
198
- if (rawSchema instanceof z.ZodArray) {
199
- const inner = unwrapSchema(rawSchema.element)
200
- if (inner instanceof z.ZodString) {
201
- const items = Array.isArray(valueToUse)
202
- ? valueToUse.filter(item => typeof item === 'string')
203
- : []
204
- return (
205
- <FieldRow
206
- key={fieldKey}
207
- title={label}
208
- description={description}
209
- icon={getTypeIcon('array')}
210
- layout='stacked'
211
- >
212
- <StringArrayEditor
213
- value={items}
214
- onChange={(nextValue) => {
215
- updateChannel(channelKey, { ...recordValue, [fieldKey]: nextValue })
216
- }}
217
- t={t}
218
- />
219
- </FieldRow>
220
- )
221
- }
222
- return (
223
- <FieldRow
224
- key={fieldKey}
225
- title={label}
226
- description={description}
227
- icon={getTypeIcon('array')}
228
- layout='stacked'
229
- >
230
- <ComplexTextEditor
231
- value={Array.isArray(valueToUse) ? valueToUse : []}
232
- onChange={(nextValue) => {
233
- updateChannel(channelKey, { ...recordValue, [fieldKey]: nextValue })
234
- }}
235
- />
236
- </FieldRow>
237
- )
238
- }
239
-
240
- return (
241
- <FieldRow
242
- key={fieldKey}
243
- title={label}
244
- description={description}
245
- icon={getTypeIcon('object')}
246
- layout='stacked'
247
- >
248
- <ComplexTextEditor
249
- value={valueToUse ?? {}}
250
- onChange={(nextValue) => {
251
- updateChannel(channelKey, { ...recordValue, [fieldKey]: nextValue })
252
- }}
253
- />
254
- </FieldRow>
255
- )
256
- }
257
-
258
- return (
259
- <div className='config-view__record-list'>
260
- <div className='config-view__record-add'>
261
- <div className='config-view__record-add-inputs'>
262
- <Input
263
- value={newKey}
264
- placeholder={keyPlaceholder}
265
- onChange={(event) => setNewKey(event.target.value)}
266
- />
267
- <Select
268
- value={newType}
269
- options={typeOptions}
270
- onChange={(nextValue) => setNewType(nextValue)}
271
- />
272
- <Tooltip title={t('common.confirm')}>
273
- <Button
274
- size='small'
275
- type='primary'
276
- className='config-view__icon-button'
277
- aria-label={t('common.confirm')}
278
- icon={<span className='material-symbols-rounded'>check</span>}
279
- disabled={newKey.trim() === '' || Object.hasOwn(value, newKey) || newType === ''}
280
- onClick={() => {
281
- const definition = getChannelDefinition(newType)
282
- if (!definition) return
283
- onChange({
284
- ...value,
285
- [newKey]: buildRecordDefaults(definition)
286
- })
287
- setNewKey('')
288
- }}
289
- />
290
- </Tooltip>
291
- </div>
292
- </div>
293
- {entries.map(([key, itemValue]) => {
294
- const recordValue = (itemValue != null && typeof itemValue === 'object')
295
- ? itemValue as ChannelRecordValue
296
- : {}
297
- const type = typeof recordValue.type === 'string' ? recordValue.type : undefined
298
- const definition = getChannelDefinition(type)
299
- const titleValue = typeof recordValue.title === 'string' ? recordValue.title : ''
300
- const descriptionValue = typeof recordValue.description === 'string' ? recordValue.description : ''
301
- const displayName = titleValue.trim() !== '' ? titleValue : key
302
- const typeLabel = definition?.label ?? type ?? t('config.editor.unknownChannelType')
303
- const isCollapsed = collapsedKeys[key] === true
304
- const shape = definition ? getObjectShape(definition.configSchema) : {}
305
- const fieldEntries = Object.entries(shape)
306
- .filter(([fieldKey]) => fieldKey !== 'type')
307
- .sort(([a], [b]) => {
308
- const order = ['title', 'description', 'enabled', 'admins']
309
- const aIndex = order.indexOf(a)
310
- const bIndex = order.indexOf(b)
311
- if (aIndex === -1 && bIndex === -1) return a.localeCompare(b)
312
- if (aIndex === -1) return 1
313
- if (bIndex === -1) return -1
314
- return aIndex - bIndex
315
- })
316
-
317
- return (
318
- <div
319
- key={key}
320
- className={`config-view__record-card${isCollapsed ? ' config-view__record-card--collapsed' : ''}`}
321
- >
322
- <div className='config-view__record-title'>
323
- <div className='config-view__record-title-left'>
324
- <Tooltip title={isCollapsed ? t('config.editor.expand') : t('config.editor.collapse')}>
325
- <Button
326
- size='small'
327
- type='text'
328
- className='config-view__icon-button config-view__icon-button--compact'
329
- aria-label={isCollapsed ? t('config.editor.expand') : t('config.editor.collapse')}
330
- icon={
331
- <span className='material-symbols-rounded'>{isCollapsed ? 'chevron_right' : 'expand_more'}</span>
332
- }
333
- onClick={() => {
334
- setCollapsedKeys(prev => ({ ...prev, [key]: !isCollapsed }))
335
- }}
336
- />
337
- </Tooltip>
338
- <div className='config-view__record-heading'>
339
- <div>{displayName}</div>
340
- <div className='config-view__record-subtitle'>
341
- {key} · {typeLabel}
342
- </div>
343
- {descriptionValue !== '' && (
344
- <div className='config-view__record-desc'>{descriptionValue}</div>
345
- )}
346
- </div>
347
- </div>
348
- <div className='config-view__record-actions'>
349
- <Tooltip title={t('config.editor.remove')}>
350
- <Button
351
- size='small'
352
- type='text'
353
- danger
354
- className='config-view__icon-button config-view__icon-button--compact'
355
- aria-label={t('config.editor.remove')}
356
- icon={<span className='material-symbols-rounded'>delete</span>}
357
- onClick={() => {
358
- const updated = { ...value }
359
- delete updated[key]
360
- onChange(updated)
361
- }}
362
- />
363
- </Tooltip>
364
- </div>
365
- </div>
366
- <div className='config-view__record-body'>
367
- <div className='config-view__record-fields'>
368
- <FieldRow
369
- title={t('config.editor.channelType')}
370
- description={definition?.description ?? ''}
371
- icon={getTypeIcon('string')}
372
- >
373
- <Select
374
- value={type}
375
- options={typeOptions}
376
- onChange={(nextType) => {
377
- const nextDefinition = getChannelDefinition(nextType)
378
- if (!nextDefinition) return
379
- const defaults = buildRecordDefaults(nextDefinition)
380
- const preserved = Object.fromEntries(
381
- Object.entries(recordValue).filter(([fieldKey]) => baseKeys.has(fieldKey))
382
- )
383
- updateChannel(key, { ...defaults, ...preserved, type: nextType })
384
- }}
385
- />
386
- </FieldRow>
387
- {fieldEntries.map(([fieldKey, fieldSchema]) => (
388
- renderField(key, recordValue, fieldKey, fieldSchema)
389
- ))}
390
- </div>
391
- </div>
392
- </div>
393
- )
394
- })}
395
- </div>
396
- )
397
- }
@@ -1 +0,0 @@
1
- @use './RecordEditors.scss';
@@ -1,97 +0,0 @@
1
- import './KeyValueEditor.scss'
2
-
3
- import { Button, Input, Tooltip } from 'antd'
4
- import { useState } from 'react'
5
-
6
- import { isSensitiveKey } from '../configUtils'
7
- import type { TranslationFn } from '../configUtils'
8
-
9
- export const KeyValueEditor = ({
10
- value,
11
- onChange,
12
- t,
13
- keyPlaceholder
14
- }: {
15
- value: Record<string, string>
16
- onChange: (nextValue: Record<string, string>) => void
17
- t: TranslationFn
18
- keyPlaceholder: string
19
- }) => {
20
- const [newKey, setNewKey] = useState('')
21
- const [newValue, setNewValue] = useState('')
22
- const entries = Object.entries(value)
23
-
24
- return (
25
- <div className='config-view__array-list'>
26
- {entries.map(([key, val]) => (
27
- <div key={key} className='config-view__array-item'>
28
- <div className='config-view__record-key'>{key}</div>
29
- {isSensitiveKey(key)
30
- ? (
31
- <Input.Password
32
- value={val}
33
- onChange={(event) => {
34
- onChange({ ...value, [key]: event.target.value })
35
- }}
36
- placeholder={t('config.editor.fieldValue')}
37
- />
38
- )
39
- : (
40
- <Input
41
- value={val}
42
- onChange={(event) => {
43
- onChange({ ...value, [key]: event.target.value })
44
- }}
45
- placeholder={t('config.editor.fieldValue')}
46
- />
47
- )}
48
- <Tooltip title={t('config.editor.remove')}>
49
- <Button
50
- size='small'
51
- type='text'
52
- danger
53
- className='config-view__icon-button config-view__icon-button--compact'
54
- aria-label={t('config.editor.remove')}
55
- icon={<span className='material-symbols-rounded'>delete</span>}
56
- onClick={() => {
57
- const updated = { ...value }
58
- delete updated[key]
59
- onChange(updated)
60
- }}
61
- />
62
- </Tooltip>
63
- </div>
64
- ))}
65
- <div className='config-view__array-add'>
66
- <div className='config-view__array-add-inputs'>
67
- <Input
68
- value={newKey}
69
- placeholder={keyPlaceholder}
70
- onChange={(event) => setNewKey(event.target.value)}
71
- />
72
- <Input
73
- value={newValue}
74
- placeholder={t('config.editor.fieldValue')}
75
- onChange={(event) => setNewValue(event.target.value)}
76
- />
77
- <Tooltip title={t('common.confirm')}>
78
- <Button
79
- size='small'
80
- type='primary'
81
- className='config-view__icon-button'
82
- aria-label={t('common.confirm')}
83
- icon={<span className='material-symbols-rounded'>check</span>}
84
- disabled={newKey.trim() === '' || Object.hasOwn(value, newKey)}
85
- onClick={() => {
86
- const nextValue = { ...value, [newKey]: newValue }
87
- onChange(nextValue)
88
- setNewKey('')
89
- setNewValue('')
90
- }}
91
- />
92
- </Tooltip>
93
- </div>
94
- </div>
95
- </div>
96
- )
97
- }
@@ -1 +0,0 @@
1
- @use './RecordEditors.scss';