@vibe-forge/client 2.0.0 → 3.0.0-alpha.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 (351) hide show
  1. package/AGENTS.md +4 -1
  2. package/dist/assets/{arc-CbOXL0l9.js → arc-1JbypnRY.js} +1 -1
  3. package/dist/assets/{blockDiagram-c4efeb88-CqxINvsS.js → blockDiagram-c4efeb88-jT5b9nId.js} +1 -1
  4. package/dist/assets/{c4Diagram-c83219d4-BKazU0hb.js → c4Diagram-c83219d4-KNPh-1ta.js} +1 -1
  5. package/dist/assets/channel-pzvjJnfd.js +1 -0
  6. package/dist/assets/{classDiagram-beda092f-fAFX5BpB.js → classDiagram-beda092f-vvXuOT3F.js} +1 -1
  7. package/dist/assets/{classDiagram-v2-2358418a-w1VkNGJj.js → classDiagram-v2-2358418a-vH4j7skr.js} +1 -1
  8. package/dist/assets/clone-CtWwIeUb.js +1 -0
  9. package/dist/assets/{createText-1719965b-CEinakVP.js → createText-1719965b-COeSYnf3.js} +1 -1
  10. package/dist/assets/{cssMode-DPqRki4y.js → cssMode-Doc7QRKn.js} +1 -1
  11. package/dist/assets/{edges-96097737-Cb0F1_3K.js → edges-96097737-D09v6R_r.js} +1 -1
  12. package/dist/assets/{erDiagram-0228fc6a-C-N2fx-J.js → erDiagram-0228fc6a-CbZ6rfxl.js} +1 -1
  13. package/dist/assets/{flowDb-c6c81e3f-D1Xz_8Gf.js → flowDb-c6c81e3f-CnZOzhdk.js} +1 -1
  14. package/dist/assets/{flowDiagram-50d868cf-DyPSZyAj.js → flowDiagram-50d868cf-jv-xWM2p.js} +1 -1
  15. package/dist/assets/flowDiagram-v2-4f6560a1-BiyrkIKs.js +1 -0
  16. package/dist/assets/{flowchart-elk-definition-6af322e1-Dr1DDXwE.js → flowchart-elk-definition-6af322e1-D8pf677G.js} +1 -1
  17. package/dist/assets/{freemarker2-C3DvPFaK.js → freemarker2-CL0o23Gj.js} +1 -1
  18. package/dist/assets/{ganttDiagram-a2739b55-DmvY1GRj.js → ganttDiagram-a2739b55-BAPQzC4u.js} +1 -1
  19. package/dist/assets/{gitGraphDiagram-82fe8481-CoXfPYYi.js → gitGraphDiagram-82fe8481-BI2x71m0.js} +1 -1
  20. package/dist/assets/{graph-BkDQy7Qt.js → graph-CZK4Bjpq.js} +1 -1
  21. package/dist/assets/{handlebars-BcTFdqjl.js → handlebars-CCG38Pg6.js} +1 -1
  22. package/dist/assets/{html-Dg-O6XFr.js → html-BddshTWG.js} +1 -1
  23. package/dist/assets/{htmlMode-B_wqYWvn.js → htmlMode-xKXiYcDz.js} +1 -1
  24. package/dist/assets/{index-5325376f-kxPTR3_e.js → index-5325376f-BWMTD8RU.js} +1 -1
  25. package/dist/assets/{index-wkhI4dr6.js → index-CBe7kDkV.js} +398 -377
  26. package/dist/assets/index-MWOwVzqE.css +32 -0
  27. package/dist/assets/{infoDiagram-8eee0895-BEvqkwPI.js → infoDiagram-8eee0895-CR78btIF.js} +1 -1
  28. package/dist/assets/{javascript-DhlOH8_z.js → javascript-BPlRHPjg.js} +1 -1
  29. package/dist/assets/{journeyDiagram-c64418c1-gKtLYmmp.js → journeyDiagram-c64418c1-DZRv6FKz.js} +1 -1
  30. package/dist/assets/{jsonMode-DxTbF9OD.js → jsonMode-BYLVfdkf.js} +1 -1
  31. package/dist/assets/{layout-CDaZEk6E.js → layout-BtudyPU2.js} +1 -1
  32. package/dist/assets/{line-DNRQu8iq.js → line-DgHXrIhS.js} +1 -1
  33. package/dist/assets/{linear-Cph9Z6_j.js → linear-DtBoKICx.js} +1 -1
  34. package/dist/assets/{liquid-ByZ6JgRG.js → liquid-DxBlJk0W.js} +1 -1
  35. package/dist/assets/{lspLanguageFeatures-DzvhkgnM.js → lspLanguageFeatures-DmKVpmeH.js} +1 -1
  36. package/dist/assets/{mdx-D8RGHTl6.js → mdx-DrScsd-w.js} +1 -1
  37. package/dist/assets/{mermaid.core-BgcryF__.js → mermaid.core-Cj_NJ_lZ.js} +4 -4
  38. package/dist/assets/{mindmap-definition-8da855dc-WrxK0FcB.js → mindmap-definition-8da855dc-CMXbwtsc.js} +1 -1
  39. package/dist/assets/{pieDiagram-a8764435-VsZBsiQy.js → pieDiagram-a8764435-Bd6rfpJv.js} +1 -1
  40. package/dist/assets/{python-CXVtk_cg.js → python-Crbi7B7n.js} +1 -1
  41. package/dist/assets/{quadrantDiagram-1e28029f-BVlgwOvU.js → quadrantDiagram-1e28029f-H-FdBQn6.js} +1 -1
  42. package/dist/assets/{razor-0tind7h2.js → razor-DHyrzIfE.js} +1 -1
  43. package/dist/assets/{requirementDiagram-08caed73-CpPMPoYp.js → requirementDiagram-08caed73-BSyCVDSG.js} +1 -1
  44. package/dist/assets/{sankeyDiagram-a04cb91d-Cm5nnRmc.js → sankeyDiagram-a04cb91d-S6E6BReg.js} +1 -1
  45. package/dist/assets/{sequenceDiagram-c5b8d532-DpMlJvJB.js → sequenceDiagram-c5b8d532-BMHY4KMj.js} +1 -1
  46. package/dist/assets/{stateDiagram-1ecb1508-DU1zc7vq.js → stateDiagram-1ecb1508-BMrMw6XR.js} +1 -1
  47. package/dist/assets/{stateDiagram-v2-c2b004d7-D-0RgmAp.js → stateDiagram-v2-c2b004d7-B5SIFUb_.js} +1 -1
  48. package/dist/assets/{styles-b4e223ce-BSO-yNWV.js → styles-b4e223ce-DqiXwnx3.js} +1 -1
  49. package/dist/assets/{styles-ca3715f6-CHnsn2Ro.js → styles-ca3715f6-jNxW2Db8.js} +1 -1
  50. package/dist/assets/{styles-d45a18b0-B-rVGjEq.js → styles-d45a18b0-C4nlfLcZ.js} +1 -1
  51. package/dist/assets/{svgDrawCommon-b86b1483-CA3Pl89f.js → svgDrawCommon-b86b1483-FIWFuZfb.js} +1 -1
  52. package/dist/assets/{timeline-definition-faaaa080-BcihLR6s.js → timeline-definition-faaaa080-CEQDoqdf.js} +1 -1
  53. package/dist/assets/{tsMode-D9GGa5Ur.js → tsMode-DnNy3rE9.js} +1 -1
  54. package/dist/assets/{typescript-BT9CK_EL.js → typescript-YBZ4vw5B.js} +1 -1
  55. package/dist/assets/{xml-DNO75J-T.js → xml-BJGGYD70.js} +1 -1
  56. package/dist/assets/{xychartDiagram-f5964ef8-DJTwe32X.js → xychartDiagram-f5964ef8-DUNOFOk0.js} +1 -1
  57. package/dist/assets/{yaml-7CVzhiP2.js → yaml-BMY4mu5s.js} +1 -1
  58. package/dist/index.html +8 -3
  59. package/dist/manifest.webmanifest +30 -0
  60. package/dist/pwa-icon-192.png +0 -0
  61. package/dist/pwa-icon-512.png +0 -0
  62. package/dist/sw.js +105 -0
  63. package/index.html +6 -1
  64. package/package.json +13 -13
  65. package/public/manifest.webmanifest +30 -0
  66. package/public/pwa-icon-192.png +0 -0
  67. package/public/pwa-icon-512.png +0 -0
  68. package/public/sw.js +105 -0
  69. package/src/App.tsx +13 -1
  70. package/src/api/README.md +1 -0
  71. package/src/api/adapters.ts +63 -0
  72. package/src/api/auth-token.ts +51 -0
  73. package/src/api/auth.ts +46 -0
  74. package/src/api/automation.ts +10 -0
  75. package/src/api/base.ts +20 -17
  76. package/src/api/config.ts +5 -1
  77. package/src/api/knowledge.ts +59 -0
  78. package/src/api/sessions.ts +35 -3
  79. package/src/api/skill-hub.ts +126 -0
  80. package/src/api/workspace.ts +33 -1
  81. package/src/api/worktree-environments.ts +53 -0
  82. package/src/api.ts +62 -7
  83. package/src/client-build-info.ts +19 -0
  84. package/src/components/ConfigView.scss +596 -28
  85. package/src/components/ConfigView.tsx +569 -138
  86. package/src/components/NavRail.scss +1 -2
  87. package/src/components/NavRail.tsx +33 -3
  88. package/src/components/Sidebar.scss +0 -44
  89. package/src/components/Sidebar.tsx +110 -37
  90. package/src/components/auth/AuthGate.scss +79 -0
  91. package/src/components/auth/AuthGate.tsx +174 -0
  92. package/src/components/automation-view/@components/AutomationTaskComposer.tsx +220 -0
  93. package/src/components/automation-view/@components/AutomationTriggerRow.tsx +192 -0
  94. package/src/components/automation-view/@hooks/use-automation-startup-options-data.tsx +289 -0
  95. package/src/components/automation-view/@hooks/use-automation-startup-static-options.ts +51 -0
  96. package/src/components/automation-view/@utils/sender-model-options.tsx +52 -0
  97. package/src/components/automation-view/@utils/startup-options.ts +26 -0
  98. package/src/components/automation-view/AutomationEmptyGuide.tsx +61 -0
  99. package/src/components/automation-view/AutomationEmptyLanding.scss +165 -0
  100. package/src/components/automation-view/AutomationEmptyLanding.tsx +211 -0
  101. package/src/components/automation-view/AutomationRuleDetailPreview.tsx +179 -0
  102. package/src/components/automation-view/PanelTitleActions.tsx +66 -0
  103. package/src/components/automation-view/RuleFormPanel.scss +172 -49
  104. package/src/components/automation-view/RuleFormPanel.tsx +196 -91
  105. package/src/components/automation-view/RuleSidebar.scss +128 -41
  106. package/src/components/automation-view/RuleSidebar.tsx +173 -89
  107. package/src/components/automation-view/RunHistoryPanel.scss +307 -72
  108. package/src/components/automation-view/RunHistoryPanel.tsx +185 -165
  109. package/src/components/automation-view/TaskList.scss +130 -64
  110. package/src/components/automation-view/TaskList.tsx +15 -31
  111. package/src/components/automation-view/TriggerList.scss +87 -8
  112. package/src/components/automation-view/TriggerList.tsx +14 -173
  113. package/src/components/automation-view/index.scss +165 -37
  114. package/src/components/automation-view/index.tsx +174 -87
  115. package/src/components/automation-view/types.ts +13 -0
  116. package/src/components/chat/AGENTS.md +3 -1
  117. package/src/components/chat/ChatHeader.tsx +56 -33
  118. package/src/components/chat/ChatHistoryView.tsx +254 -123
  119. package/src/components/chat/NewSessionGuide.scss +274 -204
  120. package/src/components/chat/NewSessionGuide.tsx +46 -111
  121. package/src/components/chat/NewSessionGuideStarterList.tsx +190 -0
  122. package/src/components/chat/NewSessionGuideStarterSection.tsx +121 -0
  123. package/src/components/chat/bottom-dock-constants.ts +4 -0
  124. package/src/components/chat/conversation-starter-apply.ts +181 -0
  125. package/src/components/chat/git-controls/ChatGitControls.scss +65 -0
  126. package/src/components/chat/git-controls/DraftGitControls.tsx +14 -0
  127. package/src/components/chat/git-controls/DraftWorktreeEnvironmentDropdown.tsx +115 -0
  128. package/src/components/chat/messages/MessageItem.tsx +21 -6
  129. package/src/components/chat/messages/MessageStatusNotice.tsx +12 -4
  130. package/src/components/chat/messages/build-chat-history-status-notices.ts +18 -13
  131. package/src/components/chat/messages/message-action-utils.ts +29 -0
  132. package/src/components/chat/new-session-guide-config.ts +19 -0
  133. package/src/components/chat/new-session-guide-items.ts +172 -0
  134. package/src/components/chat/new-session-guide-list-order.ts +58 -0
  135. package/src/components/chat/sender/@components/account-select/AccountSelectControl.scss +112 -0
  136. package/src/components/chat/sender/@components/account-select/AccountSelectControl.tsx +280 -0
  137. package/src/components/chat/sender/@components/account-select/AccountSelectDropdown.scss +155 -0
  138. package/src/components/chat/sender/@components/adapter-select/AdapterSelectControl.scss +51 -12
  139. package/src/components/chat/sender/@components/adapter-select/AdapterSelectDropdown.scss +14 -0
  140. package/src/components/chat/sender/@components/effort-select/EffortSelectControl.scss +36 -0
  141. package/src/components/chat/sender/@components/effort-select/EffortSelectControl.tsx +17 -12
  142. package/src/components/chat/sender/@components/model-select/ModelSelectControl.scss +62 -0
  143. package/src/components/chat/sender/@components/model-select/ModelSelectControl.tsx +17 -12
  144. package/src/components/chat/sender/@components/model-select/ModelSelectMenu.scss +2 -0
  145. package/src/components/chat/sender/@components/model-select/ModelSelectMenuLabels.scss +24 -0
  146. package/src/components/chat/sender/@components/permission-mode-control/PermissionModeControl.scss +199 -0
  147. package/src/components/chat/sender/@components/permission-mode-control/PermissionModeControl.tsx +172 -0
  148. package/src/components/chat/sender/@components/reference-actions/ReferenceActionsControl.scss +1 -10
  149. package/src/components/chat/sender/@components/reference-actions/ReferenceActionsControl.tsx +16 -65
  150. package/src/components/chat/sender/@components/sender-body/SenderBody.tsx +13 -1
  151. package/src/components/chat/sender/@components/sender-header-controls/SenderHeaderControls.tsx +157 -0
  152. package/src/components/chat/sender/@components/sender-monaco-editor/monaco-runtime.ts +1 -17
  153. package/src/components/chat/sender/@components/sender-toolbar/SenderSelectBase.scss +18 -2
  154. package/src/components/chat/sender/@components/sender-toolbar/SenderSelectShared.scss +18 -1
  155. package/src/components/chat/sender/@components/sender-toolbar/SenderToolbar.scss +2 -0
  156. package/src/components/chat/sender/@components/sender-toolbar/SenderToolbar.tsx +40 -40
  157. package/src/components/chat/sender/@components/session-target/SenderSessionTargetBar.scss +215 -0
  158. package/src/components/chat/sender/@components/session-target/SenderSessionTargetBar.tsx +185 -0
  159. package/src/components/chat/sender/@core/build-sender-toolbar.ts +6 -0
  160. package/src/components/chat/sender/@core/create-sender-toolbar-handlers.ts +21 -1
  161. package/src/components/chat/sender/@core/get-sender-runtime-state.ts +3 -2
  162. package/src/components/chat/sender/@core/sender-toolbar-bindings.ts +12 -0
  163. package/src/components/chat/sender/@hooks/use-sender-controller.ts +56 -1
  164. package/src/components/chat/sender/@hooks/use-sender-reference-actions.ts +9 -66
  165. package/src/components/chat/sender/@types/sender-props.ts +18 -0
  166. package/src/components/chat/sender/@types/sender-toolbar-types.ts +8 -1
  167. package/src/components/chat/sender/@types/sender-types.ts +1 -3
  168. package/src/components/chat/sender/@utils/sender-constants.ts +1 -1
  169. package/src/components/chat/sender/Sender.scss +257 -2
  170. package/src/components/chat/sender/Sender.tsx +1 -0
  171. package/src/components/chat/status-bar/ChatStatusBar.scss +85 -0
  172. package/src/components/chat/status-bar/ChatStatusBar.tsx +48 -0
  173. package/src/components/chat/terminal/@components/TerminalManagerList.tsx +191 -0
  174. package/src/components/chat/terminal/@components/TerminalPane.scss +71 -0
  175. package/src/components/chat/terminal/@components/TerminalPane.tsx +137 -0
  176. package/src/components/chat/terminal/@components/TerminalPanelActions.tsx +75 -0
  177. package/src/components/chat/terminal/@hooks/use-terminal-instance.ts +36 -0
  178. package/src/components/chat/terminal/@hooks/use-terminal-session.ts +18 -21
  179. package/src/components/chat/terminal/@hooks/use-terminal-title-editor.ts +72 -0
  180. package/src/components/chat/terminal/@utils/terminal-keyboard.ts +141 -0
  181. package/src/components/chat/terminal/@utils/terminal-panes.ts +123 -0
  182. package/src/components/chat/terminal/ChatTerminalView.scss +310 -38
  183. package/src/components/chat/terminal/ChatTerminalView.tsx +151 -79
  184. package/src/components/chat/tools/core/ToolDiffViewer.tsx +3 -17
  185. package/src/components/chat/workspace-drawer/ChatWorkspaceDrawer.scss +778 -0
  186. package/src/components/chat/workspace-drawer/ChatWorkspaceDrawer.tsx +112 -0
  187. package/src/components/chat/workspace-drawer/ChatWorkspaceDrawerToolbar.tsx +183 -0
  188. package/src/components/chat/workspace-drawer/WorkspaceDrawerChangedFileRow.tsx +75 -0
  189. package/src/components/chat/workspace-drawer/WorkspaceDrawerChangedFiles.tsx +161 -0
  190. package/src/components/chat/workspace-drawer/WorkspaceDrawerChangedFolderTree.tsx +191 -0
  191. package/src/components/chat/workspace-drawer/WorkspaceDrawerTree.tsx +35 -0
  192. package/src/components/chat/workspace-drawer/WorkspaceDrawerTreeState.tsx +17 -0
  193. package/src/components/chat/workspace-drawer/changed-files-model.ts +152 -0
  194. package/src/components/chat/workspace-drawer/workspace-drawer-icons.ts +110 -0
  195. package/src/components/chat/workspace-file-editor/WorkspaceFileBreadcrumb.tsx +17 -0
  196. package/src/components/chat/workspace-file-editor/WorkspaceFileEditorView.scss +283 -0
  197. package/src/components/chat/workspace-file-editor/WorkspaceFileEditorView.tsx +165 -0
  198. package/src/components/chat/workspace-file-editor/WorkspaceFileTabs.tsx +135 -0
  199. package/src/components/chat/workspace-file-editor/use-workspace-file-editor-state.ts +113 -0
  200. package/src/components/chat/workspace-file-editor/workspace-file-editor-language.ts +55 -0
  201. package/src/components/composer-landing/ComposerLanding.scss +75 -0
  202. package/src/components/composer-landing/ComposerLanding.tsx +47 -0
  203. package/src/components/config/AGENTS.md +45 -0
  204. package/src/components/config/AdapterAccountsManager.scss +540 -0
  205. package/src/components/config/AdapterAccountsManager.tsx +846 -0
  206. package/src/components/config/AppSettingsPanel.tsx +85 -9
  207. package/src/components/config/ConfigAboutSection.scss +7 -1
  208. package/src/components/config/ConfigAboutSection.tsx +21 -3
  209. package/src/components/config/ConfigEditors.scss +12 -0
  210. package/src/components/config/ConfigFieldRow.scss +88 -4
  211. package/src/components/config/ConfigSectionForm.scss +88 -3
  212. package/src/components/config/ConfigSectionForm.tsx +948 -138
  213. package/src/components/config/ConfigSectionPanel.tsx +188 -12
  214. package/src/components/config/ConfigSourceSwitch.tsx +32 -18
  215. package/src/components/config/DetailCollectionFieldActions.tsx +63 -0
  216. package/src/components/config/DetailListField.tsx +413 -0
  217. package/src/components/config/McpServerItemEditor.tsx +154 -0
  218. package/src/components/config/RecommendedModelsItemEditor.tsx +146 -0
  219. package/src/components/config/WorktreeEnvironmentDetailView.tsx +126 -0
  220. package/src/components/config/WorktreeEnvironmentListView.tsx +126 -0
  221. package/src/components/config/WorktreeEnvironmentPanel.scss +430 -0
  222. package/src/components/config/WorktreeEnvironmentPanel.tsx +147 -0
  223. package/src/components/config/WorktreeEnvironmentScriptEditorCard.tsx +125 -0
  224. package/src/components/config/WorktreeEnvironmentScriptEditors.tsx +189 -0
  225. package/src/components/config/configConflict.ts +41 -0
  226. package/src/components/config/configDetail.ts +381 -0
  227. package/src/components/config/configSchema.ts +850 -179
  228. package/src/components/config/configUtils.ts +1 -1
  229. package/src/components/config/record-editors/RecordEditors.scss +187 -2
  230. package/src/components/config/record-editors/RecordJsonEditor.tsx +27 -2
  231. package/src/components/config/record-editors/SchemaObjectEditor.tsx +183 -0
  232. package/src/components/config/record-editors/SchemaRecordEditor.tsx +184 -0
  233. package/src/components/config/record-editors/index.tsx +2 -1
  234. package/src/components/config/record-editors/schemaRecordUtils.ts +55 -0
  235. package/src/components/config/use-worktree-environment-auto-save.ts +386 -0
  236. package/src/components/config/worktree-environment-panel-model.ts +108 -0
  237. package/src/components/dock-panel/DockPanel.scss +84 -17
  238. package/src/components/dock-panel/DockPanel.tsx +37 -34
  239. package/src/components/dock-panel/DockPanelHeader.tsx +65 -0
  240. package/src/components/dock-panel/use-dock-panel-fullscreen.ts +51 -0
  241. package/src/components/knowledge-base/KnowledgeBaseView.scss +276 -38
  242. package/src/components/knowledge-base/KnowledgeBaseView.tsx +252 -46
  243. package/src/components/knowledge-base/components/@hooks/use-skills-cli-modal-controller.ts +157 -0
  244. package/src/components/knowledge-base/components/@hooks/use-skills-tab-actions.ts +63 -0
  245. package/src/components/knowledge-base/components/ActionButton.scss +30 -4
  246. package/src/components/knowledge-base/components/ActionButton.tsx +13 -3
  247. package/src/components/knowledge-base/components/CreateSkillModal.tsx +59 -0
  248. package/src/components/knowledge-base/components/EmptyState.scss +4 -2
  249. package/src/components/knowledge-base/components/EntitiesTab.tsx +20 -20
  250. package/src/components/knowledge-base/components/EntityList.scss +3 -0
  251. package/src/components/knowledge-base/components/FilterBar.scss +1 -0
  252. package/src/components/knowledge-base/components/FilterBar.tsx +12 -8
  253. package/src/components/knowledge-base/components/FlowsTab.tsx +20 -20
  254. package/src/components/knowledge-base/components/KnowledgeBaseHeader.tsx +7 -6
  255. package/src/components/knowledge-base/components/KnowledgeContentControls.tsx +35 -0
  256. package/src/components/knowledge-base/components/KnowledgeList.scss +14 -3
  257. package/src/components/knowledge-base/components/KnowledgeMobilePanel.tsx +122 -0
  258. package/src/components/knowledge-base/components/KnowledgeSidebar.tsx +97 -0
  259. package/src/components/knowledge-base/components/LoadingState.scss +2 -1
  260. package/src/components/knowledge-base/components/ProjectSkillsList.tsx +79 -0
  261. package/src/components/knowledge-base/components/RuleList.scss +3 -0
  262. package/src/components/knowledge-base/components/RulesTab.tsx +31 -30
  263. package/src/components/knowledge-base/components/SectionHeader.scss +13 -1
  264. package/src/components/knowledge-base/components/SectionHeader.tsx +5 -3
  265. package/src/components/knowledge-base/components/SkillArchiveInput.tsx +43 -0
  266. package/src/components/knowledge-base/components/SkillHubResultItem.tsx +112 -0
  267. package/src/components/knowledge-base/components/SkillMarketResults.tsx +98 -0
  268. package/src/components/knowledge-base/components/SkillMarketView.tsx +198 -0
  269. package/src/components/knowledge-base/components/SkillMarketView.types.ts +28 -0
  270. package/src/components/knowledge-base/components/SkillRegistryErrors.tsx +21 -0
  271. package/src/components/knowledge-base/components/SkillRegistryModal.tsx +74 -0
  272. package/src/components/knowledge-base/components/SkillsCliModal.tsx +154 -0
  273. package/src/components/knowledge-base/components/SkillsTab.scss +424 -0
  274. package/src/components/knowledge-base/components/SkillsTab.tsx +166 -35
  275. package/src/components/knowledge-base/components/SkillsTabActions.tsx +88 -0
  276. package/src/components/knowledge-base/components/SpecList.scss +3 -0
  277. package/src/components/knowledge-base/components/TabContent.scss +4 -3
  278. package/src/components/knowledge-base/components/skill-hub-utils.ts +108 -0
  279. package/src/components/knowledge-base/components/use-skill-market-filters.ts +37 -0
  280. package/src/components/knowledge-base/components/use-skill-market-query-input.ts +44 -0
  281. package/src/components/knowledge-base/components/use-skill-market-search.ts +49 -0
  282. package/src/components/knowledge-base/components/use-skill-registry-modal.ts +68 -0
  283. package/src/components/monaco/monaco-runtime.ts +44 -0
  284. package/src/components/monaco/use-monaco-theme.ts +63 -0
  285. package/src/components/nav-rail-account-actions.tsx +104 -0
  286. package/src/components/server-connection/ServerConnectionGate.scss +356 -0
  287. package/src/components/server-connection/ServerConnectionGate.tsx +238 -0
  288. package/src/components/server-connection/ServerConnectionProfileModal.tsx +145 -0
  289. package/src/components/server-connection/ServerConnectionProfiles.tsx +113 -0
  290. package/src/components/server-connection/ServerConnectionUrlInput.tsx +85 -0
  291. package/src/components/sidebar/SidebarHeader.scss +5 -41
  292. package/src/components/sidebar/SidebarHeader.tsx +117 -91
  293. package/src/components/sidebar/SidebarHeaderSearchActions.tsx +24 -28
  294. package/src/components/sidebar/sidebar-search-visibility.ts +18 -0
  295. package/src/components/sidebar-list/SidebarListHeader.scss +246 -0
  296. package/src/components/sidebar-list/SidebarListHeader.tsx +146 -0
  297. package/src/components/workspace/ContextFilePicker.scss +9 -26
  298. package/src/components/workspace/ContextFilePicker.tsx +31 -113
  299. package/src/components/workspace/context-file-types.ts +36 -0
  300. package/src/components/workspace/project-file-tree/ProjectFileTree.scss +298 -0
  301. package/src/components/workspace/project-file-tree/ProjectFileTree.tsx +138 -0
  302. package/src/components/workspace/project-file-tree/ProjectFileTreeRow.tsx +167 -0
  303. package/src/components/workspace/project-file-tree/ProjectFileTreeRowContextMenu.tsx +106 -0
  304. package/src/components/workspace/project-file-tree/ProjectFileTreeRows.tsx +139 -0
  305. package/src/components/workspace/project-file-tree/project-file-tree-helpers.ts +101 -0
  306. package/src/components/workspace/project-file-tree/project-file-tree-icons.ts +93 -0
  307. package/src/components/workspace/project-file-tree/project-file-tree-types.ts +27 -0
  308. package/src/components/workspace/project-file-tree/use-project-file-tree-data.ts +197 -0
  309. package/src/components/workspace/project-file-tree/use-project-file-tree-selection.ts +144 -0
  310. package/src/hooks/chat/chat-session-target.ts +69 -0
  311. package/src/hooks/chat/chat-session-workspace-draft.ts +11 -4
  312. package/src/hooks/chat/interaction-state.ts +1 -0
  313. package/src/hooks/chat/optimistic-session-creation.ts +189 -0
  314. package/src/hooks/chat/use-chat-adapter-account-selection.tsx +156 -0
  315. package/src/hooks/chat/use-chat-route-bottom-panel.ts +181 -0
  316. package/src/hooks/chat/use-chat-route-deep-link-view.ts +33 -0
  317. package/src/hooks/chat/use-chat-session-actions.ts +259 -65
  318. package/src/hooks/chat/use-chat-session-messages.ts +71 -4
  319. package/src/hooks/chat/use-chat-session.ts +36 -1
  320. package/src/hooks/chat/workspace-file-panel-state.ts +43 -0
  321. package/src/hooks/session-subscription-cache.ts +25 -0
  322. package/src/hooks/use-chat-layout-query-state.ts +29 -0
  323. package/src/hooks/use-sender-header-query-state.ts +35 -0
  324. package/src/hooks/use-session-subscription.ts +17 -8
  325. package/src/hooks/useQueryParams.ts +91 -23
  326. package/src/i18n-resources.ts +44 -0
  327. package/src/i18n.ts +21 -6
  328. package/src/main.tsx +8 -0
  329. package/src/pwa.ts +46 -0
  330. package/src/resources/locales/en.json +741 -24
  331. package/src/resources/locales/zh.json +743 -26
  332. package/src/routes/ChatRoute.scss +110 -7
  333. package/src/routes/ChatRoute.tsx +11 -165
  334. package/src/routes/ChatRouteBottomPanel.tsx +47 -0
  335. package/src/routes/ChatRouteView.tsx +199 -0
  336. package/src/runtime-config.ts +155 -2
  337. package/src/server-connection-history.ts +179 -0
  338. package/src/store/index.ts +151 -3
  339. package/src/styles/global.scss +3 -0
  340. package/src/utils/mobile-viewport.ts +67 -0
  341. package/src/version-compatibility.ts +37 -0
  342. package/src/vite-env.d.ts +9 -0
  343. package/src/ws.ts +20 -9
  344. package/vite.config.ts +23 -1
  345. package/dist/assets/channel-Dnopc5A6.js +0 -1
  346. package/dist/assets/clone-sQthahUA.js +0 -1
  347. package/dist/assets/flowDiagram-v2-4f6560a1-OazrdWQO.js +0 -1
  348. package/dist/assets/index-o93dlo92.css +0 -32
  349. package/src/components/chat/NewSessionGuideCompactPanel.tsx +0 -130
  350. package/src/components/chat/NewSessionGuideGrid.tsx +0 -141
  351. package/src/components/chat/sender/@components/reference-actions/ReferencePermissionActionsPopover.tsx +0 -114
@@ -1,9 +1,11 @@
1
1
  import './DockPanel.scss'
2
2
 
3
- import { Button } from 'antd'
4
3
  import type { CSSProperties, PointerEvent as ReactPointerEvent, ReactNode } from 'react'
5
4
  import { useEffect, useMemo, useRef, useState } from 'react'
6
5
 
6
+ import { DockPanelHeader } from './DockPanelHeader'
7
+ import { useDockPanelFullscreen } from './use-dock-panel-fullscreen'
8
+
7
9
  const DEFAULT_PANEL_HEIGHT = 240
8
10
 
9
11
  const clampPanelHeight = (height: number, minHeight: number, maxHeight: number) =>
@@ -17,11 +19,15 @@ const shouldIgnoreResizePointerDown = (target: HTMLElement | null) =>
17
19
  export function DockPanel({
18
20
  enterMotion = 'slide-up',
19
21
  allowResize = true,
22
+ allowFullscreen = false,
20
23
  children,
21
24
  className,
22
25
  closeLabel,
23
26
  defaultHeight = DEFAULT_PANEL_HEIGHT,
24
27
  footer,
28
+ fullscreenEnterLabel,
29
+ fullscreenExitLabel,
30
+ isResizeDisabled = false,
25
31
  isOpen = true,
26
32
  maxHeight = 520,
27
33
  meta,
@@ -33,6 +39,7 @@ export function DockPanel({
33
39
  actions
34
40
  }: {
35
41
  enterMotion?: 'none' | 'slide-up'
42
+ allowFullscreen?: boolean
36
43
  allowResize?: boolean
37
44
  actions?: ReactNode
38
45
  children: ReactNode
@@ -40,7 +47,10 @@ export function DockPanel({
40
47
  closeLabel?: string
41
48
  defaultHeight?: number
42
49
  footer?: ReactNode
50
+ fullscreenEnterLabel?: string
51
+ fullscreenExitLabel?: string
43
52
  isOpen?: boolean
53
+ isResizeDisabled?: boolean
44
54
  maxHeight?: number
45
55
  meta?: ReactNode
46
56
  minHeight?: number
@@ -52,12 +62,14 @@ export function DockPanel({
52
62
  const panelRef = useRef<HTMLDivElement | null>(null)
53
63
  const resizeSessionRef = useRef<{ maxHeight: number; startHeight: number; startY: number } | null>(null)
54
64
  const [isResizing, setIsResizing] = useState(false)
65
+ const { isFullscreen, isFullscreenExiting, toggleFullscreen } = useDockPanelFullscreen()
55
66
  const [panelHeight, setPanelHeight] = useState(() => {
56
67
  const storedHeight = Number(localStorage.getItem(storageKey))
57
68
  return Number.isFinite(storedHeight) && storedHeight > 0
58
69
  ? clampPanelHeight(storedHeight, minHeight, maxHeight)
59
70
  : clampPanelHeight(defaultHeight, minHeight, maxHeight)
60
71
  })
72
+ const resizeEnabled = allowResize && !isResizeDisabled && !isFullscreen
61
73
 
62
74
  useEffect(() => {
63
75
  localStorage.setItem(storageKey, String(panelHeight))
@@ -71,7 +83,7 @@ export function DockPanel({
71
83
  }, [])
72
84
 
73
85
  useEffect(() => {
74
- if (!allowResize || !isResizing) {
86
+ if (!resizeEnabled || !isResizing) {
75
87
  return
76
88
  }
77
89
 
@@ -106,10 +118,10 @@ export function DockPanel({
106
118
  window.removeEventListener('pointerup', stopResizing)
107
119
  window.removeEventListener('pointercancel', stopResizing)
108
120
  }
109
- }, [allowResize, isResizing, minHeight])
121
+ }, [isResizing, minHeight, resizeEnabled])
110
122
 
111
123
  const handleResizePointerDown = (event: ReactPointerEvent<HTMLDivElement>) => {
112
- if (shouldIgnoreResizePointerDown(event.target as HTMLElement | null)) {
124
+ if (!resizeEnabled || shouldIgnoreResizePointerDown(event.target as HTMLElement | null)) {
113
125
  return
114
126
  }
115
127
 
@@ -144,38 +156,29 @@ export function DockPanel({
144
156
  ref={panelRef}
145
157
  className={`dock-panel ${isOpen && enterMotion === 'slide-up' ? 'is-entering-slide-up' : ''} ${
146
158
  isOpen ? 'is-open' : 'is-closing'
147
- } ${className ?? ''} ${isResizing ? 'is-resizing' : ''} ${allowResize ? 'is-resizable' : 'is-static'}`}
159
+ } ${className ?? ''} ${isResizing ? 'is-resizing' : ''} ${resizeEnabled ? 'is-resizable' : 'is-static'} ${
160
+ isResizeDisabled || isFullscreen ? 'is-resize-disabled' : ''
161
+ } ${isFullscreen ? 'is-fullscreen' : ''} ${isFullscreenExiting ? 'is-fullscreen-exiting' : ''}`}
148
162
  style={panelStyle as CSSProperties}
149
163
  >
150
- <div
151
- className={`dock-panel__resize-handle ${allowResize ? 'is-resizable' : 'is-static'}`}
152
- title={allowResize ? resizeLabel : undefined}
153
- onPointerDown={allowResize ? handleResizePointerDown : undefined}
154
- >
155
- <div className='dock-panel__header-main'>
156
- <span className='dock-panel__title'>{title}</span>
157
- {meta != null && (
158
- <span className='dock-panel__meta'>{meta}</span>
159
- )}
160
- </div>
161
- <div className='dock-panel__header-spacer' />
162
- {(actions != null || onClose != null) && (
163
- <div className='dock-panel__header-actions'>
164
- {actions}
165
- {onClose != null && closeLabel != null && (
166
- <Button
167
- type='text'
168
- className='dock-panel__close-btn'
169
- data-dock-panel-no-resize='true'
170
- icon={<span className='material-symbols-rounded'>close</span>}
171
- title={closeLabel}
172
- aria-label={closeLabel}
173
- onClick={onClose}
174
- />
175
- )}
176
- </div>
177
- )}
178
- </div>
164
+ {resizeEnabled && (
165
+ <div
166
+ className='dock-panel__resize-strip'
167
+ title={resizeLabel}
168
+ onPointerDown={handleResizePointerDown}
169
+ />
170
+ )}
171
+ <DockPanelHeader
172
+ actions={actions}
173
+ closeLabel={closeLabel}
174
+ fullscreenEnterLabel={fullscreenEnterLabel}
175
+ fullscreenExitLabel={fullscreenExitLabel}
176
+ isFullscreen={isFullscreen}
177
+ meta={meta}
178
+ title={title}
179
+ onClose={onClose}
180
+ onToggleFullscreen={allowFullscreen ? toggleFullscreen : undefined}
181
+ />
179
182
 
180
183
  <div className='dock-panel__body'>
181
184
  {children}
@@ -0,0 +1,65 @@
1
+ import { Button } from 'antd'
2
+ import type { ReactNode } from 'react'
3
+
4
+ export function DockPanelHeader({
5
+ actions,
6
+ closeLabel,
7
+ fullscreenEnterLabel,
8
+ fullscreenExitLabel,
9
+ isFullscreen,
10
+ meta,
11
+ onClose,
12
+ onToggleFullscreen,
13
+ title
14
+ }: {
15
+ actions?: ReactNode
16
+ closeLabel?: string
17
+ fullscreenEnterLabel?: string
18
+ fullscreenExitLabel?: string
19
+ isFullscreen: boolean
20
+ meta?: ReactNode
21
+ onClose?: () => void
22
+ onToggleFullscreen?: () => void
23
+ title: ReactNode
24
+ }) {
25
+ const fullscreenLabel = isFullscreen ? fullscreenExitLabel : fullscreenEnterLabel
26
+
27
+ return (
28
+ <div className='dock-panel__header'>
29
+ <div className='dock-panel__header-main'>
30
+ <span className='dock-panel__title'>{title}</span>
31
+ {meta != null && (
32
+ <span className='dock-panel__meta'>{meta}</span>
33
+ )}
34
+ </div>
35
+ <div className='dock-panel__header-spacer' />
36
+ {(actions != null || onToggleFullscreen != null || onClose != null) && (
37
+ <div className='dock-panel__header-actions'>
38
+ {actions}
39
+ {onToggleFullscreen != null && fullscreenLabel != null && (
40
+ <Button
41
+ type='text'
42
+ className='dock-panel__close-btn dock-panel__fullscreen-btn'
43
+ data-dock-panel-no-resize='true'
44
+ icon={<span className='material-symbols-rounded'>{isFullscreen ? 'fullscreen_exit' : 'fullscreen'}</span>}
45
+ title={fullscreenLabel}
46
+ aria-label={fullscreenLabel}
47
+ onClick={onToggleFullscreen}
48
+ />
49
+ )}
50
+ {onClose != null && closeLabel != null && (
51
+ <Button
52
+ type='text'
53
+ className='dock-panel__close-btn'
54
+ data-dock-panel-no-resize='true'
55
+ icon={<span className='material-symbols-rounded'>close</span>}
56
+ title={closeLabel}
57
+ aria-label={closeLabel}
58
+ onClick={onClose}
59
+ />
60
+ )}
61
+ </div>
62
+ )}
63
+ </div>
64
+ )
65
+ }
@@ -0,0 +1,51 @@
1
+ import { useCallback, useEffect, useRef, useState } from 'react'
2
+
3
+ const FULLSCREEN_EXIT_ANIMATION_MS = 180
4
+
5
+ export function useDockPanelFullscreen() {
6
+ const [isFullscreen, setIsFullscreen] = useState(false)
7
+ const [isFullscreenExiting, setIsFullscreenExiting] = useState(false)
8
+ const exitTimerRef = useRef<number | null>(null)
9
+
10
+ const clearExitTimer = useCallback(() => {
11
+ if (exitTimerRef.current == null) {
12
+ return
13
+ }
14
+
15
+ window.clearTimeout(exitTimerRef.current)
16
+ exitTimerRef.current = null
17
+ }, [])
18
+
19
+ const enterFullscreen = useCallback(() => {
20
+ clearExitTimer()
21
+ setIsFullscreenExiting(false)
22
+ setIsFullscreen(true)
23
+ }, [clearExitTimer])
24
+
25
+ const exitFullscreen = useCallback(() => {
26
+ clearExitTimer()
27
+ setIsFullscreenExiting(true)
28
+ exitTimerRef.current = window.setTimeout(() => {
29
+ setIsFullscreen(false)
30
+ setIsFullscreenExiting(false)
31
+ exitTimerRef.current = null
32
+ }, FULLSCREEN_EXIT_ANIMATION_MS)
33
+ }, [clearExitTimer])
34
+
35
+ const toggleFullscreen = useCallback(() => {
36
+ if (isFullscreen && !isFullscreenExiting) {
37
+ exitFullscreen()
38
+ return
39
+ }
40
+
41
+ enterFullscreen()
42
+ }, [enterFullscreen, exitFullscreen, isFullscreen, isFullscreenExiting])
43
+
44
+ useEffect(() => clearExitTimer, [clearExitTimer])
45
+
46
+ return {
47
+ isFullscreen,
48
+ isFullscreenExiting,
49
+ toggleFullscreen
50
+ }
51
+ }
@@ -2,11 +2,8 @@
2
2
  color: var(--text-color);
3
3
  }
4
4
 
5
- .knowledge-base-view__mobile-switcher-shell {
6
- display: none;
7
- }
8
-
9
5
  .knowledge-base-view__body {
6
+ position: relative;
10
7
  display: flex;
11
8
  flex: 1;
12
9
  min-height: 0;
@@ -14,6 +11,68 @@
14
11
  overflow: hidden;
15
12
  }
16
13
 
14
+ .knowledge-base-view--compact .knowledge-base-view__body {
15
+ flex-direction: column;
16
+ }
17
+
18
+ .knowledge-base-view__mobile-sidebar-backdrop {
19
+ position: fixed;
20
+ inset: 0;
21
+ border: none;
22
+ background: rgba(0, 0, 0, .28);
23
+ opacity: 0;
24
+ visibility: hidden;
25
+ pointer-events: none;
26
+ transition: opacity .24s ease, visibility 0s linear .24s;
27
+ z-index: 70;
28
+ }
29
+
30
+ .knowledge-base-view__mobile-sidebar-backdrop.is-open {
31
+ opacity: 1;
32
+ visibility: visible;
33
+ pointer-events: auto;
34
+ transition-delay: 0s;
35
+ }
36
+
37
+ .knowledge-base-view__mobile-sidebar-sheet {
38
+ position: fixed;
39
+ top: 0;
40
+ left: 0;
41
+ bottom: 0;
42
+ width: min(320px, calc(100vw - 24px));
43
+ max-width: calc(100vw - 24px);
44
+ padding: max(4px, env(safe-area-inset-top)) 0
45
+ max(4px, env(safe-area-inset-bottom)) max(4px, env(safe-area-inset-left));
46
+ transform: translateX(-100%);
47
+ visibility: hidden;
48
+ transition:
49
+ transform .24s cubic-bezier(.4, 0, .2, 1),
50
+ visibility 0s linear .24s;
51
+ z-index: 71;
52
+ pointer-events: none;
53
+ overscroll-behavior: contain;
54
+ }
55
+
56
+ .knowledge-base-view__mobile-sidebar-sheet.is-open {
57
+ transform: translateX(0);
58
+ visibility: visible;
59
+ pointer-events: auto;
60
+ transition-delay: 0s;
61
+ }
62
+
63
+ .knowledge-base-view__mobile-sidebar {
64
+ height: 100%;
65
+ min-height: 0;
66
+ display: flex;
67
+ flex-direction: column;
68
+ overflow: hidden;
69
+ border-right: 1px solid var(--border-color);
70
+ border-radius: 0 8px 8px 0;
71
+ background: var(--sub-bg-color);
72
+ box-shadow: 0 16px 36px rgba(15, 23, 42, .22);
73
+ overscroll-behavior: contain;
74
+ }
75
+
17
76
  .knowledge-base-view__left {
18
77
  width: var(--subpage-secondary-panel-width);
19
78
  min-width: var(--subpage-secondary-panel-width);
@@ -21,6 +80,22 @@
21
80
  display: flex;
22
81
  flex-direction: column;
23
82
  background: var(--sub-bg-color);
83
+ position: relative;
84
+ overflow: visible;
85
+ transition:
86
+ width .3s cubic-bezier(.4, 0, .2, 1),
87
+ min-width .3s cubic-bezier(.4, 0, .2, 1);
88
+ }
89
+
90
+ .knowledge-base-view__left.is-collapsed {
91
+ width: 0;
92
+ min-width: 0;
93
+ max-width: 0;
94
+ }
95
+
96
+ .knowledge-base-view__left.is-collapsed .knowledge-base-view__sidebar {
97
+ transform: translateX(calc(-1 * var(--subpage-secondary-panel-width)));
98
+ pointer-events: none;
24
99
  }
25
100
 
26
101
  .knowledge-base-view__sidebar {
@@ -28,13 +103,81 @@
28
103
  flex-direction: column;
29
104
  flex: 1;
30
105
  min-height: 0;
106
+ width: var(--subpage-secondary-panel-width);
107
+ transition: transform .3s cubic-bezier(.4, 0, .2, 1);
108
+ }
109
+
110
+ .knowledge-base-view__sidebar-top {
111
+ display: flex;
112
+ align-items: center;
113
+ gap: 6px;
114
+ padding: 10px 12px 0;
115
+ flex-shrink: 0;
116
+ }
117
+
118
+ .knowledge-base-view__new-button {
119
+ height: 28px;
120
+ display: flex;
121
+ align-items: center;
122
+ justify-content: flex-start;
123
+ padding: 0 8px;
124
+ border-radius: 6px;
125
+ font-size: 12px;
126
+ font-weight: 500;
127
+ }
128
+
129
+ .knowledge-base-view__new-button-content {
130
+ display: inline-flex;
131
+ align-items: center;
132
+ gap: 4px;
133
+ min-width: 0;
134
+ }
135
+
136
+ .knowledge-base-view__new-button .material-symbols-rounded {
137
+ font-size: 16px;
138
+ line-height: 1;
139
+ }
140
+
141
+ .ant-btn.knowledge-base-view__sidebar-control {
142
+ display: inline-flex;
143
+ align-items: center;
144
+ justify-content: center;
145
+ width: 28px !important;
146
+ min-width: 28px !important;
147
+ max-width: 28px !important;
148
+ height: 28px !important;
149
+ min-height: 28px !important;
150
+ padding: 0 !important;
151
+ color: var(--sub-text-color);
152
+ flex-shrink: 0;
153
+ }
154
+
155
+ .knowledge-base-view__sidebar-control .material-symbols-rounded {
156
+ display: inline-flex;
157
+ align-items: center;
158
+ font-size: 18px;
159
+ line-height: 1;
160
+ }
161
+
162
+ .knowledge-base-view__sidebar-search {
163
+ margin: 6px 12px 0;
164
+ width: calc(100% - 24px);
165
+ height: 30px;
166
+ border-radius: 6px;
167
+ font-size: 12px;
168
+ }
169
+
170
+ .knowledge-base-view__sidebar-search .ant-input {
171
+ font-size: 12px;
31
172
  }
32
173
 
33
174
  .knowledge-base-view__nav-list {
34
175
  display: flex;
35
176
  flex-direction: column;
177
+ flex: 1;
36
178
  gap: 6px;
37
- padding: 10px 12px 12px;
179
+ min-height: 0;
180
+ padding: 8px 12px 12px;
38
181
  overflow: auto;
39
182
  }
40
183
 
@@ -53,9 +196,9 @@
53
196
  transition: border-color .2s ease, background-color .2s ease, color .2s ease;
54
197
  }
55
198
 
56
- .knowledge-base-view__nav-item:hover {
57
- border-color: var(--sidebar-hover-bg, #e5e5e5);
58
- background: var(--sidebar-hover-bg, #e5e5e5);
199
+ .knowledge-base-view__nav-item:not(.is-active):hover {
200
+ border-color: var(--sub-border-color);
201
+ background: var(--tag-hover-bg);
59
202
  }
60
203
 
61
204
  .knowledge-base-view__nav-item.is-active {
@@ -133,57 +276,152 @@
133
276
  flex-direction: column;
134
277
  }
135
278
 
279
+ .knowledge-base-view--compact .knowledge-base-view__right {
280
+ margin: 0;
281
+ border-radius: 8px;
282
+ }
283
+
284
+ .knowledge-base-view--compact .knowledge-base-view__mobile-sidebar {
285
+ .knowledge-base-view__sidebar-top {
286
+ align-items: stretch;
287
+ padding-top: 12px;
288
+ }
289
+
290
+ .knowledge-base-view__new-button {
291
+ height: 40px;
292
+ min-height: 40px;
293
+ padding: 0 12px;
294
+ border-radius: 8px;
295
+ font-size: 13px;
296
+ }
297
+
298
+ .knowledge-base-view__new-button .material-symbols-rounded {
299
+ font-size: 18px;
300
+ }
301
+
302
+ .ant-btn.knowledge-base-view__sidebar-control {
303
+ width: 40px !important;
304
+ min-width: 40px !important;
305
+ max-width: 40px !important;
306
+ height: 40px !important;
307
+ min-height: 40px !important;
308
+ border-radius: 8px !important;
309
+ }
310
+
311
+ .knowledge-base-view__sidebar-search {
312
+ height: 40px;
313
+ min-height: 40px;
314
+ margin-top: 8px;
315
+ padding: 0 10px !important;
316
+ border-radius: 8px;
317
+ font-size: 13px;
318
+ display: flex;
319
+ align-items: center;
320
+ }
321
+
322
+ .knowledge-base-view__sidebar-search .ant-input {
323
+ font-size: 13px;
324
+ }
325
+
326
+ .knowledge-base-view__sidebar-search .knowledge-base-view__filter-icon {
327
+ font-size: 16px;
328
+ line-height: 1;
329
+ }
330
+ }
331
+
136
332
  .knowledge-base-view__right-body {
137
333
  flex: 1;
138
334
  min-height: 0;
139
335
  overflow: hidden;
140
336
  }
141
337
 
142
- @media (max-width: 1100px) {
143
- .knowledge-base-view__body {
144
- flex-direction: column;
145
- }
338
+ .knowledge-base-view__icon-button {
339
+ display: inline-flex;
340
+ align-items: center;
341
+ justify-content: center;
342
+ width: 28px !important;
343
+ min-width: 28px !important;
344
+ max-width: 28px !important;
345
+ height: 28px !important;
346
+ min-height: 28px !important;
347
+ padding: 0 !important;
348
+ border-radius: 6px !important;
349
+ }
146
350
 
147
- .knowledge-base-view__left {
148
- width: 100%;
149
- min-width: 0;
150
- max-width: none;
151
- }
351
+ .knowledge-base-view__icon-button .material-symbols-rounded {
352
+ font-size: 18px;
353
+ line-height: 1;
354
+ }
355
+
356
+ .knowledge-base-view__content-controls {
357
+ display: inline-flex;
358
+ align-items: center;
359
+ gap: 6px;
360
+ flex-shrink: 0;
361
+ }
152
362
 
153
- .knowledge-base-view__right {
154
- margin-top: 0;
155
- margin-left: var(--subpage-content-card-gap);
363
+ .app-shell--dark {
364
+ .knowledge-base-view__mobile-sidebar-backdrop {
365
+ background: rgba(0, 0, 0, .48);
156
366
  }
157
367
 
158
- .knowledge-base-view__nav-list {
159
- padding-bottom: 10px;
368
+ .knowledge-base-view__mobile-sidebar {
369
+ box-shadow: 0 18px 44px rgba(0, 0, 0, .42);
160
370
  }
161
371
  }
162
372
 
163
373
  @media (max-width: 960px) {
164
374
  .knowledge-base-view--compact {
165
- .knowledge-base-view__mobile-switcher-shell {
166
- display: block;
167
- padding: 12px;
168
- padding-bottom: 0;
375
+ .knowledge-base-view__right {
376
+ margin: 0;
377
+ min-height: 0;
378
+ border-radius: 8px;
169
379
  }
170
380
 
171
- .knowledge-base-view__mobile-switcher {
172
- width: 100%;
381
+ .knowledge-base-view__content {
382
+ padding: 10px;
383
+ gap: 8px;
384
+ }
173
385
 
174
- .ant-segmented-group {
175
- gap: 4px;
176
- }
386
+ .knowledge-base-view__section-header {
387
+ gap: 8px;
388
+ }
177
389
 
178
- .ant-segmented-item {
179
- min-height: 32px;
180
- font-size: 12px;
181
- }
390
+ .knowledge-base-view__section-actions .ant-space {
391
+ gap: 6px !important;
182
392
  }
183
393
 
184
- .knowledge-base-view__right {
185
- margin: 12px;
186
- margin-top: 12px;
394
+ .knowledge-base-view__icon-button,
395
+ .knowledge-base-view__action-button--icon-only {
396
+ width: 36px !important;
397
+ min-width: 36px !important;
398
+ max-width: 36px !important;
399
+ height: 36px !important;
400
+ min-height: 36px !important;
401
+ border-radius: 8px !important;
402
+ }
403
+
404
+ .knowledge-base-view__filter-input,
405
+ .knowledge-base-view__filter-select {
406
+ min-width: 0;
407
+ flex: 1 1 100%;
408
+ }
409
+
410
+ .knowledge-base-view__filter-input .ant-input-affix-wrapper,
411
+ .knowledge-base-view__filter-select .ant-select-selector,
412
+ .knowledge-base-view__skill-toolbar-select .ant-select-selector {
413
+ min-height: 40px !important;
414
+ height: 40px !important;
415
+ border-radius: 8px !important;
416
+ }
417
+
418
+ .knowledge-base-view__list .ant-list-items {
419
+ gap: 8px;
420
+ }
421
+
422
+ .knowledge-base-view__skill-result,
423
+ .knowledge-base-view__item {
424
+ padding: 10px;
187
425
  }
188
426
  }
189
427