@hienlh/ppm 0.8.86 → 0.8.87

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 (219) hide show
  1. package/CHANGELOG.md +193 -5
  2. package/bun.lock +5 -0
  3. package/dist/web/assets/{_basePickBy-5eBmZ_lt.js → _basePickBy-5PGDJbfF.js} +1 -1
  4. package/dist/web/assets/{_baseUniq-DimLlN0y.js → _baseUniq-BT4Ow4Kk.js} +1 -1
  5. package/dist/web/assets/api-settings-Bx1GaNmQ.js +1 -0
  6. package/dist/web/assets/{arc-D4SasZrA.js → arc-BAOivWpI.js} +1 -1
  7. package/dist/web/assets/architecture-PBZL5I3N-DEO2f3VD.js +1 -0
  8. package/dist/web/assets/{architectureDiagram-2XIMDMQ5-nv0WbM7d.js → architectureDiagram-2XIMDMQ5-DWBCPMLF.js} +1 -1
  9. package/dist/web/assets/arrow-up--LjUXLEt.js +1 -0
  10. package/dist/web/assets/{blockDiagram-WCTKOSBZ-C1XvYrb8.js → blockDiagram-WCTKOSBZ-TEF8Ally.js} +1 -1
  11. package/dist/web/assets/browser-tab-DaHGm_0i.js +1 -0
  12. package/dist/web/assets/{c4Diagram-IC4MRINW-CygDrbWJ.js → c4Diagram-IC4MRINW-dV22iAsY.js} +1 -1
  13. package/dist/web/assets/channel-wrd-NHWf.js +1 -0
  14. package/dist/web/assets/chat-tab-BDYE0KHF.js +8 -0
  15. package/dist/web/assets/chevron-right-DeV0ehiG.js +1 -0
  16. package/dist/web/assets/{chunk-4BX2VUAB-C2FDgsgT.js → chunk-4BX2VUAB-D4tOov49.js} +1 -1
  17. package/dist/web/assets/{chunk-55IACEB6-jF4w6cat.js → chunk-55IACEB6-DJ6BynZ4.js} +1 -1
  18. package/dist/web/assets/{chunk-7E7YKBS2-BVCECZFi.js → chunk-7E7YKBS2-CiyUJxNI.js} +1 -1
  19. package/dist/web/assets/{chunk-7R4GIKGN-DXTbeu5d.js → chunk-7R4GIKGN-BbIFzsIv.js} +2 -2
  20. package/dist/web/assets/{chunk-C72U2L5F-BaZqOsTs.js → chunk-C72U2L5F-D21mS_6G.js} +1 -1
  21. package/dist/web/assets/{chunk-EGIJ26TM-Bky2tcH7.js → chunk-EGIJ26TM-DzqmU2Z7.js} +1 -1
  22. package/dist/web/assets/{chunk-FMBD7UC4-Cp4BK9A8.js → chunk-FMBD7UC4-DXncblvW.js} +1 -1
  23. package/dist/web/assets/{chunk-GEFDOKGD-BosFEH7G.js → chunk-GEFDOKGD-BbQkJu8C.js} +1 -1
  24. package/dist/web/assets/chunk-GLR3WWYH-CzYx4w-r.js +2 -0
  25. package/dist/web/assets/chunk-HHEYEP7N-HRhYy3kG.js +1 -0
  26. package/dist/web/assets/{chunk-JSJVCQXG-H5Gbjsbr.js → chunk-JSJVCQXG-23tyvw8k.js} +1 -1
  27. package/dist/web/assets/{chunk-KX2RTZJC-CWerSUwS.js → chunk-KX2RTZJC-sQ0o-39C.js} +1 -1
  28. package/dist/web/assets/{chunk-KYZI473N-FvwP7jUy.js → chunk-KYZI473N-BcUZNnwd.js} +1 -1
  29. package/dist/web/assets/{chunk-L3YUKLVL-D1PI_ORP.js → chunk-L3YUKLVL-C7qGJrfV.js} +1 -1
  30. package/dist/web/assets/{chunk-MX3YWQON-C7Vzk_AI.js → chunk-MX3YWQON-BpS_PtKp.js} +1 -1
  31. package/dist/web/assets/{chunk-NQ4KR5QH-BceYBGYX.js → chunk-NQ4KR5QH-wMgTlP7f.js} +1 -1
  32. package/dist/web/assets/{chunk-O4XLMI2P-WPtzgxql.js → chunk-O4XLMI2P-JC6EGoUz.js} +1 -1
  33. package/dist/web/assets/{chunk-OZEHJAEY-DlHXDeLY.js → chunk-OZEHJAEY-BXhYx3nO.js} +1 -1
  34. package/dist/web/assets/{chunk-PQ6SQG4A-Ci_Prygb.js → chunk-PQ6SQG4A-D6BTbCQw.js} +1 -1
  35. package/dist/web/assets/{chunk-PU5JKC2W-CO0zMN-z.js → chunk-PU5JKC2W-Dw8ClWch.js} +1 -1
  36. package/dist/web/assets/chunk-QZHKN3VN-CYaTbeZf.js +1 -0
  37. package/dist/web/assets/{chunk-R5LLSJPH-IAEEzfpM.js → chunk-R5LLSJPH-CFwSJijQ.js} +1 -1
  38. package/dist/web/assets/{chunk-WL4C6EOR-BLXalOgc.js → chunk-WL4C6EOR-DfofndiH.js} +1 -1
  39. package/dist/web/assets/{chunk-XIRO2GV7-Dx1Ri_p2.js → chunk-XIRO2GV7-Djlmrely.js} +1 -1
  40. package/dist/web/assets/{chunk-XPW4576I-m9pPGKn7.js → chunk-XPW4576I-BPQQBakK.js} +1 -1
  41. package/dist/web/assets/{chunk-XZSTWKYB-B_08ExbI.js → chunk-XZSTWKYB-DxAOx4hG.js} +1 -1
  42. package/dist/web/assets/{chunk-YBOYWFTD-DqSOVcYe.js → chunk-YBOYWFTD-CeU4Q-xC.js} +1 -1
  43. package/dist/web/assets/classDiagram-VBA2DB6C-lse8oZoJ.js +1 -0
  44. package/dist/web/assets/classDiagram-v2-RAHNMMFH-CxkwuInd.js +1 -0
  45. package/dist/web/assets/clone-LRxlvnMj.js +1 -0
  46. package/dist/web/assets/code-editor-DTA3c9Y8.js +2 -0
  47. package/dist/web/assets/{cose-bilkent-S5V4N54A-DlL82QHu.js → cose-bilkent-S5V4N54A-B_AWZsOP.js} +1 -1
  48. package/dist/web/assets/csv-preview-DLqYtXxt.js +10 -0
  49. package/dist/web/assets/{dagre-BmVoh2At.js → dagre-Dbb5k38K.js} +1 -1
  50. package/dist/web/assets/{dagre-KLK3FWXG-sDrRW9MQ.js → dagre-KLK3FWXG-BH7aWGRP.js} +1 -1
  51. package/dist/web/assets/database-viewer-DXk79Nel.js +1 -0
  52. package/dist/web/assets/{diagram-E7M64L7V-ChnAhgni.js → diagram-E7M64L7V-B1Qz70Do.js} +1 -1
  53. package/dist/web/assets/{diagram-IFDJBPK2-DW1J1uJd.js → diagram-IFDJBPK2-k55eVqVU.js} +1 -1
  54. package/dist/web/assets/{diagram-P4PSJMXO-CQ32hyG_.js → diagram-P4PSJMXO-BkfNRc9U.js} +1 -1
  55. package/dist/web/assets/diff-viewer-HhIcsOQE.js +4 -0
  56. package/dist/web/assets/dist-DylI9XxN.js +13 -0
  57. package/dist/web/assets/dist-lF8CoYII.js +41 -0
  58. package/dist/web/assets/{erDiagram-INFDFZHY-6CHo6nOw.js → erDiagram-INFDFZHY-CKzVujYI.js} +1 -1
  59. package/dist/web/assets/{flowDiagram-PKNHOUZH-DroDiNT0.js → flowDiagram-PKNHOUZH-DIqcTrDV.js} +1 -1
  60. package/dist/web/assets/{ganttDiagram-A5KZAMGK-DP0QBh8w.js → ganttDiagram-A5KZAMGK-D4v7ZbVE.js} +1 -1
  61. package/dist/web/assets/git-graph-CQtWu8yE.js +1 -0
  62. package/dist/web/assets/gitGraph-HDMCJU4V-Bwna3and.js +1 -0
  63. package/dist/web/assets/{gitGraphDiagram-K3NZZRJ6-DvU3JGZn.js → gitGraphDiagram-K3NZZRJ6-BTXo57mF.js} +1 -1
  64. package/dist/web/assets/{graphlib-CQBb2thr.js → graphlib-BcsNnGcW.js} +1 -1
  65. package/dist/web/assets/index-CgQXpBb_.css +2 -0
  66. package/dist/web/assets/index-DEeeRoka.js +37 -0
  67. package/dist/web/assets/info-3K5VOQVL-_vRxVNUm.js +1 -0
  68. package/dist/web/assets/infoDiagram-LFFYTUFH-B1CX0pbC.js +2 -0
  69. package/dist/web/assets/input-BglMT33g.js +1 -0
  70. package/dist/web/assets/{isEmpty-B4kqZBtn.js → isEmpty-bnrF3Qbc.js} +1 -1
  71. package/dist/web/assets/{ishikawaDiagram-PHBUUO56-46yibrV5.js → ishikawaDiagram-PHBUUO56-BOyvKMmB.js} +1 -1
  72. package/dist/web/assets/{journeyDiagram-4ABVD52K-BcmRwjK-.js → journeyDiagram-4ABVD52K-ufoasAy6.js} +1 -1
  73. package/dist/web/assets/{kanban-definition-K7BYSVSG-B619K53y.js → kanban-definition-K7BYSVSG-Bi0UTUeN.js} +1 -1
  74. package/dist/web/assets/keybindings-store-1CJ7VX57.js +1 -0
  75. package/dist/web/assets/lib-BQ34Db2e.js +4 -0
  76. package/dist/web/assets/{line-1gcO63_w.js → line-B78g-52T.js} +1 -1
  77. package/dist/web/assets/{linear-DfRqDoVd.js → linear-DP4mkX3m.js} +1 -1
  78. package/dist/web/assets/markdown-renderer-Brj8_LQM.js +69 -0
  79. package/dist/web/assets/{mermaid-parser.core-XtjZQOeM.js → mermaid-parser.core-DMIWdgEW.js} +2 -2
  80. package/dist/web/assets/{mindmap-definition-YRQLILUH-CifOFo_q.js → mindmap-definition-YRQLILUH-BsfWvIoO.js} +1 -1
  81. package/dist/web/assets/{ordinal-BJYw-iDX.js → ordinal-_K3x1fkz.js} +1 -1
  82. package/dist/web/assets/packet-RMMSAZCW-DY5PNnZU.js +1 -0
  83. package/dist/web/assets/pie-UPGHQEXC-BHncZutv.js +1 -0
  84. package/dist/web/assets/{pieDiagram-SKSYHLDU-BuHUh_fO.js → pieDiagram-SKSYHLDU-WP0XXw51.js} +1 -1
  85. package/dist/web/assets/postgres-viewer-CwkTGmqy.js +1 -0
  86. package/dist/web/assets/{quadrantDiagram-337W2JSQ-Bau_hj6Z.js → quadrantDiagram-337W2JSQ-FHMogtsh.js} +1 -1
  87. package/dist/web/assets/radar-KQ55EAFF-DH0AOkUy.js +1 -0
  88. package/dist/web/assets/react-dom-Bpkvzu3U.js +1 -0
  89. package/dist/web/assets/{requirementDiagram-Z7DCOOCP-Cq2b-uwp.js → requirementDiagram-Z7DCOOCP-BatTxyWb.js} +1 -1
  90. package/dist/web/assets/{sankeyDiagram-WA2Y5GQK-DrdGQxWQ.js → sankeyDiagram-WA2Y5GQK-ClJuW3Hv.js} +1 -1
  91. package/dist/web/assets/{sequenceDiagram-2WXFIKYE-qPxiTUcS.js → sequenceDiagram-2WXFIKYE-ByxQqGgs.js} +1 -1
  92. package/dist/web/assets/settings-tab-BDE1MsIh.js +1 -0
  93. package/dist/web/assets/sqlite-viewer-CFYTwgA8.js +1 -0
  94. package/dist/web/assets/{stateDiagram-RAJIS63D-Dulj2oa8.js → stateDiagram-RAJIS63D-f8opcZNY.js} +1 -1
  95. package/dist/web/assets/stateDiagram-v2-FVOUBMTO-DrxVDY9q.js +1 -0
  96. package/dist/web/assets/tab-store-BJw7OCmy.js +1 -0
  97. package/dist/web/assets/{terminal-tab-wKgpSPAT.js → terminal-tab-CCDLZA5Y.js} +2 -2
  98. package/dist/web/assets/{timeline-definition-YZTLITO2-BWyDnCYq.js → timeline-definition-YZTLITO2-58BlOSf9.js} +1 -1
  99. package/dist/web/assets/treemap-KZPCXAKY-B2Xkyv-K.js +1 -0
  100. package/dist/web/assets/use-monaco-theme-CNzekTN3.js +11 -0
  101. package/dist/web/assets/{vennDiagram-LZ73GAT5-B9Iv2bNV.js → vennDiagram-LZ73GAT5-BOSy9ma9.js} +1 -1
  102. package/dist/web/assets/{xychartDiagram-JWTSCODW-ChXcMzBQ.js → xychartDiagram-JWTSCODW-z5MVJauZ.js} +1 -1
  103. package/dist/web/index.html +12 -11
  104. package/dist/web/sw.js +1 -1
  105. package/docs/code-standards.md +232 -7
  106. package/docs/codebase-summary.md +9 -3
  107. package/docs/design-guidelines.md +21 -0
  108. package/docs/project-changelog.md +115 -1
  109. package/docs/project-roadmap.md +41 -19
  110. package/docs/system-architecture.md +212 -15
  111. package/package.json +3 -2
  112. package/src/cli/commands/autostart.ts +1 -1
  113. package/src/cli/commands/restart.ts +9 -1
  114. package/src/cli/commands/status.ts +19 -0
  115. package/src/index.ts +2 -3
  116. package/src/providers/claude-agent-sdk.ts +92 -25
  117. package/src/providers/mock-provider.ts +6 -1
  118. package/src/server/index.ts +38 -166
  119. package/src/server/routes/browser-preview.ts +159 -0
  120. package/src/server/routes/chat.ts +52 -3
  121. package/src/server/routes/project-scoped.ts +2 -0
  122. package/src/server/routes/proxy.ts +46 -53
  123. package/src/server/routes/tunnel.ts +0 -32
  124. package/src/server/routes/workspace.ts +35 -0
  125. package/src/server/ws/chat.ts +207 -146
  126. package/src/services/account-selector.service.ts +16 -8
  127. package/src/services/account.service.ts +19 -13
  128. package/src/services/claude-usage.service.ts +48 -11
  129. package/src/services/cloud-ws.service.ts +227 -0
  130. package/src/services/cloud.service.ts +10 -6
  131. package/src/services/db.service.ts +111 -6
  132. package/src/services/proxy.service.ts +4 -19
  133. package/src/services/supervisor.ts +285 -25
  134. package/src/types/api.ts +9 -1
  135. package/src/types/chat.ts +3 -1
  136. package/src/web/app.tsx +41 -35
  137. package/src/web/components/browser/browser-tab.tsx +106 -97
  138. package/src/web/components/chat/account-rotation-settings.tsx +163 -0
  139. package/src/web/components/chat/chat-history-bar.tsx +72 -6
  140. package/src/web/components/chat/chat-tab.tsx +32 -16
  141. package/src/web/components/chat/chat-welcome.tsx +148 -0
  142. package/src/web/components/chat/message-input.tsx +107 -13
  143. package/src/web/components/chat/message-list.tsx +27 -15
  144. package/src/web/components/chat/session-picker.tsx +78 -31
  145. package/src/web/components/chat/usage-badge.tsx +11 -1
  146. package/src/web/components/editor/code-editor.tsx +36 -26
  147. package/src/web/components/editor/csv-preview.tsx +228 -0
  148. package/src/web/components/editor/editor-breadcrumb.tsx +216 -0
  149. package/src/web/components/editor/editor-toolbar.tsx +74 -0
  150. package/src/web/components/layout/command-palette.tsx +3 -1
  151. package/src/web/components/layout/editor-panel.tsx +162 -18
  152. package/src/web/components/layout/panel-layout.tsx +17 -1
  153. package/src/web/components/settings/proxy-settings-section.tsx +40 -42
  154. package/src/web/components/shared/connection-lost-overlay.tsx +89 -0
  155. package/src/web/hooks/use-chat.ts +211 -201
  156. package/src/web/hooks/use-global-keybindings.ts +25 -2
  157. package/src/web/hooks/use-server-reload.ts +9 -0
  158. package/src/web/hooks/use-url-sync.ts +173 -21
  159. package/src/web/hooks/use-voice-input.ts +111 -0
  160. package/src/web/lib/csv-parser.ts +134 -0
  161. package/src/web/stores/connection-store.ts +39 -0
  162. package/src/web/stores/keybindings-store.ts +1 -0
  163. package/src/web/stores/panel-store.ts +73 -19
  164. package/src/web/stores/panel-utils.ts +145 -3
  165. package/dist/web/assets/api-settings-CFw-lh5k.js +0 -1
  166. package/dist/web/assets/architecture-PBZL5I3N-CJupe6q_.js +0 -1
  167. package/dist/web/assets/browser-tab-CmsL5eny.js +0 -1
  168. package/dist/web/assets/channel-DmKoFTd_.js +0 -1
  169. package/dist/web/assets/chat-tab-CFWsf13Z.js +0 -7
  170. package/dist/web/assets/chunk-GLR3WWYH-BnP-hOp6.js +0 -2
  171. package/dist/web/assets/chunk-HHEYEP7N-DKDPTPEZ.js +0 -1
  172. package/dist/web/assets/chunk-QZHKN3VN-C_wpI9wz.js +0 -1
  173. package/dist/web/assets/classDiagram-VBA2DB6C-B1T5uY-F.js +0 -1
  174. package/dist/web/assets/classDiagram-v2-RAHNMMFH-xs5vI3xC.js +0 -1
  175. package/dist/web/assets/clone-CijCFRT5.js +0 -1
  176. package/dist/web/assets/code-editor-H_dAh_fJ.js +0 -1
  177. package/dist/web/assets/database-viewer-DBzsgEJ8.js +0 -1
  178. package/dist/web/assets/diff-viewer-DzS-OnAR.js +0 -4
  179. package/dist/web/assets/dist-0Va_2L7G.js +0 -16
  180. package/dist/web/assets/dist-D9irYETY.js +0 -41
  181. package/dist/web/assets/git-graph-D3C7F8o3.js +0 -1
  182. package/dist/web/assets/gitGraph-HDMCJU4V-B0KvGQG8.js +0 -1
  183. package/dist/web/assets/index-CIkjfera.js +0 -31
  184. package/dist/web/assets/index-WKLuYsBY.css +0 -2
  185. package/dist/web/assets/info-3K5VOQVL-1uJ6_hCm.js +0 -1
  186. package/dist/web/assets/infoDiagram-LFFYTUFH-DLA5Q-3y.js +0 -2
  187. package/dist/web/assets/input-CGp1nFIg.js +0 -1
  188. package/dist/web/assets/keybindings-store-BdaoLwSo.js +0 -1
  189. package/dist/web/assets/markdown-renderer-DH49Zag7.js +0 -69
  190. package/dist/web/assets/packet-RMMSAZCW-34C4o9yj.js +0 -1
  191. package/dist/web/assets/pie-UPGHQEXC-D9ekKlh9.js +0 -1
  192. package/dist/web/assets/postgres-viewer-B9FYk8sD.js +0 -1
  193. package/dist/web/assets/radar-KQ55EAFF-DEuXOXSD.js +0 -1
  194. package/dist/web/assets/settings-store-DWXGVHsE.js +0 -2
  195. package/dist/web/assets/settings-tab-D-q8pd-5.js +0 -1
  196. package/dist/web/assets/sqlite-viewer-CDqcTePw.js +0 -1
  197. package/dist/web/assets/stateDiagram-v2-FVOUBMTO-CAkzLlhk.js +0 -1
  198. package/dist/web/assets/tab-store-BPeiymiH.js +0 -1
  199. package/dist/web/assets/treemap-KZPCXAKY-nc7a1Ia1.js +0 -1
  200. package/dist/web/assets/use-monaco-theme-CCBTQ0S3.js +0 -11
  201. package/src/services/port-tunnel.service.ts +0 -97
  202. /package/dist/web/assets/{api-client-DOElml5u.js → api-client-BfBM3I7n.js} +0 -0
  203. /package/dist/web/assets/{array-CYkMkqnU.js → array-B9UHiPd-.js} +0 -0
  204. /package/dist/web/assets/{columns-2-ChOTgl3e.js → columns-2-DpsNbZOc.js} +0 -0
  205. /package/dist/web/assets/{cytoscape.esm-HeHO0VhB.js → cytoscape.esm-BW-DbntU.js} +0 -0
  206. /package/dist/web/assets/{defaultLocale-Beh6XjaL.js → defaultLocale-5eAKkKJC.js} +0 -0
  207. /package/dist/web/assets/{dist-BUYzeuKe.js → dist-CSJdAyA9.js} +0 -0
  208. /package/dist/web/assets/{init-Rr1s_RiX.js → init-DlZdxViB.js} +0 -0
  209. /package/dist/web/assets/{isArrayLikeObject-BB-mzMLb.js → isArrayLikeObject-B_v2FtYn.js} +0 -0
  210. /package/dist/web/assets/{katex-CKoArbIw.js → katex-Bqvo_ZG0.js} +0 -0
  211. /package/dist/web/assets/{math-B7b0HgJF.js → math-069Z4SuC.js} +0 -0
  212. /package/dist/web/assets/{path-BAQ3hXlG.js → path-6uRLdFF7.js} +0 -0
  213. /package/dist/web/assets/{preload-helper-DeiOTZKJ.js → preload-helper-uTix4PVD.js} +0 -0
  214. /package/dist/web/assets/{react-Dev-wu-s.js → react-ER-4DN55.js} +0 -0
  215. /package/dist/web/assets/{rough.esm-Dwml_la6.js → rough.esm-JX0wREDd.js} +0 -0
  216. /package/dist/web/assets/{src-B_cC68fH.js → src-BqX54PbV.js} +0 -0
  217. /package/dist/web/assets/{table-COiJDPRA.js → table-C7X5UAEI.js} +0 -0
  218. /package/dist/web/assets/{tag-LMq02LfE.js → tag-CCtdV063.js} +0 -0
  219. /package/dist/web/assets/{utils-btZ8C8-R.js → utils-BNytJOb1.js} +0 -0
@@ -1,5 +1,4 @@
1
1
  import { create } from "zustand";
2
- import { randomId } from "@/lib/utils";
3
2
  import type { Tab, TabType } from "./tab-store";
4
3
  import {
5
4
  type Panel,
@@ -13,18 +12,15 @@ import {
13
12
  MAX_ROWS,
14
13
  savePanelLayout,
15
14
  loadPanelLayout,
15
+ deriveTabId,
16
16
  } from "./panel-utils";
17
17
 
18
18
  /** Tab types that can only have 1 instance per project */
19
- const SINGLETON_TYPES = new Set<TabType>(["git-graph"]);
19
+ const SINGLETON_TYPES = new Set<TabType>(["git-graph", "settings"]);
20
20
 
21
21
  /** Tab types removed in a prior version — filter them out when loading persisted state */
22
22
  const OBSOLETE_TAB_TYPES = new Set(["projects", "git-status"]);
23
23
 
24
- function generateTabId(): string {
25
- return `tab-${randomId()}`;
26
- }
27
-
28
24
  function pushHistory(history: string[], id: string): string[] {
29
25
  const filtered = history.filter((h) => h !== id);
30
26
  filtered.push(id);
@@ -47,6 +43,7 @@ export interface PanelStore {
47
43
 
48
44
  // Project lifecycle
49
45
  switchProject: (projectName: string) => void;
46
+ reloadProject: (projectName: string) => void;
50
47
 
51
48
  // Panel focus
52
49
  setFocusedPanel: (panelId: string) => void;
@@ -188,6 +185,25 @@ export const usePanelStore = create<PanelStore>()((set, get) => {
188
185
  }
189
186
  },
190
187
 
188
+ reloadProject: (projectName) => {
189
+ const { projectGrids, projectFocused, panels } = get();
190
+ // Clear in-memory cache so switchProject re-reads from localStorage
191
+ const newGrids = { ...projectGrids };
192
+ const newFocused = { ...projectFocused };
193
+ delete newGrids[projectName];
194
+ delete newFocused[projectName];
195
+
196
+ // Remove old panels belonging to this project from flat map
197
+ const oldGrid = projectGrids[projectName];
198
+ const oldPanelIds = oldGrid ? new Set(oldGrid.flat()) : new Set<string>();
199
+ const cleanedPanels = { ...panels };
200
+ for (const id of oldPanelIds) delete cleanedPanels[id];
201
+
202
+ set({ projectGrids: newGrids, projectFocused: newFocused, panels: cleanedPanels, currentProject: null });
203
+ // Re-trigger full load from localStorage
204
+ get().switchProject(projectName);
205
+ },
206
+
191
207
  setFocusedPanel: (panelId) => {
192
208
  if (get().panels[panelId]) set({ focusedPanelId: panelId });
193
209
  },
@@ -197,10 +213,25 @@ export const usePanelStore = create<PanelStore>()((set, get) => {
197
213
  const panel = get().panels[pid];
198
214
  if (!panel) return "";
199
215
 
200
- // Singleton check across ALL panels
216
+ // Terminal: compute next available index if not provided
217
+ if (tabDef.type === "terminal" && !tabDef.metadata?.terminalIndex) {
218
+ const allTabs = Object.values(get().panels).flatMap((p) => p.tabs);
219
+ const terminalNums = allTabs
220
+ .filter((t) => t.type === "terminal")
221
+ .map((t) => {
222
+ const match = t.id.match(/^terminal:(\d+)/);
223
+ return match ? parseInt(match[1]!, 10) : 0;
224
+ });
225
+ const nextIndex = terminalNums.length > 0 ? Math.max(...terminalNums) + 1 : 1;
226
+ tabDef = { ...tabDef, metadata: { ...tabDef.metadata, terminalIndex: nextIndex } };
227
+ }
228
+
229
+ const baseId = deriveTabId(tabDef.type, tabDef.metadata);
230
+
231
+ // Singleton check — focus existing across ALL panels
201
232
  if (SINGLETON_TYPES.has(tabDef.type)) {
202
233
  for (const p of Object.values(get().panels)) {
203
- const existing = p.tabs.find((t) => t.type === tabDef.type && t.projectId === tabDef.projectId);
234
+ const existing = p.tabs.find((t) => t.id === baseId);
204
235
  if (existing) {
205
236
  set((s) => ({
206
237
  focusedPanelId: p.id,
@@ -219,7 +250,30 @@ export const usePanelStore = create<PanelStore>()((set, get) => {
219
250
  }
220
251
  }
221
252
 
222
- const id = generateTabId();
253
+ // Non-singleton: dedup within SAME panel only
254
+ const currentPanel = get().panels[pid]!;
255
+ const existingInPanel = currentPanel.tabs.find((t) => t.id === baseId);
256
+ if (existingInPanel) {
257
+ set((s) => ({
258
+ panels: {
259
+ ...s.panels,
260
+ [pid]: {
261
+ ...currentPanel,
262
+ activeTabId: existingInPanel.id,
263
+ tabHistory: pushHistory(currentPanel.tabHistory, existingInPanel.id),
264
+ },
265
+ },
266
+ }));
267
+ persist();
268
+ return existingInPanel.id;
269
+ }
270
+
271
+ // Check if same base ID exists in OTHER panels (split case)
272
+ const existsElsewhere = Object.values(get().panels).some(
273
+ (p) => p.id !== pid && p.tabs.some((t) => t.id === baseId),
274
+ );
275
+ const id = existsElsewhere ? `${baseId}@${pid}` : baseId;
276
+
223
277
  const tab: Tab = { ...tabDef, id };
224
278
  set((s) => {
225
279
  const p = s.panels[pid]!;
@@ -257,9 +311,9 @@ export const usePanelStore = create<PanelStore>()((set, get) => {
257
311
  : newTabs[newTabs.length - 1]?.id ?? null;
258
312
  }
259
313
 
260
- // Auto-close panel if empty and not the last one
261
- const panelIds = Object.keys(s.panels);
262
- if (newTabs.length === 0 && panelIds.length > 1) {
314
+ // Auto-close panel if empty and not the last one in current grid
315
+ const gridPanelCount = s.grid.flat().length;
316
+ if (newTabs.length === 0 && gridPanelCount > 1) {
263
317
  const { [pid]: _, ...rest } = s.panels;
264
318
  const newGrid = gridRemovePanel(s.grid, pid);
265
319
  const newFocused = s.focusedPanelId === pid ? Object.keys(rest)[0]! : s.focusedPanelId;
@@ -331,9 +385,9 @@ export const usePanelStore = create<PanelStore>()((set, get) => {
331
385
  else toTabs.push(tab);
332
386
 
333
387
  set((s) => {
334
- const panelIds = Object.keys(s.panels);
335
- // Auto-close empty source panel if not last
336
- if (fromTabs.length === 0 && panelIds.length > 1) {
388
+ const gridPanelCount = s.grid.flat().length;
389
+ // Auto-close empty source panel if not last in current grid
390
+ if (fromTabs.length === 0 && gridPanelCount > 1) {
337
391
  const { [fromPanelId]: _, ...rest } = s.panels;
338
392
  return {
339
393
  panels: {
@@ -405,14 +459,14 @@ export const usePanelStore = create<PanelStore>()((set, get) => {
405
459
  }
406
460
 
407
461
  set((s) => {
408
- const panelIds = Object.keys(s.panels);
462
+ const gridPanelCount = s.grid.flat().length;
409
463
  let updatedPanels = {
410
464
  ...s.panels,
411
465
  [newPanel.id]: newPanel,
412
466
  };
413
467
 
414
- // If source is now empty and not last panel, remove it
415
- if (srcTabs.length === 0 && panelIds.length > 1) {
468
+ // If source is now empty and not last panel in grid, remove it
469
+ if (srcTabs.length === 0 && gridPanelCount > 1) {
416
470
  const { [sourcePanelId]: _, ...rest } = updatedPanels;
417
471
  updatedPanels = rest;
418
472
  newGrid = gridRemovePanel(newGrid, sourcePanelId);
@@ -428,7 +482,7 @@ export const usePanelStore = create<PanelStore>()((set, get) => {
428
482
 
429
483
  closePanel: (panelId) => {
430
484
  const { panels, grid } = get();
431
- if (Object.keys(panels).length <= 1) return;
485
+ if (grid.flat().length <= 1) return;
432
486
 
433
487
  const panel = panels[panelId];
434
488
  if (!panel) return;
@@ -1,5 +1,5 @@
1
1
  import { randomId } from "@/lib/utils";
2
- import type { Tab } from "./tab-store";
2
+ import type { Tab, TabType } from "./tab-store";
3
3
 
4
4
  // ---------------------------------------------------------------------------
5
5
  // Panel types
@@ -69,6 +69,62 @@ export function findPanelPosition(grid: string[][], panelId: string): { row: num
69
69
  return null;
70
70
  }
71
71
 
72
+ // ---------------------------------------------------------------------------
73
+ // Deterministic tab IDs
74
+ // ---------------------------------------------------------------------------
75
+
76
+ /** Derive deterministic tab ID from type + metadata */
77
+ export function deriveTabId(type: TabType, metadata?: Record<string, unknown>): string {
78
+ switch (type) {
79
+ case "editor":
80
+ return `editor:${metadata?.filePath ?? "untitled"}`;
81
+ case "chat": {
82
+ const provider = metadata?.providerId ?? "default";
83
+ return `chat:${provider}/${metadata?.sessionId ?? randomId()}`;
84
+ }
85
+ case "terminal":
86
+ return `terminal:${metadata?.terminalIndex ?? 1}`;
87
+ case "database":
88
+ return `database:${metadata?.connectionId ?? "default"}:${metadata?.tableName ?? ""}`;
89
+ case "sqlite":
90
+ return `sqlite:${metadata?.filePath ?? "default"}`;
91
+ case "postgres":
92
+ return `postgres:${metadata?.connectionId ?? "default"}:${metadata?.tableName ?? ""}`;
93
+ case "git-graph":
94
+ return "git-graph";
95
+ case "git-diff":
96
+ return `git-diff:${metadata?.filePath ?? "unknown"}`;
97
+ case "settings":
98
+ return "settings";
99
+ case "browser":
100
+ return `browser:${metadata?.url ?? "blank"}`;
101
+ default:
102
+ return `${type}:${randomId()}`;
103
+ }
104
+ }
105
+
106
+ /** Migrate old random tab IDs to deterministic IDs */
107
+ export function migrateTabIds(layout: PanelLayout): PanelLayout {
108
+ const migrated = { ...layout, panels: { ...layout.panels } };
109
+ for (const [panelId, panel] of Object.entries(migrated.panels)) {
110
+ const newTabs = panel.tabs.map((tab) => {
111
+ if (tab.id.startsWith("tab-")) {
112
+ const newId = deriveTabId(tab.type, tab.metadata);
113
+ return { ...tab, id: newId };
114
+ }
115
+ return tab;
116
+ });
117
+ const idMap = new Map<string, string>();
118
+ panel.tabs.forEach((old, i) => {
119
+ if (old.id !== newTabs[i]!.id) idMap.set(old.id, newTabs[i]!.id);
120
+ });
121
+ const newActive = idMap.get(panel.activeTabId ?? "") ?? panel.activeTabId;
122
+ const newHistory = panel.tabHistory.map((h) => idMap.get(h) ?? h);
123
+ migrated.panels[panelId] = { ...panel, tabs: newTabs, activeTabId: newActive, tabHistory: newHistory };
124
+ }
125
+ return migrated;
126
+ }
127
+
72
128
  // ---------------------------------------------------------------------------
73
129
  // Persistence
74
130
  // ---------------------------------------------------------------------------
@@ -81,20 +137,106 @@ function storageKey(projectName: string): string {
81
137
 
82
138
  export function savePanelLayout(projectName: string, layout: PanelLayout): void {
83
139
  try {
84
- localStorage.setItem(storageKey(projectName), JSON.stringify(layout));
140
+ const withTimestamp = { ...layout, updatedAt: new Date().toISOString() };
141
+ localStorage.setItem(storageKey(projectName), JSON.stringify(withTimestamp));
142
+ // Debounced server sync
143
+ syncWorkspaceToServer(projectName, layout);
85
144
  } catch { /* ignore */ }
86
145
  }
87
146
 
88
147
  export function loadPanelLayout(projectName: string): PanelLayout | null {
89
148
  try {
90
149
  const raw = localStorage.getItem(storageKey(projectName));
91
- if (raw) return JSON.parse(raw) as PanelLayout;
150
+ if (raw) {
151
+ const layout = JSON.parse(raw) as PanelLayout;
152
+ return migrateTabIds(layout);
153
+ }
92
154
  } catch { /* ignore */ }
93
155
 
94
156
  // Migrate from old tab-store format
95
157
  return migrateOldTabStore(projectName);
96
158
  }
97
159
 
160
+ // ---------------------------------------------------------------------------
161
+ // Server sync
162
+ // ---------------------------------------------------------------------------
163
+
164
+ export interface PanelLayoutWithTimestamp extends PanelLayout {
165
+ updatedAt: string;
166
+ }
167
+
168
+ /** Fetch workspace from server */
169
+ export async function fetchWorkspaceFromServer(
170
+ projectName: string,
171
+ ): Promise<PanelLayoutWithTimestamp | null> {
172
+ try {
173
+ const headers: Record<string, string> = {};
174
+ const token = localStorage.getItem("ppm-auth-token");
175
+ if (token) headers["Authorization"] = `Bearer ${token}`;
176
+
177
+ const res = await fetch(`/api/project/${encodeURIComponent(projectName)}/workspace`, { headers });
178
+ if (!res.ok) return null;
179
+ const json = await res.json();
180
+ if (!json.ok || !json.data) return null;
181
+ return { ...json.data.layout, updatedAt: json.data.updatedAt };
182
+ } catch {
183
+ return null;
184
+ }
185
+ }
186
+
187
+ /** Save workspace to server (debounced per project) */
188
+ const syncTimers = new Map<string, ReturnType<typeof setTimeout>>();
189
+
190
+ function syncWorkspaceToServer(projectName: string, layout: PanelLayout): void {
191
+ const existing = syncTimers.get(projectName);
192
+ if (existing) clearTimeout(existing);
193
+
194
+ syncTimers.set(projectName, setTimeout(async () => {
195
+ syncTimers.delete(projectName);
196
+ try {
197
+ const headers: Record<string, string> = { "Content-Type": "application/json" };
198
+ const token = localStorage.getItem("ppm-auth-token");
199
+ if (token) headers["Authorization"] = `Bearer ${token}`;
200
+
201
+ const res = await fetch(`/api/project/${encodeURIComponent(projectName)}/workspace`, {
202
+ method: "PUT",
203
+ headers,
204
+ body: JSON.stringify({ layout }),
205
+ });
206
+ if (res.ok) {
207
+ const json = await res.json();
208
+ if (json.data?.updatedAt) {
209
+ const key = `${STORAGE_PREFIX}${projectName}`;
210
+ const raw = localStorage.getItem(key);
211
+ if (raw) {
212
+ const local = JSON.parse(raw);
213
+ local.updatedAt = json.data.updatedAt;
214
+ localStorage.setItem(key, JSON.stringify(local));
215
+ }
216
+ }
217
+ }
218
+ } catch { /* silent fail — localStorage is still the cache */ }
219
+ }, 1500));
220
+ }
221
+
222
+ /** Compare local vs server timestamps, return newer layout */
223
+ export function resolveWorkspaceConflict(
224
+ local: PanelLayoutWithTimestamp | null,
225
+ server: PanelLayoutWithTimestamp | null,
226
+ ): PanelLayoutWithTimestamp | null {
227
+ if (!local && !server) return null;
228
+ if (!local) return server!;
229
+ if (!server) return local;
230
+
231
+ const localTime = new Date(local.updatedAt).getTime();
232
+ const serverTime = new Date(server.updatedAt).getTime();
233
+ return serverTime >= localTime ? server : local;
234
+ }
235
+
236
+ // ---------------------------------------------------------------------------
237
+ // Old format migration
238
+ // ---------------------------------------------------------------------------
239
+
98
240
  function migrateOldTabStore(projectName: string): PanelLayout | null {
99
241
  try {
100
242
  const raw = localStorage.getItem(`${OLD_STORAGE_PREFIX}${projectName}`);
@@ -1 +0,0 @@
1
- import{r as e}from"./chunk-CFjPhJqf.js";import{t}from"./api-client-DOElml5u.js";var n=e({addAccount:()=>a,exchangeOAuthCode:()=>c,getAISettings:()=>f,getAccounts:()=>r,getActiveAccount:()=>i,getAllAccountUsages:()=>l,getOAuthUrl:()=>s,getProxySettings:()=>m,importAccounts:()=>u,patchAccount:()=>o,updateAISettings:()=>p,updateDeviceName:()=>d,updateProxySettings:()=>h});function r(){return t.get(`/api/accounts`)}function i(){return t.get(`/api/accounts/active`)}function a(e){return t.post(`/api/accounts`,e)}function o(e,n){return t.patch(`/api/accounts/${e}`,n)}function s(){return t.get(`/api/accounts/oauth/url`)}function c(e,n){return t.post(`/api/accounts/oauth/exchange`,{code:e,state:n})}function l(){return t.get(`/api/accounts/usage`)}function u(e){return t.post(`/api/accounts/import`,e)}function d(e){return t.put(`/api/settings/device-name`,{device_name:e})}function f(){return t.get(`/api/settings/ai`)}function p(e){return t.put(`/api/settings/ai`,e)}function m(){return t.get(`/api/settings/proxy`)}function h(e){return t.put(`/api/settings/proxy`,e)}export{r as a,s as c,o as d,p as f,f as i,m as l,n,i as o,h as p,c as r,l as s,a as t,u};
@@ -1 +0,0 @@
1
- import"./chunk-XZSTWKYB-B_08ExbI.js";import{n as e}from"./chunk-R5LLSJPH-IAEEzfpM.js";export{e as createArchitectureServices};
@@ -1 +0,0 @@
1
- import{o as e}from"./chunk-CFjPhJqf.js";import{t}from"./react-nm2Ru1Pt.js";import{t as n}from"./jsx-runtime-BRW_vwa9.js";import{n as r,t as i}from"./input-CGp1nFIg.js";import{t as a}from"./api-client-DOElml5u.js";import{B as o,D as s,N as c,X as l,q as u,z as d}from"./index-CIkjfera.js";var f=e(t(),1),p=n();function m({metadata:e}){let[t,n]=(0,f.useState)((e?.port?Number(e.port):void 0)?.toString()??``),[m,h]=(0,f.useState)(null),[g,_]=(0,f.useState)(!1),[v,y]=(0,f.useState)(null),[b,x]=(0,f.useState)(!1),S=(0,f.useRef)(null),C=async()=>{let e=Number(t);if(!e||e<1||e>65535){y(`Enter a valid port (1-65535)`);return}_(!0),y(null);try{h((await a.post(`/api/tunnel/port/start`,{port:e})).url)}catch(e){y(e.message)}finally{_(!1)}};return m?(0,p.jsxs)(`div`,{className:`flex flex-col h-full`,children:[(0,p.jsxs)(`div`,{className:`flex items-center gap-2 px-3 py-1.5 border-b border-border bg-muted/30 shrink-0`,children:[(0,p.jsx)(`code`,{className:`text-[11px] font-mono text-muted-foreground truncate flex-1`,children:m}),(0,p.jsx)(r,{variant:`ghost`,size:`sm`,className:`h-6 px-1.5 cursor-pointer`,onClick:()=>{m&&(navigator.clipboard.writeText(m),x(!0),setTimeout(()=>x(!1),2e3))},title:`Copy URL`,children:b?(0,p.jsx)(`span`,{className:`text-[10px]`,children:`Copied!`}):(0,p.jsx)(l,{className:`size-3`})}),(0,p.jsx)(r,{variant:`ghost`,size:`sm`,className:`h-6 px-1.5 cursor-pointer`,onClick:()=>{S.current&&(S.current.src=S.current.src)},title:`Reload`,children:(0,p.jsx)(c,{className:`size-3`})}),(0,p.jsx)(`a`,{href:m,target:`_blank`,rel:`noopener noreferrer`,children:(0,p.jsx)(r,{variant:`ghost`,size:`sm`,className:`h-6 px-1.5 cursor-pointer`,title:`Open in new tab`,children:(0,p.jsx)(u,{className:`size-3`})})}),(0,p.jsx)(r,{variant:`ghost`,size:`sm`,className:`h-6 px-1.5 cursor-pointer text-red-500`,onClick:async()=>{let e=Number(t);if(e){try{await a.post(`/api/tunnel/port/stop`,{port:e})}catch{}h(null)}},title:`Stop tunnel`,children:(0,p.jsx)(s,{className:`size-3`})})]}),(0,p.jsx)(`iframe`,{ref:S,src:m,className:`flex-1 w-full border-none bg-white`,sandbox:`allow-scripts allow-same-origin allow-forms allow-popups`,title:`Preview port ${t}`})]}):(0,p.jsx)(`div`,{className:`flex items-center justify-center h-full p-4`,children:(0,p.jsxs)(`div`,{className:`w-full max-w-sm space-y-4 text-center`,children:[(0,p.jsx)(o,{className:`size-10 mx-auto text-muted-foreground`}),(0,p.jsxs)(`div`,{className:`space-y-1`,children:[(0,p.jsx)(`h3`,{className:`text-sm font-medium`,children:`Open Tunnel`}),(0,p.jsx)(`p`,{className:`text-xs text-muted-foreground`,children:`Enter a local port to create a public tunnel URL`})]}),(0,p.jsxs)(`form`,{onSubmit:e=>{e.preventDefault(),C()},className:`flex gap-2`,children:[(0,p.jsx)(i,{type:`number`,placeholder:`e.g. 3000`,value:t,onChange:e=>n(e.target.value),className:`h-9 text-sm font-mono flex-1`,min:1,max:65535,autoFocus:!0,disabled:g}),(0,p.jsx)(r,{type:`submit`,size:`sm`,className:`h-9 px-4 cursor-pointer`,disabled:g||!t,children:g?(0,p.jsx)(d,{className:`size-4 animate-spin`}):`Connect`})]}),v&&(0,p.jsx)(`p`,{className:`text-xs text-red-500`,children:v})]})})}export{m as BrowserTab};
@@ -1 +0,0 @@
1
- import{it as e,rt as t}from"./chunk-7R4GIKGN-DXTbeu5d.js";var n=(n,r)=>e.lang.round(t.parse(n)[r]);export{n as t};
@@ -1,7 +0,0 @@
1
- const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/api-client-DOElml5u.js","assets/chunk-CFjPhJqf.js"])))=>i.map(i=>d[i]);
2
- import{o as e}from"./chunk-CFjPhJqf.js";import{t}from"./react-nm2Ru1Pt.js";import{D as n,E as r,T as i}from"./dist-D9irYETY.js";import{n as a,t as o}from"./jsx-runtime-BRW_vwa9.js";import{t as s}from"./columns-2-ChOTgl3e.js";import{t as c}from"./tag-LMq02LfE.js";import{t as l}from"./preload-helper-DeiOTZKJ.js";import{n as u}from"./settings-store-DWXGVHsE.js";import{n as d,t as f}from"./input-CGp1nFIg.js";import{n as p,r as m,t as h}from"./utils-btZ8C8-R.js";import{n as g,t as _}from"./tab-store-BPeiymiH.js";import{i as v,r as y,t as b}from"./api-client-DOElml5u.js";import{a as x,c as S,d as C,i as w,o as T,r as E,s as D,t as O,u as k}from"./api-settings-CFw-lh5k.js";import{$ as A,A as j,B as M,D as N,E as P,F,H as I,J as L,K as R,L as ee,M as z,N as B,O as te,P as V,Q as H,R as U,U as ne,W as re,X as ie,a as ae,b as oe,c as se,d as ce,et as le,f as W,it as ue,l as de,n as fe,o as pe,p as G,q as me,r as he,rt as ge,s as _e,tt as K,u as ve,z as q}from"./index-CIkjfera.js";import"./chunk-GEFDOKGD-BosFEH7G.js";import"./src-B_cC68fH.js";import"./chunk-7R4GIKGN-DXTbeu5d.js";import"./chunk-HHEYEP7N-DKDPTPEZ.js";import"./dist-BUYzeuKe.js";import"./chunk-PU5JKC2W-CO0zMN-z.js";import"./chunk-MX3YWQON-C7Vzk_AI.js";import"./chunk-YBOYWFTD-DqSOVcYe.js";import"./chunk-PQ6SQG4A-Ci_Prygb.js";import"./chunk-KYZI473N-FvwP7jUy.js";import"./chunk-O4XLMI2P-WPtzgxql.js";import"./chunk-GLR3WWYH-BnP-hOp6.js";import"./chunk-XPW4576I-m9pPGKn7.js";import{t as ye}from"./markdown-renderer-DH49Zag7.js";var be=a(`activity`,[[`path`,{d:`M22 12h-2.48a2 2 0 0 0-1.93 1.46l-2.35 8.36a.25.25 0 0 1-.48 0L9.24 2.18a.25.25 0 0 0-.48 0l-2.35 8.36A2 2 0 0 1 4.49 12H2`,key:`169zse`}]]),xe=a(`arrow-up`,[[`path`,{d:`m5 12 7-7 7 7`,key:`hav0vg`}],[`path`,{d:`M12 19V5`,key:`x0mq9r`}]]),Se=a(`circle-x`,[[`circle`,{cx:`12`,cy:`12`,r:`10`,key:`1mglay`}],[`path`,{d:`m15 9-6 6`,key:`1uzhvr`}],[`path`,{d:`m9 9 6 6`,key:`z0biqf`}]]),Ce=a(`clipboard-list`,[[`rect`,{width:`8`,height:`4`,x:`8`,y:`2`,rx:`1`,ry:`1`,key:`tgr4d6`}],[`path`,{d:`M16 4h2a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2h2`,key:`116196`}],[`path`,{d:`M12 11h4`,key:`1jrz19`}],[`path`,{d:`M12 16h4`,key:`n85exb`}],[`path`,{d:`M8 11h.01`,key:`1dfujw`}],[`path`,{d:`M8 16h.01`,key:`18s6g9`}]]),we=a(`code`,[[`path`,{d:`m16 18 6-6-6-6`,key:`eg8j8`}],[`path`,{d:`m8 6-6 6 6 6`,key:`ppft3o`}]]),Te=a(`hand`,[[`path`,{d:`M18 11V6a2 2 0 0 0-2-2a2 2 0 0 0-2 2`,key:`1fvzgz`}],[`path`,{d:`M14 10V4a2 2 0 0 0-2-2a2 2 0 0 0-2 2v2`,key:`1kc0my`}],[`path`,{d:`M10 10.5V6a2 2 0 0 0-2-2a2 2 0 0 0-2 2v8`,key:`10h0bg`}],[`path`,{d:`M18 8a2 2 0 1 1 4 0v6a8 8 0 0 1-8 8h-2c-2.8 0-4.5-.86-5.99-2.34l-3.6-3.6a2 2 0 0 1 2.83-2.82L7 15`,key:`1s1gnw`}]]),Ee=a(`history`,[[`path`,{d:`M3 12a9 9 0 1 0 9-9 9.75 9.75 0 0 0-6.74 2.74L3 8`,key:`1357e3`}],[`path`,{d:`M3 3v5h5`,key:`1xhq8a`}],[`path`,{d:`M12 7v5l4 2`,key:`1fdv2h`}]]),De=a(`image`,[[`rect`,{width:`18`,height:`18`,x:`3`,y:`3`,rx:`2`,ry:`2`,key:`1m3agn`}],[`circle`,{cx:`9`,cy:`9`,r:`2`,key:`af1f0g`}],[`path`,{d:`m21 15-3.086-3.086a2 2 0 0 0-2.828 0L6 21`,key:`1xmnt7`}]]),Oe=a(`list-todo`,[[`path`,{d:`M13 5h8`,key:`a7qcls`}],[`path`,{d:`M13 12h8`,key:`h98zly`}],[`path`,{d:`M13 19h8`,key:`c3s6r1`}],[`path`,{d:`m3 17 2 2 4-4`,key:`1jhpwq`}],[`rect`,{x:`3`,y:`4`,width:`6`,height:`6`,rx:`1`,key:`cif1o7`}]]),ke=a(`paperclip`,[[`path`,{d:`m16 6-8.414 8.586a2 2 0 0 0 2.829 2.829l8.414-8.586a4 4 0 1 0-5.657-5.657l-8.379 8.551a6 6 0 1 0 8.485 8.485l8.379-8.551`,key:`1miecu`}]]),Ae=a(`settings-2`,[[`path`,{d:`M14 17H5`,key:`gfn3mx`}],[`path`,{d:`M19 7h-9`,key:`6i9tg`}],[`circle`,{cx:`17`,cy:`17`,r:`3`,key:`18b49y`}],[`circle`,{cx:`7`,cy:`7`,r:`3`,key:`dfmy0x`}]]),je=a(`shield-alert`,[[`path`,{d:`M20 13c0 5-3.5 7.5-7.66 8.95a1 1 0 0 1-.67-.01C7.5 20.5 4 18 4 13V6a1 1 0 0 1 1-1c2 0 4.5-1.2 6.24-2.72a1.17 1.17 0 0 1 1.52 0C14.51 3.81 17 5 19 5a1 1 0 0 1 1 1z`,key:`oel41y`}],[`path`,{d:`M12 8v4`,key:`1got3b`}],[`path`,{d:`M12 16h.01`,key:`1drbdi`}]]),Me=a(`shield-off`,[[`path`,{d:`m2 2 20 20`,key:`1ooewy`}],[`path`,{d:`M5 5a1 1 0 0 0-1 1v7c0 5 3.5 7.5 7.67 8.94a1 1 0 0 0 .67.01c2.35-.82 4.48-1.97 5.9-3.71`,key:`1jlk70`}],[`path`,{d:`M9.309 3.652A12.252 12.252 0 0 0 11.24 2.28a1.17 1.17 0 0 1 1.52 0C14.51 3.81 17 5 19 5a1 1 0 0 1 1 1v7a9.784 9.784 0 0 1-.08 1.264`,key:`18rp1v`}]]),Ne=a(`sparkles`,[[`path`,{d:`M11.017 2.814a1 1 0 0 1 1.966 0l1.051 5.558a2 2 0 0 0 1.594 1.594l5.558 1.051a1 1 0 0 1 0 1.966l-5.558 1.051a2 2 0 0 0-1.594 1.594l-1.051 5.558a1 1 0 0 1-1.966 0l-1.051-5.558a2 2 0 0 0-1.594-1.594l-5.558-1.051a1 1 0 0 1 0-1.966l5.558-1.051a2 2 0 0 0 1.594-1.594z`,key:`1s2grr`}],[`path`,{d:`M20 2v4`,key:`1rf3ol`}],[`path`,{d:`M22 4h-4`,key:`gwowj6`}],[`circle`,{cx:`4`,cy:`20`,r:`2`,key:`6kqj1y`}]]),Pe=a(`square`,[[`rect`,{width:`18`,height:`18`,x:`3`,y:`3`,rx:`2`,key:`afitv7`}]]),J=e(t(),1),Fe=3e4,Ie=1e3,Le=class{ws=null;url;handlers=[];reconnectAttempts=0;reconnectTimer=null;intentionalClose=!1;pendingMessages=[];constructor(e){this.url=e}connect(){this.intentionalClose=!1,this.cleanup();let e=window.location.protocol===`https:`?`wss:`:`ws:`,t=this.url.startsWith(`ws`)?this.url:`${e}//${window.location.host}${this.url}`;this.ws=new WebSocket(t),this.ws.onopen=()=>{this.reconnectAttempts=0;try{this.ws?.send(JSON.stringify({type:`ready`}))}catch{}if(this.pendingMessages.length>0){console.log(`[ws] flushing ${this.pendingMessages.length} queued message(s)`);for(let e of this.pendingMessages)try{this.ws?.send(e)}catch{}this.pendingMessages=[]}},this.ws.onmessage=e=>{for(let t of this.handlers)t(e)},this.ws.onclose=()=>{this.intentionalClose||this.scheduleReconnect()},this.ws.onerror=()=>{this.ws?.close()}}disconnect(){this.intentionalClose=!0,this.pendingMessages=[],this.cleanup(),this.reconnectTimer&&=(clearTimeout(this.reconnectTimer),null)}send(e){this.ws?.readyState===WebSocket.OPEN?this.ws.send(e):this.ws?.readyState===WebSocket.CONNECTING?(console.warn(`[ws] WS still CONNECTING — queuing message`),this.pendingMessages.push(e)):console.warn(`[ws] message dropped — readyState=${this.ws?.readyState??`no-ws`}`)}onMessage(e){return this.handlers.push(e),()=>{this.handlers=this.handlers.filter(t=>t!==e)}}get isConnected(){return this.ws?.readyState===WebSocket.OPEN}cleanup(){this.ws&&=(this.ws.onopen=null,this.ws.onclose=null,this.ws.onmessage=null,this.ws.onerror=null,(this.ws.readyState===WebSocket.OPEN||this.ws.readyState===WebSocket.CONNECTING)&&this.ws.close(),null)}scheduleReconnect(){let e=Math.min(Ie*2**this.reconnectAttempts,Fe);this.reconnectAttempts++,this.reconnectTimer=setTimeout(()=>this.connect(),e)}};function Re({url:e,onMessage:t,autoConnect:n=!0}){let r=(0,J.useRef)(null);return(0,J.useEffect)(()=>{let i=new Le(e);return r.current=i,t&&i.onMessage(t),n&&i.connect(),()=>{i.disconnect(),r.current=null}},[e,n]),{send:(0,J.useCallback)(e=>{r.current?.send(e)},[]),connect:(0,J.useCallback)(()=>{r.current?.connect()},[]),disconnect:(0,J.useCallback)(()=>{r.current?.disconnect()},[])}}var ze=null;function Be(){return ze||=new AudioContext,ze}function Y(e,t,n,r,i=`sine`){let a=Be(),o=a.createOscillator(),s=a.createGain();o.type=i,o.frequency.value=e,s.gain.setValueAtTime(r,n),s.gain.exponentialRampToValueAtTime(.001,n+t),o.connect(s),s.connect(a.destination),o.start(n),o.stop(n+t)}function Ve(){let e=Be().currentTime;Y(523,.15,e,.15),Y(659,.2,e+.12,.15)}function He(){let e=Be().currentTime;Y(880,.12,e,.18,`square`),Y(698,.12,e+.15,.18,`square`),Y(880,.15,e+.3,.15,`square`)}function Ue(){let e=Be().currentTime;Y(440,.12,e,.12),Y(523,.12,e+.1,.12),Y(659,.18,e+.2,.12)}var We={done:Ve,approval_request:He,question:Ue};function Ge(e){try{We[e]?.()}catch{}}function Ke(e){if(document.hidden)return!1;let{panels:t,focusedPanelId:n}=g.getState(),r=t[n];if(!r)return!1;let i=r.tabs.find(e=>e.id===r.activeTabId);return i?.type===`chat`&&i.metadata?.sessionId===e}function qe(e,t=`claude`,n=``){let[r,i]=(0,J.useState)([]),[a,o]=(0,J.useState)(!1),[s,c]=(0,J.useState)(!1),[l,u]=(0,J.useState)(`idle`),[d,f]=(0,J.useState)(0),[p,m]=(0,J.useState)(15),[h,g]=(0,J.useState)(null),[_,b]=(0,J.useState)(null),[x,S]=(0,J.useState)(null),[C,w]=(0,J.useState)(!1),T=(0,J.useRef)(``),E=(0,J.useRef)([]),D=(0,J.useRef)(null),O=(0,J.useRef)(!1),k=(0,J.useRef)(null),A=(0,J.useRef)(()=>{}),j=(0,J.useRef)(null),M=(0,J.useRef)(e);M.current=e;let N=(0,J.useRef)(n);N.current=n;let P=(0,J.useCallback)(e=>{let t;try{t=JSON.parse(e.data)}catch{return}if(t.type===`ping`)return;if(t.type===`title_updated`){S(t.title??null);return}if(t.type===`streaming_status`){let e=t.status??`idle`;if(u(e),f(e===`connecting`?t.elapsed??0:0),e===`connecting`){let e=t.effort,n=t.thinkingBudget,r=15;n&&n>0?r=Math.max(15,Math.round(n/500)):e===`high`?r=30:e===`low`&&(r=10),m(r)}return}if(t.type===`connected`){w(!0),t.sessionTitle&&S(t.sessionTitle);return}if(t.type===`status`){w(!0);let e=t;e.sessionTitle&&S(e.sessionTitle),e.isStreaming&&(O.current=!0,c(!0)),e.pendingApproval&&g({requestId:e.pendingApproval.requestId,tool:e.pendingApproval.tool,input:e.pendingApproval.input}),j.current?.();return}let n=(e,t)=>{let n=E.current.findIndex(e=>e.type===`tool_use`&&(e.tool===`Agent`||e.tool===`Task`)&&e.toolUseId===t);if(n===-1)return!1;let r=E.current[n];if(r.type!==`tool_use`)return!1;let i=[...r.children??[],e];return E.current[n]={...r,children:i},!0},r=()=>{let e=T.current,t=[...E.current],n=D.current;i(r=>{let i=r[r.length-1];return i?.role===`assistant`&&!i.id.startsWith(`final-`)?[...r.slice(0,-1),{...i,content:e,events:t,...n}]:[...r,{id:`streaming-${Date.now()}`,role:`assistant`,content:e,events:t,timestamp:new Date().toISOString(),...n}]})};switch(t.type){case`account_info`:D.current={accountId:t.accountId,accountLabel:t.accountLabel};break;case`text`:{let e=t.parentToolUseId;if(e&&n(t,e)){r();break}T.current+=t.content,E.current.push(t),r();break}case`thinking`:{let e=t.parentToolUseId;if(e&&n(t,e)){r();break}E.current.push(t),r();break}case`tool_use`:{let e=t.parentToolUseId;if(e&&n(t,e)){r();break}E.current.push(t),r();break}case`tool_result`:{let e=t.parentToolUseId;if(e&&n(t,e)){r();break}E.current.push(t),r();break}case`approval_request`:if(E.current.push(t),g({requestId:t.requestId,tool:t.tool,input:t.input}),M.current&&!Ke(M.current)){let e=t.tool===`AskUserQuestion`?`question`:`approval_request`;oe.getState().addNotification(M.current,e,N.current),Ge(e)}break;case`error`:{E.current.push(t);let e=[...E.current];i(n=>{let r=n[n.length-1];return r?.role===`assistant`?[...n.slice(0,-1),{...r,events:e}]:[...n,{id:`error-${Date.now()}`,role:`system`,content:t.message,events:[t],timestamp:new Date().toISOString()}]}),O.current=!1,c(!1),u(`idle`);break}case`done`:{if(!O.current)break;t.contextWindowPct!=null&&b(t.contextWindowPct),M.current&&!Ke(M.current)&&(oe.getState().addNotification(M.current,`done`,N.current),Ge(`done`));let e=T.current,n=[...E.current];i(t=>{let r=t[t.length-1];return r?.role===`assistant`?[...t.slice(0,-1),{...r,id:`final-${Date.now()}`,content:e||r.content,events:n.length>0?n:r.events}]:t}),T.current=``,E.current=[],D.current=null,O.current=!1,c(!1),u(`idle`);break}}},[]),{send:F,connect:I}=Re({url:e&&n?`/ws/project/${encodeURIComponent(n)}/chat/${e}`:``,onMessage:P,autoConnect:!!e&&!!n});A.current=F,(0,J.useEffect)(()=>{let r=!1;return c(!1),g(null),T.current=``,E.current=[],w(!1),e&&n?(o(!0),fetch(`${v(n)}/chat/sessions/${e}/messages?providerId=${t}`,{headers:{Authorization:`Bearer ${y()}`}}).then(e=>e.json()).then(e=>{r||O.current||(e.ok&&Array.isArray(e.data)&&e.data.length>0?i(e.data):i([]))}).catch(()=>{!r&&!O.current&&i([])}).finally(()=>{r||o(!1)})):i([]),()=>{r=!0}},[e,t,n]);let L=(0,J.useCallback)((e,t)=>{if(e.trim()){if(O.current){let e=T.current,t=[...E.current];i(n=>{let r=n[n.length-1];return r?.role===`assistant`?[...n.slice(0,-1),{...r,id:`final-${Date.now()}`,content:e||r.content,events:t.length>0?t:r.events}]:n}),F(JSON.stringify({type:`cancel`}))}i(t=>[...t,{id:`user-${Date.now()}`,role:`user`,content:e,timestamp:new Date().toISOString()}]),T.current=``,E.current=[],k.current=null,O.current=!0,c(!0),u(`connecting`),g(null),F(JSON.stringify({type:`message`,content:e,permissionMode:t?.permissionMode}))}},[F]),R=(0,J.useCallback)((e,t,n)=>{if(F(JSON.stringify({type:`approval_response`,requestId:e,approved:t,data:n})),t&&n){let t=E.current.find(t=>t.type===`approval_request`&&t.requestId===e&&t.tool===`AskUserQuestion`);if(t){let e=t.input;e&&typeof e==`object`&&(e.answers=n)}i(e=>[...e])}g(null)},[F]),ee=(0,J.useCallback)(()=>{if(!O.current)return;F(JSON.stringify({type:`cancel`}));let e=T.current,t=[...E.current];i(n=>{let r=n[n.length-1];return r?.role===`assistant`?[...n.slice(0,-1),{...r,id:`final-${Date.now()}`,content:e||r.content,events:t.length>0?t:r.events}]:n}),T.current=``,E.current=[],k.current=null,O.current=!1,c(!1),g(null)},[F]),z=(0,J.useCallback)(()=>{w(!1),I(),j.current?.()},[I]),B=(0,J.useCallback)(()=>{!e||!n||(o(!0),fetch(`${v(n)}/chat/sessions/${e}/messages?providerId=${t}`,{headers:{Authorization:`Bearer ${y()}`}}).then(e=>e.json()).then(e=>{e.ok&&Array.isArray(e.data)&&e.data.length>0&&(i(e.data),T.current=``,E.current=[])}).catch(()=>{}).finally(()=>o(!1)))},[e,t,n]);return j.current=B,{messages:r,messagesLoading:a,isStreaming:s,streamingStatus:l,connectingElapsed:d,thinkingWarningThreshold:p,pendingApproval:h,contextWindowPct:_,sessionTitle:x,sendMessage:L,respondToApproval:R,cancelStreaming:ee,reconnect:z,refetchMessages:B,isConnected:C}}var Je=12e4;function Ye(e,t=`claude`){let[n,r]=(0,J.useState)({}),[i,a]=(0,J.useState)(!1),[o,s]=(0,J.useState)(null),c=(0,J.useRef)(null),l=(0,J.useCallback)((n=!1)=>{if(!e)return;a(!0);let i=n?`&refresh=1`:``;fetch(`${v(e)}/chat/usage?providerId=${t}${i}`,{headers:{Authorization:`Bearer ${y()}`}}).then(e=>e.json()).then(e=>{e.ok&&e.data&&(r(t=>({...t,...e.data})),e.data.lastFetchedAt&&s(e.data.lastFetchedAt))}).catch(()=>{}).finally(()=>a(!1))},[e,t]);return(0,J.useEffect)(()=>(l(),c.current=setInterval(()=>l(),Je),()=>{c.current&&clearInterval(c.current)}),[l]),{usageInfo:n,usageLoading:i,lastFetchedAt:o,refreshUsage:(0,J.useCallback)(()=>l(!0),[l])}}var Xe={damping:.7,stiffness:.05,mass:1.25},Ze=70,Qe=1e3/60,$e=350,et=!1;globalThis.document?.addEventListener(`mousedown`,()=>{et=!0}),globalThis.document?.addEventListener(`mouseup`,()=>{et=!1}),globalThis.document?.addEventListener(`click`,()=>{et=!1});var tt=(e={})=>{let[t,n]=(0,J.useState)(!1),[r,i]=(0,J.useState)(e.initial!==!1),[a,o]=(0,J.useState)(!1),s=(0,J.useRef)(null);s.current=e;let c=(0,J.useCallback)(()=>{if(!et)return!1;let e=window.getSelection();if(!e||!e.rangeCount)return!1;let t=e.getRangeAt(0);return t.commonAncestorContainer.contains(g.current)||g.current?.contains(t.commonAncestorContainer)},[]),l=(0,J.useCallback)(e=>{d.isAtBottom=e,i(e)},[]),u=(0,J.useCallback)(e=>{d.escapedFromLock=e,n(e)},[]),d=(0,J.useMemo)(()=>{let n;return{escapedFromLock:t,isAtBottom:r,resizeDifference:0,accumulated:0,velocity:0,listeners:new Set,get scrollTop(){return g.current?.scrollTop??0},set scrollTop(e){g.current&&(g.current.scrollTop=e,d.ignoreScrollToTop=g.current.scrollTop)},get targetScrollTop(){return!g.current||!_.current?0:g.current.scrollHeight-1-g.current.clientHeight},get calculatedTargetScrollTop(){if(!g.current||!_.current)return 0;let{targetScrollTop:t}=this;if(!e.targetScrollTop)return t;if(n?.targetScrollTop===t)return n.calculatedScrollTop;let r=Math.max(Math.min(e.targetScrollTop(t,{scrollElement:g.current,contentElement:_.current}),t),0);return n={targetScrollTop:t,calculatedScrollTop:r},requestAnimationFrame(()=>{n=void 0}),r},get scrollDifference(){return this.calculatedTargetScrollTop-this.scrollTop},get isNearBottom(){return this.scrollDifference<=Ze}}},[]),f=(0,J.useCallback)((e={})=>{typeof e==`string`&&(e={animation:e}),e.preserveScrollPosition||l(!0);let t=Date.now()+(Number(e.wait)||0),n=it(s.current,e.animation),{ignoreEscapes:r=!1}=e,i,a=d.calculatedTargetScrollTop;e.duration instanceof Promise?e.duration.finally(()=>{i=Date.now()}):i=t+(e.duration??0);let o=async()=>{let e=new Promise(requestAnimationFrame).then(()=>{if(!d.isAtBottom)return d.animation=void 0,!1;let{scrollTop:l}=d,u=performance.now(),p=(u-(d.lastTick??u))/Qe;if(d.animation||={behavior:n,promise:e,ignoreEscapes:r},d.animation.behavior===n&&(d.lastTick=u),c()||t>Date.now())return o();if(l<Math.min(a,d.calculatedTargetScrollTop)){if(d.animation?.behavior===n){if(n===`instant`)return d.scrollTop=d.calculatedTargetScrollTop,o();d.velocity=(n.damping*d.velocity+n.stiffness*d.scrollDifference)/n.mass,d.accumulated+=d.velocity*p,d.scrollTop+=d.accumulated,d.scrollTop!==l&&(d.accumulated=0)}return o()}return i>Date.now()?(a=d.calculatedTargetScrollTop,o()):(d.animation=void 0,d.scrollTop<d.calculatedTargetScrollTop?f({animation:it(s.current,s.current.resize),ignoreEscapes:r,duration:Math.max(0,i-Date.now())||void 0}):d.isAtBottom)});return e.then(e=>(requestAnimationFrame(()=>{d.animation||(d.lastTick=void 0,d.velocity=0)}),e))};return e.wait!==!0&&(d.animation=void 0),d.animation?.behavior===n?d.animation.promise:o()},[l,c,d]),p=(0,J.useCallback)(()=>{u(!0),l(!1)},[u,l]),m=(0,J.useCallback)(({target:e})=>{if(e!==g.current)return;let{scrollTop:t,ignoreScrollToTop:n}=d,{lastScrollTop:r=t}=d;d.lastScrollTop=t,d.ignoreScrollToTop=void 0,n&&n>t&&(r=n),o(d.isNearBottom),setTimeout(()=>{if(d.resizeDifference||t===n)return;if(c()){u(!0),l(!1);return}let e=t>r,i=t<r;if(d.animation?.ignoreEscapes){d.scrollTop=r;return}i&&(u(!0),l(!1)),e&&u(!1),!d.escapedFromLock&&d.isNearBottom&&l(!0)},1)},[u,l,c,d]),h=(0,J.useCallback)(({target:e,deltaY:t})=>{let n=e;for(;![`scroll`,`auto`].includes(getComputedStyle(n).overflow);){if(!n.parentElement)return;n=n.parentElement}n===g.current&&t<0&&g.current.scrollHeight>g.current.clientHeight&&!d.animation?.ignoreEscapes&&(u(!0),l(!1))},[u,l,d]),g=nt(e=>{g.current?.removeEventListener(`scroll`,m),g.current?.removeEventListener(`wheel`,h),e?.addEventListener(`scroll`,m,{passive:!0}),e?.addEventListener(`wheel`,h,{passive:!0})},[]),_=nt(e=>{if(d.resizeObserver?.disconnect(),!e)return;let t;d.resizeObserver=new ResizeObserver(([e])=>{let{height:n}=e.contentRect,r=n-(t??n);if(d.resizeDifference=r,d.scrollTop>d.targetScrollTop&&(d.scrollTop=d.targetScrollTop),o(d.isNearBottom),r>=0){let e=it(s.current,t?s.current.resize:s.current.initial);f({animation:e,wait:!0,preserveScrollPosition:!0,duration:e===`instant`?void 0:$e})}else d.isNearBottom&&(u(!1),l(!0));t=n,requestAnimationFrame(()=>{setTimeout(()=>{d.resizeDifference===r&&(d.resizeDifference=0)},1)})}),d.resizeObserver?.observe(e)},[]);return{contentRef:_,scrollRef:g,scrollToBottom:f,stopScroll:p,isAtBottom:r||a,isNearBottom:a,escapedFromLock:t,state:d}};function nt(e,t){let n=(0,J.useCallback)(t=>(n.current=t,e(t)),t);return n}var rt=new Map;function it(...e){let t={...Xe},n=!1;for(let r of e){if(r===`instant`){n=!0;continue}typeof r==`object`&&(n=!1,t.damping=r.damping??t.damping,t.stiffness=r.stiffness??t.stiffness,t.mass=r.mass??t.mass)}let r=JSON.stringify(t);return rt.has(r)||rt.set(r,Object.freeze(t)),n?`instant`:rt.get(r)}var at=(0,J.createContext)(null),ot=typeof window<`u`?J.useLayoutEffect:J.useEffect;function st({instance:e,children:t,resize:n,initial:r,mass:i,damping:a,stiffness:o,targetScrollTop:s,contextRef:c,...l}){let u=(0,J.useRef)(null),d=tt({mass:i,damping:a,stiffness:o,resize:n,initial:r,targetScrollTop:J.useCallback((e,t)=>(y?.targetScrollTop??s)?.(e,t)??e,[s])}),{scrollRef:f,contentRef:p,scrollToBottom:m,stopScroll:h,isAtBottom:g,escapedFromLock:_,state:v}=e??d,y=(0,J.useMemo)(()=>({scrollToBottom:m,stopScroll:h,scrollRef:f,isAtBottom:g,escapedFromLock:_,contentRef:p,state:v,get targetScrollTop(){return u.current},set targetScrollTop(e){u.current=e}}),[m,g,p,f,h,_,v]);return(0,J.useImperativeHandle)(c,()=>y,[y]),ot(()=>{f.current&&getComputedStyle(f.current).overflow===`visible`&&(f.current.style.overflow=`auto`)},[]),J.createElement(at.Provider,{value:y},J.createElement(`div`,{...l},typeof t==`function`?t(y):t))}(function(e){function t({children:e,scrollClassName:t,...n}){let r=ct();return J.createElement(`div`,{ref:r.scrollRef,style:{height:`100%`,width:`100%`,scrollbarGutter:`stable both-edges`},className:t},J.createElement(`div`,{...n,ref:r.contentRef},typeof e==`function`?e(r):e))}e.Content=t})(st||={});function ct(){let e=(0,J.useContext)(at);if(!e)throw Error(`use-stick-to-bottom component context must be used within a StickToBottom component`);return e}var X=o();function lt(e){let t=e.type===`approval_request`;return{toolName:e.type===`tool_use`?e.tool:t?e.tool??`Tool`:`Tool`,input:e.type===`tool_use`?e.input:t?e.input??{}:{}}}function ut({tool:e,result:t,completed:n,projectName:i}){let[a,o]=(0,J.useState)(!1);if(e.type===`error`)return(0,X.jsxs)(`div`,{className:`flex items-center gap-2 rounded bg-red-500/10 border border-red-500/20 px-2 py-1.5 text-xs text-red-400`,children:[(0,X.jsx)(A,{className:`size-3`}),(0,X.jsx)(`span`,{children:e.message})]});let{toolName:s,input:c}=lt(e),l=t?.type===`tool_result`,u=l&&!!t.isError,d=s===`AskUserQuestion`&&!!c?.answers,f=(s===`Agent`||s===`Task`)&&e.type===`tool_use`,p=f?e.children:void 0,m=p&&p.length>0;return(0,X.jsxs)(`div`,{className:`rounded border text-xs ${f?`border-accent/30 bg-accent/5`:`border-border bg-background`}`,children:[(0,X.jsxs)(`button`,{onClick:()=>o(!a),className:`flex items-center gap-2 px-2 py-1.5 w-full text-left hover:bg-surface transition-colors min-w-0`,children:[a?(0,X.jsx)(r,{className:`size-3 shrink-0`}):(0,X.jsx)(K,{className:`size-3 shrink-0`}),u?(0,X.jsx)(Se,{className:`size-3 text-red-400 shrink-0`}):l||d||n?(0,X.jsx)(H,{className:`size-3 text-green-400 shrink-0`}):(0,X.jsx)(q,{className:`size-3 text-yellow-400 shrink-0 animate-spin`}),(0,X.jsx)(`span`,{className:`truncate text-text-primary`,children:(0,X.jsx)(dt,{name:s,input:c})}),m&&(0,X.jsxs)(`span`,{className:`ml-auto text-[10px] text-text-subtle shrink-0`,children:[p.length,` steps`]})]}),a&&(0,X.jsxs)(`div`,{className:`px-2 pb-2 space-y-1.5`,children:[(e.type===`tool_use`||e.type===`approval_request`)&&(0,X.jsx)(ft,{name:s,input:c,projectName:i}),m&&(0,X.jsx)(gt,{events:p,projectName:i}),l&&(0,X.jsx)(mt,{toolName:s,output:t.output})]})]})}function dt({name:e,input:t}){let n=e=>String(e??``);switch(e){case`Read`:case`Write`:case`Edit`:case`MultiEdit`:case`NotebookEdit`:return(0,X.jsxs)(X.Fragment,{children:[e,` `,(0,X.jsx)(`span`,{className:`text-text-subtle`,children:h(n(t.file_path))})]});case`Bash`:return(0,X.jsxs)(X.Fragment,{children:[e,` `,(0,X.jsx)(`span`,{className:`font-mono text-text-subtle`,children:Z(n(t.command),60)})]});case`Glob`:return(0,X.jsxs)(X.Fragment,{children:[e,` `,(0,X.jsx)(`span`,{className:`font-mono text-text-subtle`,children:n(t.pattern)})]});case`Grep`:return(0,X.jsxs)(X.Fragment,{children:[e,` `,(0,X.jsx)(`span`,{className:`font-mono text-text-subtle`,children:Z(n(t.pattern),40)})]});case`WebSearch`:return(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(z,{className:`size-3 inline`}),` `,e,` `,(0,X.jsx)(`span`,{className:`text-text-subtle`,children:Z(n(t.query),50)})]});case`WebFetch`:return(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(M,{className:`size-3 inline`}),` `,e,` `,(0,X.jsx)(`span`,{className:`text-text-subtle`,children:Z(n(t.url),50)})]});case`ToolSearch`:return(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(z,{className:`size-3 inline`}),` `,e,` `,(0,X.jsx)(`span`,{className:`text-text-subtle`,children:Z(n(t.query),50)})]});case`Agent`:case`Task`:return(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(ge,{className:`size-3 inline`}),` `,e,` `,(0,X.jsx)(`span`,{className:`text-text-subtle`,children:Z(n(t.description||t.prompt),60)})]});case`TodoWrite`:{let n=Array.isArray(t.todos)?t.todos:[],r=n.filter(e=>e.status===`completed`).length;return(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(Oe,{className:`size-3 inline`}),` `,e,` `,(0,X.jsxs)(`span`,{className:`text-text-subtle`,children:[r,`/`,n.length,` done`]})]})}case`AskUserQuestion`:{let n=Array.isArray(t.questions)?t.questions:[],r=!!t.answers;return(0,X.jsxs)(X.Fragment,{children:[e,` `,(0,X.jsxs)(`span`,{className:`text-text-subtle`,children:[n.length,` question`,n.length===1?``:`s`,r?` ✓`:``]})]})}default:return(0,X.jsx)(X.Fragment,{children:e})}}function ft({name:e,input:t,projectName:n}){let r=e=>String(e??``),{openTab:i}=_(),a=e=>{n&&i({type:`editor`,title:h(e),metadata:{filePath:e,projectName:n},projectId:n,closable:!0})},o=(e,t,r)=>{i({type:`git-diff`,title:`Diff ${h(e)}`,metadata:{filePath:e,projectName:n,original:t,modified:r},projectId:n??null,closable:!0})};switch(e){case`Bash`:return(0,X.jsxs)(`div`,{className:`space-y-1`,children:[!!t.description&&(0,X.jsx)(`p`,{className:`text-text-subtle italic`,children:r(t.description)}),(0,X.jsx)(`pre`,{className:`font-mono text-text-secondary overflow-x-auto whitespace-pre-wrap break-all`,children:r(t.command)})]});case`Read`:case`Write`:case`Edit`:case`MultiEdit`:case`NotebookEdit`:{let n=r(t.file_path);return(0,X.jsxs)(`div`,{className:`space-y-1`,children:[(0,X.jsxs)(`button`,{type:`button`,className:`font-mono text-text-secondary break-all hover:text-primary hover:underline text-left flex items-center gap-1`,onClick:()=>a(n),title:`Open file in editor`,children:[(0,X.jsx)(me,{className:`size-3 shrink-0`}),n]}),e===`Edit`&&(!!t.old_string||!!t.new_string)&&(0,X.jsxs)(`button`,{type:`button`,className:`text-text-subtle hover:text-primary hover:underline text-left flex items-center gap-1`,onClick:()=>o(n,r(t.old_string),r(t.new_string)),title:`View diff in new tab`,children:[(0,X.jsx)(s,{className:`size-3 shrink-0`}),`View Diff`]}),e===`Write`&&!!t.content&&(0,X.jsx)(`pre`,{className:`font-mono text-text-subtle overflow-x-auto max-h-32 whitespace-pre-wrap`,children:Z(r(t.content),300)})]})}case`Glob`:return(0,X.jsxs)(`p`,{className:`font-mono text-text-secondary`,children:[r(t.pattern),t.path?` in ${r(t.path)}`:``]});case`Grep`:return(0,X.jsxs)(`div`,{className:`space-y-0.5`,children:[(0,X.jsxs)(`p`,{className:`font-mono text-text-secondary`,children:[`/`,r(t.pattern),`/`]}),!!t.path&&(0,X.jsxs)(`p`,{className:`text-text-subtle`,children:[`in `,r(t.path)]})]});case`TodoWrite`:return(0,X.jsx)(pt,{todos:t.todos??[]});case`Agent`:case`Task`:return(0,X.jsxs)(`div`,{className:`space-y-1`,children:[!!t.description&&(0,X.jsx)(`p`,{className:`text-text-secondary font-medium`,children:r(t.description)}),!!t.subagent_type&&(0,X.jsxs)(`p`,{className:`text-text-subtle`,children:[`Type: `,r(t.subagent_type)]}),!!t.prompt&&(0,X.jsx)(_t,{content:r(t.prompt),maxHeight:`max-h-48`})]});case`ToolSearch`:return(0,X.jsxs)(`div`,{className:`space-y-0.5`,children:[(0,X.jsx)(`p`,{className:`font-mono text-text-secondary`,children:r(t.query)}),!!t.max_results&&(0,X.jsxs)(`p`,{className:`text-text-subtle`,children:[`Max results: `,r(t.max_results)]})]});case`WebFetch`:return(0,X.jsxs)(`div`,{className:`space-y-0.5`,children:[(0,X.jsxs)(`a`,{href:r(t.url),target:`_blank`,rel:`noopener noreferrer`,className:`font-mono text-primary hover:underline break-all flex items-center gap-1`,children:[(0,X.jsx)(M,{className:`size-3 shrink-0`}),r(t.url)]}),!!t.prompt&&(0,X.jsx)(`p`,{className:`text-text-subtle`,children:Z(r(t.prompt),100)})]});case`AskUserQuestion`:{let e=t.questions??[],n=t.answers??{};return(0,X.jsx)(`div`,{className:`space-y-2`,children:e.map((e,t)=>(0,X.jsxs)(`div`,{className:`space-y-0.5`,children:[(0,X.jsxs)(`p`,{className:`text-text-primary font-medium`,children:[e.header?`${e.header}: `:``,e.question]}),(0,X.jsx)(`div`,{className:`flex flex-wrap gap-1`,children:e.options.map((t,r)=>(0,X.jsx)(`span`,{className:`inline-block rounded px-1.5 py-0.5 text-xs border ${(n[e.question]??``).split(`, `).includes(t.label)?`border-accent bg-accent/20 text-text-primary`:`border-border text-text-subtle`}`,children:t.label},r))}),n[e.question]&&(0,X.jsxs)(`p`,{className:`text-foreground text-xs`,children:[`Answer: `,n[e.question]]})]},t))})}default:return(0,X.jsx)(`pre`,{className:`overflow-x-auto text-text-secondary font-mono whitespace-pre-wrap break-all`,children:JSON.stringify(t,null,2)})}}function pt({todos:e}){return(0,X.jsx)(`div`,{className:`space-y-0.5`,children:e.map((e,t)=>(0,X.jsxs)(`div`,{className:`flex items-start gap-1.5`,children:[(0,X.jsx)(`span`,{className:`shrink-0 mt-0.5 ${e.status===`completed`?`text-green-400`:e.status===`in_progress`?`text-yellow-400`:`text-text-subtle`}`,children:e.status===`completed`?`✓`:e.status===`in_progress`?`▶`:`○`}),(0,X.jsx)(`span`,{className:e.status===`completed`?`line-through text-text-subtle`:`text-text-secondary`,children:e.content})]},t))})}function mt({toolName:e,output:t}){let[n,r]=(0,J.useState)(!1),i=(0,J.useMemo)(()=>{if(e!==`Agent`&&e!==`Task`)return null;try{let e=JSON.parse(t);if(Array.isArray(e)){let t=e.filter(e=>e.type===`text`&&e.text).map(e=>e.text).join(`
3
-
4
- `);if(t)return t}if(typeof e==`string`)return e}catch{if(t&&!t.startsWith(`[{`))return t}return null},[e,t]);return i?(0,X.jsxs)(`div`,{className:`border-t border-border pt-1.5 space-y-1`,children:[(0,X.jsx)(_t,{content:i,maxHeight:`max-h-60`}),(0,X.jsxs)(`button`,{type:`button`,onClick:()=>r(!n),className:`flex items-center gap-1 text-[10px] text-text-subtle hover:text-text-secondary transition-colors`,children:[(0,X.jsx)(we,{className:`size-3`}),n?`Hide`:`Show`,` raw`]}),n&&(0,X.jsx)(`pre`,{className:`overflow-x-auto text-text-subtle font-mono max-h-40 whitespace-pre-wrap break-all text-[10px]`,children:t})]}):(0,X.jsx)(ht,{output:t})}function ht({output:e}){let t=e.split(`
5
- `).length,n=t>3||e.length>200,[i,a]=(0,J.useState)(n);return(0,X.jsxs)(`div`,{className:`border-t border-border pt-1.5`,children:[n&&(0,X.jsxs)(`button`,{type:`button`,onClick:()=>a(!i),className:`flex items-center gap-1 text-[10px] text-text-subtle hover:text-text-secondary transition-colors mb-1`,children:[i?(0,X.jsx)(K,{className:`size-3`}):(0,X.jsx)(r,{className:`size-3`}),`Output (`,t,` lines)`]}),(0,X.jsx)(`pre`,{className:`overflow-x-auto text-text-subtle font-mono whitespace-pre-wrap break-all ${i?`max-h-16 overflow-hidden`:`max-h-60`}`,children:e})]})}function gt({events:e,projectName:t}){let n=[],r=``;for(let t of e)if(t.type===`text`)r+=t.content;else if(t.type===`tool_use`)r&&=(n.push({kind:`text`,content:r}),``),n.push({kind:`tool`,tool:t});else if(t.type===`tool_result`){let e=t.toolUseId,r=e?n.find(t=>t.kind===`tool`&&t.tool.type===`tool_use`&&t.tool.toolUseId===e&&!t.result):n.findLast(e=>e.kind===`tool`&&!e.result);r&&(r.result=t)}return r&&n.push({kind:`text`,content:r}),(0,X.jsx)(`div`,{className:`border-l-2 border-accent/20 pl-2 space-y-1 mt-1`,children:n.map((e,n)=>e.kind===`text`?(0,X.jsx)(`div`,{className:`text-text-secondary text-[11px]`,children:(0,X.jsx)(_t,{content:e.content,maxHeight:`max-h-24`})},`st-${n}`):(0,X.jsx)(ut,{tool:e.tool,result:e.result,completed:!!e.result,projectName:t},`sc-${n}`))})}function _t({content:e,maxHeight:t=`max-h-48`}){return(0,X.jsx)(ye,{content:e,className:`text-text-secondary overflow-auto ${t}`})}function Z(e,t=50){return e?e.length>t?e.slice(0,t)+`…`:e:``}function vt(e){let[t,n]=(0,J.useState)({}),[r,i]=(0,J.useState)({}),[a,o]=(0,J.useState)(0),s=(0,J.useCallback)((e,t)=>{n(n=>({...n,[e]:[t]})),i(t=>({...t,[e]:``}))},[]),c=(0,J.useCallback)((e,t)=>{n(n=>{let r=n[e]||[];return{...n,[e]:r.includes(t)?r.filter(e=>e!==t):[...r,t]}})},[]),l=(0,J.useCallback)((e,t)=>{i(n=>({...n,[e]:t})),t&&n(t=>({...t,[e]:[]}))},[]),u=(0,J.useCallback)(e=>(t[e]?.length??0)>0||(r[e]?.trim().length??0)>0,[t,r]);return{answers:t,customInputs:r,activeTab:a,setActiveTab:o,handleSingleSelect:s,handleMultiSelect:c,handleCustomInput:l,hasAnswer:u,allAnswered:(0,J.useMemo)(()=>e.every((e,t)=>u(t)),[e,u]),getFinalAnswer:(0,J.useCallback)(e=>r[e]?.trim()||(t[e]??[]).join(`, `),[t,r]),goToNextTab:(0,J.useCallback)(()=>o(t=>Math.min(t+1,e.length-1)),[e.length]),goToPrevTab:(0,J.useCallback)(()=>o(e=>Math.max(e-1,0)),[])}}function yt(e){let[t,n]=(0,J.useState)(0),r=(0,J.useRef)(null);return(0,J.useEffect)(()=>n(0),[e.activeTab]),(0,J.useEffect)(()=>{if(!e.enabled)return;let i=r=>{let i=document.activeElement===e.customInputRef.current;if(!i&&r.key>=`1`&&r.key<=`9`){r.preventDefault();let t=parseInt(r.key)-1;t<e.totalOptions-1&&(n(t),e.onSelectOption(t));return}if(!i&&(r.key===`o`||r.key===`O`||r.key===`0`)){r.preventDefault(),e.customInputRef.current?.focus(),n(e.totalOptions-1);return}if(r.key===`Tab`&&e.questions.length>1){r.preventDefault(),r.shiftKey?e.goToPrevTab():e.goToNextTab();return}if(!i){if(r.key===`ArrowLeft`){r.preventDefault(),e.goToPrevTab();return}if(r.key===`ArrowRight`){r.preventDefault(),e.goToNextTab();return}if(r.key===`ArrowUp`){r.preventDefault(),n(e=>Math.max(0,e-1));return}if(r.key===`ArrowDown`){r.preventDefault(),n(t=>Math.min(e.totalOptions-1,t+1));return}if(r.key===` `){r.preventDefault(),e.onSelectOption(t);return}}if(r.key===`Enter`){r.preventDefault(),e.allAnswered?e.onSubmit():e.hasAnswer(e.activeTab)&&e.goToNextTab();return}r.key===`Escape`&&i&&e.customInputRef.current?.blur()},a=r.current;return a&&(a.addEventListener(`keydown`,i),a.setAttribute(`tabindex`,`0`),a.contains(document.activeElement)||a.focus()),()=>{a?.removeEventListener(`keydown`,i)}},[e,t]),{focusedOption:t,setFocusedOption:n,containerRef:r}}function bt({questions:e,onSubmit:t,onSkip:n}){let r=(0,J.useRef)(null),i=vt(e),a=e[i.activeTab],o=a?a.options.length+1:0,s=e.length>1,c=(0,J.useCallback)(()=>{if(!i.allAnswered)return;let n={};e.forEach((e,t)=>{n[e.question]=i.getFinalAnswer(t)}),t(n)},[i.allAnswered,i.getFinalAnswer,e,t]),l=(0,J.useCallback)(e=>{if(!(!a||e<0))if(e<a.options.length){let t=a.options[e]?.label;if(!t)return;a.multiSelect?i.handleMultiSelect(i.activeTab,t):i.handleSingleSelect(i.activeTab,t)}else e===a.options.length&&r.current?.focus()},[a,i]),u=yt({questions:e,activeTab:i.activeTab,totalOptions:o,allAnswered:i.allAnswered,hasAnswer:i.hasAnswer,onSelectOption:l,goToNextTab:i.goToNextTab,goToPrevTab:i.goToPrevTab,onSubmit:c,customInputRef:r,enabled:!0}),d=(0,J.useCallback)(e=>{l(e),u.setFocusedOption(e)},[l,u.setFocusedOption]);return(0,X.jsxs)(`div`,{ref:u.containerRef,className:`rounded-lg border-2 border-primary/30 bg-primary/5 p-3 space-y-3 outline-none animate-in slide-in-from-bottom-2`,children:[(0,X.jsxs)(`div`,{className:`flex items-center justify-between text-sm font-medium text-text-primary`,children:[(0,X.jsxs)(`span`,{children:[`AI has `,s?`${e.length} questions`:`a question`]}),(0,X.jsxs)(`span`,{className:`text-[10px] text-text-secondary font-normal`,children:[s?`←→ tabs · `:``,`↑↓ options · 1-`,Math.min(o-1,9),` select · Enter submit`]})]}),s&&(0,X.jsx)(`div`,{className:`flex gap-1 p-1 bg-background rounded-md overflow-x-auto border border-border`,children:e.map((e,t)=>(0,X.jsxs)(`button`,{className:`flex items-center gap-1.5 px-3 py-1.5 rounded text-xs whitespace-nowrap transition-all ${i.activeTab===t?`bg-primary text-primary-foreground`:i.hasAnswer(t)?`text-primary bg-transparent`:`text-text-secondary hover:bg-surface-elevated`}`,onClick:()=>{i.setActiveTab(t),u.setFocusedOption(0)},tabIndex:-1,children:[(0,X.jsx)(`span`,{className:`flex items-center justify-center w-4 h-4 rounded-full text-[10px] font-semibold ${i.activeTab===t?`bg-white/20`:i.hasAnswer(t)?`bg-primary/20 text-primary`:`bg-surface-elevated text-text-secondary`}`,children:i.hasAnswer(t)?`✓`:t+1}),(0,X.jsx)(`span`,{className:`max-w-[100px] overflow-hidden text-ellipsis`,children:e.header||`Q${t+1}`})]},t))}),a&&(0,X.jsxs)(`div`,{className:`space-y-2`,children:[!s&&a.header&&(0,X.jsx)(`div`,{className:`text-[11px] font-semibold uppercase tracking-wide text-text-secondary`,children:a.header}),(0,X.jsx)(`div`,{className:`text-sm text-text-primary`,children:a.question}),a.multiSelect&&(0,X.jsx)(`div`,{className:`text-[11px] text-text-secondary`,children:`Select multiple`}),(0,X.jsxs)(`div`,{className:`flex flex-col gap-1.5`,children:[a.options.map((e,t)=>{let n=(i.answers[i.activeTab]||[]).includes(e.label),r=u.focusedOption===t;return(0,X.jsxs)(`button`,{onClick:()=>d(t),className:`text-left flex items-start gap-2.5 rounded px-2.5 py-2 text-xs border transition-all ${n?`border-primary bg-primary/10 text-text-primary`:`border-border bg-background text-text-secondary hover:border-primary/40 hover:bg-primary/5`} ${r?`ring-2 ring-primary/40 ring-offset-1 ring-offset-background`:``}`,children:[(0,X.jsx)(`span`,{className:`flex items-center justify-center w-4.5 h-4.5 rounded text-[10px] font-semibold shrink-0 mt-px ${n?`bg-primary/20 text-primary`:`bg-surface-elevated text-text-secondary`}`,children:t+1}),(0,X.jsxs)(`div`,{className:`flex flex-col gap-0.5 flex-1`,children:[(0,X.jsx)(`span`,{className:`font-medium text-text-primary`,children:e.label}),e.description&&(0,X.jsx)(`span`,{className:`text-[11px] text-text-secondary`,children:e.description})]})]},t)}),(0,X.jsxs)(`div`,{className:`flex items-start gap-2.5 rounded px-2.5 py-2 text-xs border border-dashed transition-all border-border bg-transparent ${u.focusedOption===o-1?`ring-2 ring-primary/40 ring-offset-1 ring-offset-background`:``}`,children:[(0,X.jsx)(`span`,{className:`flex items-center justify-center w-4.5 h-4.5 rounded bg-surface-elevated text-text-secondary text-[10px] font-semibold shrink-0 mt-px`,children:`O`}),(0,X.jsx)(`input`,{ref:r,type:`text`,className:`flex-1 px-2 py-1 text-xs bg-surface border border-border rounded text-text-primary outline-none placeholder:text-text-subtle focus:border-primary`,placeholder:`Other (press O to type)...`,value:i.customInputs[i.activeTab]||``,onChange:e=>i.handleCustomInput(i.activeTab,e.target.value),onFocus:()=>u.setFocusedOption(o-1)})]})]})]}),(0,X.jsxs)(`div`,{className:`flex gap-2 justify-end pt-1`,children:[s&&(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(`button`,{className:`px-3 py-1.5 text-xs rounded border border-border bg-background text-text-primary hover:bg-surface-elevated disabled:opacity-40 disabled:cursor-not-allowed transition-colors`,onClick:i.goToPrevTab,disabled:i.activeTab===0,tabIndex:-1,children:`← Prev`}),(0,X.jsx)(`button`,{className:`px-3 py-1.5 text-xs rounded border border-border bg-background text-text-primary hover:bg-surface-elevated disabled:opacity-40 disabled:cursor-not-allowed transition-colors`,onClick:i.goToNextTab,disabled:i.activeTab===e.length-1,tabIndex:-1,children:`Next →`})]}),(0,X.jsx)(`button`,{onClick:n,className:`px-4 py-1.5 rounded border border-border bg-background text-text-secondary text-xs hover:bg-surface-elevated transition-colors`,tabIndex:-1,children:`Skip`}),(0,X.jsxs)(`button`,{onClick:c,disabled:!i.allAnswered,className:`px-4 py-1.5 rounded bg-primary text-primary-foreground text-xs font-medium hover:bg-primary/80 transition-colors disabled:opacity-40 disabled:cursor-not-allowed`,tabIndex:-1,children:[`Submit `,i.allAnswered?`✓`:`(${e.filter((e,t)=>i.hasAnswer(t)).length}/${e.length})`]})]})]})}function xt({messages:e,messagesLoading:t,pendingApproval:n,onApprovalResponse:r,isStreaming:i,streamingStatus:a,connectingElapsed:o,thinkingWarningThreshold:s,projectName:c,onFork:l}){if(t)return(0,X.jsxs)(`div`,{className:`flex flex-col items-center justify-center h-full gap-3 text-text-secondary`,children:[(0,X.jsx)(ge,{className:`size-10 text-text-subtle animate-pulse`}),(0,X.jsx)(`p`,{className:`text-sm`,children:`Loading messages...`})]});if(e.length===0&&!i)return(0,X.jsxs)(`div`,{className:`flex flex-col items-center justify-center h-full gap-3 text-text-secondary`,children:[(0,X.jsx)(ge,{className:`size-10 text-text-subtle`}),(0,X.jsx)(`p`,{className:`text-sm`,children:`Send a message to start the conversation`})]});let u=(0,J.useMemo)(()=>e.filter(e=>{let t=e.content&&e.content.trim().length>0,n=e.events&&e.events.length>0;return e.role===`user`?t:t||n}),[e]);return(0,X.jsx)(`div`,{className:`relative flex-1 overflow-hidden flex flex-col min-h-0`,children:(0,X.jsxs)(st,{className:`flex-1 overflow-y-auto overflow-x-hidden`,resize:`smooth`,initial:`instant`,children:[(0,X.jsxs)(st.Content,{className:`p-4 space-y-4`,children:[u.map(e=>(0,X.jsx)(Ct,{message:e,isStreaming:i&&e.id.startsWith(`streaming-`),projectName:c,onFork:e.role===`user`&&l?()=>l(e.content):void 0},e.id)),n&&(n.tool===`AskUserQuestion`?(0,X.jsx)(Kt,{approval:n,onRespond:r}):(0,X.jsx)(Gt,{approval:n,onRespond:r})),i&&(0,X.jsx)(Ut,{lastMessage:e[e.length-1],streamingStatus:a,elapsed:o,warningThreshold:s})]}),(0,X.jsx)(St,{})]})})}function St(){let{isAtBottom:e,scrollToBottom:t}=ct();return e?null:(0,X.jsxs)(`button`,{onClick:()=>t(),className:`absolute bottom-4 left-1/2 -translate-x-1/2 z-10 flex items-center gap-1 px-3 py-1 rounded-full bg-surface-elevated border border-border text-xs text-text-secondary hover:text-foreground shadow-lg transition-all`,children:[(0,X.jsx)(r,{className:`size-3`}),`Scroll to bottom`]})}function Ct({message:e,isStreaming:t,projectName:n,onFork:r}){return e.role===`user`?(0,X.jsx)(jt,{content:e.content,projectName:n,onFork:r}):e.role===`system`?(0,X.jsxs)(`div`,{className:`flex items-center gap-2 rounded-lg bg-red-500/10 border border-red-500/20 px-3 py-2 text-sm text-red-400`,children:[(0,X.jsx)(A,{className:`size-4 shrink-0`}),(0,X.jsx)(`p`,{children:e.content})]}):(0,X.jsxs)(`div`,{className:`flex flex-col gap-2`,children:[e.events&&e.events.length>0?(0,X.jsx)(Bt,{events:e.events,isStreaming:t,projectName:n}):e.content&&(0,X.jsx)(`div`,{className:`text-sm text-text-primary`,children:(0,X.jsx)(Wt,{content:e.content,projectName:n})}),e.accountLabel&&(0,X.jsxs)(`p`,{className:`text-[10px] select-none`,style:{color:`var(--color-text-subtle)`},children:[`via `,e.accountLabel]})]})}var wt=new Set([`.png`,`.jpg`,`.jpeg`,`.gif`,`.webp`]),Tt={"system-reminder":`Context`,claudeMd:`CLAUDE.md`,gitStatus:`Git Status`,currentDate:`Date`,fast_mode_info:`Fast Mode`,"available-deferred-tools":`Tools`,"task-notification":`Task Result`,environment_details:`Environment`};function Et(e){let t=[],n=/<(system-reminder|available-deferred-tools|antml:[\w-]+|fast_mode_info|claudeMd|gitStatus|currentDate|task-notification|environment_details)[^>]*>([\s\S]*?)<\/\1>/g,r;for(;(r=n.exec(e))!==null;){let e=r[1];t.push({name:e,label:Tt[e]??e.replace(/^antml:/,``).replace(/-/g,` `),content:r[2].trim()})}return{cleanText:e.replace(n,``).trim(),tags:t}}function Dt(e){let t=e.match(/^\[Attached file: (.+?)\]\n\n?/);if(t)return{files:[t[1]],text:e.slice(t[0].length)};let n=e.match(/^\[Attached files:\n([\s\S]+?)\]\n\n?/);return n?{files:n[1].split(`
6
- `).map(e=>e.trim()).filter(Boolean),text:e.slice(n[0].length)}:{files:[],text:e}}function Ot(e,t){let n=h(e);return`/api/project/${encodeURIComponent(t??`_`)}/chat/uploads/${encodeURIComponent(n)}`}function kt(e){let t=e.lastIndexOf(`.`);return t===-1?!1:wt.has(e.slice(t).toLowerCase())}var At=new Set([`task-notification`,`environment_details`]);function jt({content:e,projectName:t,onFork:n}){let{files:a,text:o,tags:s}=(0,J.useMemo)(()=>{let t=Dt(e),{cleanText:n,tags:r}=Et(t.text);return{files:t.files,text:n,tags:r}},[e]),c=s.some(e=>At.has(e.name)),[l,u]=(0,J.useState)(!1),[d,f]=(0,J.useState)(!1),m=(0,J.useRef)(null);return(0,J.useEffect)(()=>{let e=m.current;if(!e)return;let t=()=>f(e.scrollHeight>e.clientHeight+2);t();let n=new ResizeObserver(t);return n.observe(e),()=>n.disconnect()},[o]),(0,X.jsxs)(`div`,{className:p(`group/user relative rounded-lg px-3 py-2 text-sm border shadow-sm`,c?`bg-surface/40 border-border/40 text-text-secondary`:`bg-primary/10 border-primary/15 text-text-primary`),children:[s.length>0&&(0,X.jsx)(Mt,{tags:s}),a.length>0&&(0,X.jsx)(`div`,{className:`flex flex-wrap gap-1.5`,children:a.map((e,n)=>kt(e)?(0,X.jsx)(zt,{filePath:e,projectName:t},n):(0,X.jsxs)(`div`,{className:`flex items-center gap-1 rounded-md border border-border/60 bg-background/40 px-1.5 py-0.5 text-[11px] text-text-secondary`,children:[(0,X.jsx)(re,{className:`size-3 shrink-0`}),(0,X.jsx)(`span`,{className:`truncate max-w-32`,children:h(e)})]},n))}),o&&(0,X.jsx)(`div`,{ref:m,className:p(`whitespace-pre-wrap break-words transition-all duration-200`,!l&&`line-clamp-2`,l&&`max-h-[50vh] overflow-y-auto`),children:c?(0,X.jsx)(Lt,{text:o,projectName:t}):o}),(d||l)&&(0,X.jsx)(`button`,{onClick:()=>u(!l),className:p(`flex items-center gap-1 text-xs mt-1 transition-colors`,c?`text-text-subtle hover:text-text-secondary`:`text-primary/70 hover:text-primary`),children:l?(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(le,{className:`size-3`}),`Show less`]}):(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(r,{className:`size-3`}),`Show more`]})}),!c&&n&&(0,X.jsx)(`button`,{onClick:n,title:`Retry from this message (fork session)`,className:`absolute top-1.5 right-1.5 opacity-0 group-hover/user:opacity-100 transition-opacity size-5 flex items-center justify-center rounded text-text-subtle hover:text-text-primary`,children:(0,X.jsx)(i,{className:`size-3`})})]})}function Mt({tags:e}){return(0,X.jsx)(`div`,{className:`flex flex-wrap gap-1.5`,children:e.map((e,t)=>(0,X.jsx)(Nt,{tag:e},t))})}function Nt({tag:e}){let[t,n]=(0,J.useState)(!1);return e.name===`task-notification`?(0,X.jsx)(Ft,{content:e.content}):(0,X.jsxs)(`div`,{className:`text-xs`,children:[(0,X.jsxs)(`button`,{onClick:()=>n(!t),className:`flex items-center gap-1 rounded-full border border-border/60 bg-surface/50 px-2 py-0.5 text-text-subtle hover:text-text-secondary hover:bg-surface transition-colors`,children:[(0,X.jsx)(c,{className:`size-2.5`}),(0,X.jsx)(`span`,{children:e.label}),(0,X.jsx)(K,{className:p(`size-2.5 transition-transform`,t&&`rotate-90`)})]}),t&&(0,X.jsx)(`div`,{className:`mt-1 rounded border border-border/40 bg-surface/30 px-2 py-1.5 text-[11px] text-text-subtle/80 whitespace-pre-wrap max-h-40 overflow-y-auto leading-relaxed`,children:e.content})]})}function Pt(e,t){return e.match(RegExp(`<${t}>([\\s\\S]*?)</${t}>`))?.[1]?.trim()||void 0}function Ft({content:e}){let[t,n]=(0,J.useState)(!1),r=Pt(e,`status`),i=Pt(e,`summary`),a=Pt(e,`output-file`),o=Pt(e,`result`);return(0,X.jsxs)(`div`,{className:`text-xs`,children:[(0,X.jsxs)(`button`,{onClick:()=>n(!t),className:`flex items-center gap-1.5 rounded-full border border-border/60 bg-surface/50 px-2 py-0.5 text-text-subtle hover:text-text-secondary hover:bg-surface transition-colors`,children:[r===`completed`?(0,X.jsx)(H,{className:`size-2.5 text-green-500`}):(0,X.jsx)(Se,{className:`size-2.5 text-yellow-500`}),(0,X.jsx)(`span`,{className:`truncate max-w-80`,children:i??`Task notification`}),(0,X.jsx)(K,{className:p(`size-2.5 transition-transform shrink-0`,t&&`rotate-90`)})]}),t&&(0,X.jsxs)(`div`,{className:`mt-1 rounded border border-border/40 bg-surface/30 px-2 py-1.5 space-y-1.5`,children:[i&&(0,X.jsx)(`p`,{className:`text-[11px] text-text-secondary`,children:i}),a&&(0,X.jsx)(It,{path:a}),o&&(0,X.jsx)(`div`,{className:`text-[11px] text-text-subtle/80 max-h-60 overflow-y-auto leading-relaxed`,children:(0,X.jsx)(Wt,{content:o})})]})]})}function It({path:e,projectName:t}){return(0,X.jsxs)(`button`,{type:`button`,onClick:(0,J.useCallback)(()=>{let n=_.getState().openTab,r=t??P.getState().activeProject?.name,i=h(e),a={filePath:e};r&&(a.projectName=r),b.get(`/api/fs/read?path=${encodeURIComponent(e)}`).then(()=>{n({type:`editor`,title:i,metadata:a,projectId:null,closable:!0})}).catch(()=>{n({type:`editor`,title:i,metadata:a,projectId:null,closable:!0})})},[e,t]),className:`inline-flex items-center gap-1 rounded border border-border/50 bg-surface/50 px-1.5 py-0.5 font-mono text-[10px] text-text-secondary hover:text-text-primary hover:bg-surface transition-colors cursor-pointer`,children:[(0,X.jsx)(re,{className:`size-2.5 shrink-0`}),(0,X.jsx)(`span`,{className:`truncate max-w-60`,children:h(e)}),(0,X.jsx)(me,{className:`size-2 shrink-0 opacity-50`})]})}function Lt({text:e,projectName:t}){return(0,X.jsx)(X.Fragment,{children:(0,J.useMemo)(()=>{let t=/(\/(?:[\w.\-]+\/)+[\w.\-]+)/g,n=[],r=0,i;for(;(i=t.exec(e))!==null;)i.index>r&&n.push({kind:`text`,value:e.slice(r,i.index)}),n.push({kind:`path`,value:i[1]}),r=i.index+i[0].length;return r<e.length&&n.push({kind:`text`,value:e.slice(r)}),n},[e]).map((e,n)=>e.kind===`path`?(0,X.jsx)(It,{path:e.value,projectName:t},n):(0,X.jsx)(`span`,{children:e.value},n))})}function Rt(e){let[t,n]=(0,J.useState)(null),[r,i]=(0,J.useState)(!1);return(0,J.useEffect)(()=>{let t=!1,r,a=y();return fetch(e,{headers:a?{Authorization:`Bearer ${a}`}:{}}).then(e=>{if(!e.ok)throw Error(`Failed`);return e.blob()}).then(e=>{t||(r=URL.createObjectURL(e),n(r))}).catch(()=>{t||i(!0)}),()=>{t=!0,r&&URL.revokeObjectURL(r)}},[e]),{blobUrl:t,error:r}}function zt({filePath:e,projectName:t}){let{blobUrl:n,error:r}=Rt(Ot(e,t)),i=fe(e=>e.open),a=h(e);return(0,X.jsxs)(`button`,{type:`button`,onClick:()=>n&&i(n,a),className:`flex items-center gap-1 rounded-md border border-border/60 bg-background/40 px-1.5 py-0.5 text-[11px] text-text-secondary hover:bg-surface transition-colors cursor-pointer`,children:[n?(0,X.jsx)(`img`,{src:n,alt:a,className:`size-4 rounded-sm object-cover shrink-0`}):r?(0,X.jsx)(De,{className:`size-3 shrink-0`}):(0,X.jsx)(`div`,{className:`size-4 rounded-sm bg-surface animate-pulse shrink-0`}),(0,X.jsx)(`span`,{className:`truncate max-w-32`,children:a})]})}function Bt({events:e,isStreaming:t,projectName:n}){let r=[],i=``,a=``;for(let t=0;t<e.length;t++){let n=e[t];if(n.type===`thinking`){i&&=(r.push({kind:`text`,content:i}),``),a+=n.content;continue}a&&=(r.push({kind:`thinking`,content:a}),``),n.type===`text`?i+=n.content:n.type===`tool_use`?(i&&=(r.push({kind:`text`,content:i}),``),r.push({kind:`tool`,tool:n})):n.type===`tool_result`||(i&&=(r.push({kind:`text`,content:i}),``),r.push({kind:`tool`,tool:n}))}a&&r.push({kind:`thinking`,content:a}),i&&r.push({kind:`text`,content:i});let o=e.filter(e=>e.type===`tool_result`);for(let e of o){let t=e.toolUseId;if(t){let n=r.find(e=>e.kind===`tool`&&e.tool.type===`tool_use`&&e.tool.toolUseId===t);if(n){n.result=e;continue}}let n=r.find(e=>e.kind===`tool`&&!e.result);n&&(n.result=e)}for(let e=0;e<r.length;e++){let n=r[e];if(n.kind===`tool`&&!n.result){let i=!1;if(n.tool.type===`tool_use`&&n.tool.tool===`Read`){let t=n.tool.input?.file_path;t&&(i=r.slice(e+1).some(e=>e.kind===`tool`&&e.result&&e.tool.type===`tool_use`&&e.tool.tool===`Edit`&&e.tool.input?.file_path===t))}n.completed=i||!t}}return(0,X.jsx)(X.Fragment,{children:r.map((e,i)=>{if(e.kind===`thinking`)return(0,X.jsx)(Vt,{content:e.content,isStreaming:t&&i===r.length-1},`think-${i}`);if(e.kind===`text`){let a=t&&i===r.length-1;return(0,X.jsx)(`div`,{className:`text-sm text-text-primary`,children:(0,X.jsx)(Ht,{content:e.content,animate:a,projectName:n})},`text-${i}`)}return(0,X.jsx)(ut,{tool:e.tool,result:e.result,completed:e.completed,projectName:n},`tool-${i}`)})})}function Vt({content:e,isStreaming:t}){let[n,r]=(0,J.useState)(t);return(0,J.useEffect)(()=>{!t&&e.length>0&&r(!1)},[t,e.length]),(0,X.jsxs)(`div`,{className:`rounded border border-border/50 bg-surface/30 text-xs`,children:[(0,X.jsxs)(`button`,{onClick:()=>r(!n),className:`flex items-center gap-2 px-2 py-1.5 w-full text-left hover:bg-surface transition-colors text-text-subtle`,children:[t?(0,X.jsx)(q,{className:`size-3 animate-spin`}):(0,X.jsx)(K,{className:`size-3 transition-transform ${n?`rotate-90`:``}`}),(0,X.jsxs)(`span`,{children:[`Thinking`,t?`...`:``]}),!t&&(0,X.jsx)(`span`,{className:`text-text-subtle/50 ml-auto`,children:e.length>100?`${Math.round(e.length/4)} tokens`:``})]}),n&&(0,X.jsx)(`div`,{className:`px-2 pb-2 text-text-subtle/80 whitespace-pre-wrap max-h-60 overflow-y-auto text-[11px] leading-relaxed`,children:e})]})}function Ht({content:e,animate:t,projectName:n}){return(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(Wt,{content:e,projectName:n}),t&&(0,X.jsx)(`span`,{className:`text-text-subtle text-sm animate-pulse`,children:`Thinking...`})]})}function Ut({lastMessage:e,streamingStatus:t,elapsed:n,warningThreshold:r=15}){let i=!e||e.role!==`assistant`,a=e?.events?.length?e.events[e.events.length-1].type===`tool_result`:!1;return!i&&!a?null:(0,X.jsxs)(`div`,{className:`flex flex-col gap-1 text-sm`,children:[(0,X.jsxs)(`div`,{className:`flex items-center gap-2 text-text-subtle`,children:[(0,X.jsx)(q,{className:`size-3 animate-spin`}),(0,X.jsxs)(`span`,{children:[`Thinking`,i&&(n??0)>0&&(0,X.jsxs)(`span`,{className:`text-text-subtle/60`,children:[`... (`,n,`s)`]})]})]}),i&&(n??0)>=r&&(0,X.jsx)(`p`,{className:`text-xs text-yellow-500/80 ml-5`,children:`Taking longer than usual — may be rate-limited or API slow. Try sending a new message to retry.`})]})}function Wt({content:e,projectName:t}){return(0,X.jsx)(ye,{content:e,projectName:t,codeActions:!0})}function Gt({approval:e,onRespond:t}){return(0,X.jsxs)(`div`,{className:`rounded-lg border-2 border-yellow-500/40 bg-yellow-500/10 p-3 space-y-2`,children:[(0,X.jsxs)(`div`,{className:`flex items-center gap-2 text-yellow-400 text-sm font-medium`,children:[(0,X.jsx)(je,{className:`size-4`}),(0,X.jsx)(`span`,{children:`Tool Approval Required`})]}),(0,X.jsx)(`div`,{className:`text-xs text-text-primary`,children:(0,X.jsx)(`span`,{className:`font-medium`,children:e.tool})}),(0,X.jsx)(`pre`,{className:`text-xs font-mono text-text-secondary overflow-x-auto bg-background rounded p-2 border border-border`,children:JSON.stringify(e.input,null,2)}),(0,X.jsxs)(`div`,{className:`flex gap-2`,children:[(0,X.jsx)(`button`,{onClick:()=>t(e.requestId,!0),className:`px-4 py-1.5 rounded bg-green-600 text-white text-xs font-medium hover:bg-green-500 transition-colors`,children:`Allow`}),(0,X.jsx)(`button`,{onClick:()=>t(e.requestId,!1),className:`px-4 py-1.5 rounded bg-red-600 text-white text-xs font-medium hover:bg-red-500 transition-colors`,children:`Deny`})]})]})}function Kt({approval:e,onRespond:t}){return(0,X.jsx)(bt,{questions:e.input.questions??[],onSubmit:n=>t(e.requestId,!0,n),onSkip:()=>t(e.requestId,!1)})}var qt=new Set([`image/png`,`image/jpeg`,`image/gif`,`image/webp`]),Jt=new Set([`application/pdf`]),Yt=[`text/`,`application/json`,`application/xml`,`application/javascript`,`application/typescript`,`application/x-yaml`,`application/toml`,`application/x-sh`],Xt=new Set(`.ts,.tsx,.js,.jsx,.mjs,.cjs,.py,.rb,.go,.rs,.java,.kt,.swift,.c,.cpp,.h,.hpp,.cs,.json,.yaml,.yml,.toml,.xml,.md,.mdx,.txt,.csv,.tsv,.html,.css,.scss,.less,.sass,.sh,.bash,.zsh,.fish,.sql,.graphql,.gql,.env,.ini,.cfg,.conf,.dockerfile,.makefile,.vue,.svelte,.astro,.ipynb`.split(`,`));function Zt(e){return qt.has(e.type)}function Qt(e){if(qt.has(e.type)||Jt.has(e.type)||Yt.some(t=>e.type.startsWith(t)))return!0;let t=$t(e.name);return!!(t&&Xt.has(t))}function $t(e){let t=e.lastIndexOf(`.`);return t===-1?``:e.slice(t).toLowerCase()}function en({attachments:e,onRemove:t}){return e.length===0?null:(0,X.jsx)(`div`,{className:`flex flex-wrap gap-1.5 px-2 md:px-4 pt-2`,children:e.map(e=>(0,X.jsxs)(`div`,{className:`flex items-center gap-1.5 rounded-md border border-border bg-surface px-2 py-1 text-xs text-text-secondary max-w-48`,children:[e.previewUrl?(0,X.jsx)(`img`,{src:e.previewUrl,alt:e.name,className:`size-5 rounded object-cover shrink-0`}):e.isImage?(0,X.jsx)(De,{className:`size-3.5 shrink-0 text-text-subtle`}):(0,X.jsx)(re,{className:`size-3.5 shrink-0 text-text-subtle`}),(0,X.jsx)(`span`,{className:`truncate`,children:e.name}),e.status===`uploading`?(0,X.jsx)(q,{className:`size-3 shrink-0 animate-spin text-text-subtle`}):e.status===`error`?(0,X.jsx)(`span`,{className:`text-red-500 shrink-0`,title:`Upload failed`,children:`!`}):null,(0,X.jsx)(`button`,{type:`button`,onClick:()=>t(e.id),className:`shrink-0 rounded-sm p-0.5 hover:bg-border/50 transition-colors`,"aria-label":`Remove ${e.name}`,children:(0,X.jsx)(N,{className:`size-3`})})]},e.id))})}var Q=[{id:`default`,label:`Ask before edits`,icon:Te,description:`Claude will ask for approval before making each edit`},{id:`acceptEdits`,label:`Edit automatically`,icon:we,description:`Claude will edit files without asking first`},{id:`plan`,label:`Plan mode`,icon:Ce,description:`Claude will present a plan before editing`},{id:`bypassPermissions`,label:`Bypass permissions`,icon:Me,description:`Claude will not ask before running commands`}];function tn(e){return Q.find(t=>t.id===e)?.label??`Unknown`}function nn(e){return Q.find(t=>t.id===e)?.icon??Te}function rn({value:e,onChange:t,open:r,onOpenChange:i}){let a=(0,J.useRef)(null),o=(0,J.useRef)(0);(0,J.useEffect)(()=>{if(!r)return;let e=e=>{a.current&&!a.current.contains(e.target)&&i(!1)};return document.addEventListener(`mousedown`,e),()=>document.removeEventListener(`mousedown`,e)},[r,i]),(0,J.useEffect)(()=>{r&&(o.current=Q.findIndex(t=>t.id===e),o.current<0&&(o.current=0))},[r,e]);let s=(0,J.useCallback)(e=>{if(e.key===`Escape`){i(!1);return}if(e.key===`ArrowDown`||e.key===`ArrowUp`){e.preventDefault();let t=e.key===`ArrowDown`?1:-1;o.current=(o.current+t+Q.length)%Q.length,(a.current?.querySelector(`[data-idx="${o.current}"]`))?.focus()}if(e.key===`Enter`){e.preventDefault();let n=Q[o.current];n&&(t(n.id),i(!1))}},[t,i]);return r?(0,X.jsxs)(`div`,{ref:a,role:`listbox`,"aria-label":`Permission modes`,onKeyDown:s,onMouseDown:e=>e.stopPropagation(),onClick:e=>e.stopPropagation(),className:`absolute bottom-full left-0 mb-1 z-50 w-72 md:w-80 rounded-lg border border-border bg-surface shadow-lg`,children:[(0,X.jsxs)(`div`,{className:`flex items-center justify-between px-3 py-2 border-b border-border`,children:[(0,X.jsx)(`span`,{className:`text-xs font-medium text-text-secondary`,children:`Modes`}),(0,X.jsx)(`kbd`,{className:`text-[10px] px-1.5 py-0.5 rounded bg-surface-elevated text-text-subtle border border-border`,children:`Shift + Tab`})]}),(0,X.jsx)(`div`,{className:`py-1`,children:Q.map((r,a)=>{let o=r.icon,s=r.id===e;return(0,X.jsxs)(`button`,{"data-idx":a,role:`option`,"aria-selected":s,tabIndex:0,onClick:()=>{t(r.id),i(!1)},className:`w-full flex items-start gap-3 px-3 py-2.5 text-left transition-colors hover:bg-surface-elevated focus:bg-surface-elevated focus:outline-none ${s?`bg-surface-elevated`:``}`,children:[(0,X.jsx)(o,{className:`size-4 mt-0.5 shrink-0 text-text-secondary`}),(0,X.jsxs)(`div`,{className:`flex-1 min-w-0`,children:[(0,X.jsx)(`div`,{className:`text-sm font-medium text-text-primary`,children:r.label}),(0,X.jsx)(`div`,{className:`text-xs text-text-subtle leading-snug`,children:r.description})]}),s&&(0,X.jsx)(n,{className:`size-4 mt-0.5 shrink-0 text-primary`})]},r.id)})})]}):null}function an(e){let t=[];function n(e){for(let r of e)t.push(r),r.children&&n(r.children)}return n(e),t}function on({items:e,filter:t,onSelect:n,onClose:r,visible:i}){let[a,o]=(0,J.useState)(0),s=(0,J.useRef)(null),c=(()=>{if(!t)return e.slice(0,50);let n=t.toLowerCase();return e.filter(e=>e.path.toLowerCase().includes(n)||e.name.toLowerCase().includes(n)).slice(0,50)})();(0,J.useEffect)(()=>{o(0)},[t]),(0,J.useEffect)(()=>{let e=s.current;e&&e.children[a]?.scrollIntoView({block:`nearest`})},[a]);let l=(0,J.useCallback)(e=>{if(!i||c.length===0)return!1;switch(e.key){case`ArrowUp`:return e.preventDefault(),o(e=>e>0?e-1:c.length-1),!0;case`ArrowDown`:return e.preventDefault(),o(e=>e<c.length-1?e+1:0),!0;case`Enter`:case`Tab`:return e.preventDefault(),c[a]&&n(c[a]),!0;case`Escape`:return e.preventDefault(),r(),!0}return!1},[i,c,a,n,r]);return(0,J.useEffect)(()=>{if(!i)return;let e=e=>{l(e)&&e.stopPropagation()};return document.addEventListener(`keydown`,e,!0),()=>document.removeEventListener(`keydown`,e,!0)},[i,l]),!i||c.length===0?null:(0,X.jsx)(`div`,{className:`max-h-52 overflow-y-auto border-b border-border bg-surface`,children:(0,X.jsx)(`div`,{ref:s,className:`py-1`,children:c.map((e,t)=>(0,X.jsxs)(`button`,{className:`flex items-center gap-2 w-full px-3 py-1.5 text-left transition-colors ${t===a?`bg-primary/10 text-primary`:`hover:bg-surface-hover text-text-primary`}`,onMouseEnter:()=>o(t),onClick:()=>n(e),children:[(0,X.jsx)(`span`,{className:`shrink-0`,children:e.type===`directory`?(0,X.jsx)(I,{className:`size-4 text-amber-500`}):(0,X.jsx)(ne,{className:`size-4 text-blue-400`})}),(0,X.jsx)(`span`,{className:`text-sm truncate`,children:e.path})]},e.path))})})}var sn=(0,J.memo)(function({onSend:e,isStreaming:t,onCancel:n,disabled:r,projectName:i,onSlashStateChange:a,onSlashItemsLoaded:o,slashSelected:s,onFileStateChange:c,onFileItemsLoaded:l,fileSelected:u,externalFiles:d,initialValue:f,autoFocus:p,permissionMode:h,onModeChange:g}){let[_,x]=(0,J.useState)(f??``),[S,C]=(0,J.useState)([]),[w,T]=(0,J.useState)(!1),E=(0,J.useRef)(null),D=(0,J.useRef)(null),O=(0,J.useRef)(null),k=(0,J.useRef)([]),A=(0,J.useRef)([]);(0,J.useEffect)(()=>{f&&(x(f),setTimeout(()=>{let e=E.current;e&&(e.focus(),e.selectionStart=e.selectionEnd=e.value.length)},50))},[f]),(0,J.useEffect)(()=>{p&&setTimeout(()=>{(window.matchMedia(`(min-width: 768px)`).matches?E.current:D.current)?.focus()},100)},[]),(0,J.useEffect)(()=>{if(!i){k.current=[],o?.([]);return}b.get(`${v(i)}/chat/slash-items`).then(e=>{k.current=e,o?.(e)}).catch(()=>{k.current=[],o?.([])})},[i]),(0,J.useEffect)(()=>{if(!i){A.current=[],l?.([]);return}b.get(`${v(i)}/files/tree?depth=5`).then(e=>{let t=an(e);A.current=t,l?.(t)}).catch(()=>{A.current=[],l?.([])})},[i]),(0,J.useEffect)(()=>{if(!s)return;let e=E.current,t=e?.selectionStart??_.length,n=_.slice(0,t),r=_.slice(t),i=n.replace(/(?:^|\s)\/\S*$/,e=>`${e.startsWith(`/`)?``:e[0]}/${s.name} `);x(i+r),a?.(!1,``),c?.(!1,``),e&&(e.focus(),setTimeout(()=>{e.selectionStart=e.selectionEnd=i.length},0))},[s]),(0,J.useEffect)(()=>{if(!u)return;let e=E.current;if(!e)return;let t=e.selectionStart,n=_.slice(0,t),r=_.slice(t),i=n.match(/@(\S*)$/);if(i){let t=n.length-i[0].length;x(n.slice(0,t)+`@${u.path} `+r);let a=t+u.path.length+2;setTimeout(()=>{e.selectionStart=e.selectionEnd=a,e.focus()},0)}else{let t=_+`@${u.path} `;x(t),setTimeout(()=>{e.selectionStart=e.selectionEnd=t.length,e.focus()},0)}c?.(!1,``)},[u]),(0,J.useEffect)(()=>{!d||d.length===0||M(d)},[d]);let j=(0,J.useCallback)(async e=>{if(!i)return null;try{let t=new FormData;t.append(`files`,e);let n={},r=y();r&&(n.Authorization=`Bearer ${r}`);let a=await(await fetch(`${v(i)}/chat/upload`,{method:`POST`,headers:n,body:t})).json();return a.ok&&Array.isArray(a.data)&&a.data.length>0?a.data[0].path:null}catch{return null}},[i]),M=(0,J.useCallback)(e=>{for(let t of e){if(!Qt(t)){x(e=>e+(e.length>0&&!e.endsWith(` `)?` `:``)+t.name);continue}let e=m(),n=Zt(t),r=n?URL.createObjectURL(t):void 0,i={id:e,name:t.name,file:t,isImage:n,previewUrl:r,status:`uploading`};C(e=>[...e,i]),j(t).then(t=>{C(n=>n.map(n=>n.id===e?{...n,serverPath:t??void 0,status:t?`ready`:`error`}:n))})}(D.current??E.current)?.focus()},[j]),N=(0,J.useCallback)(e=>{C(t=>{let n=t.find(t=>t.id===e);return n?.previewUrl&&URL.revokeObjectURL(n.previewUrl),t.filter(t=>t.id!==e)})},[]),P=(0,J.useCallback)(()=>{let t=_.trim(),n=S.filter(e=>e.status===`ready`);if(!(!t&&n.length===0)&&!r){a?.(!1,``),c?.(!1,``),e(t,n),x(``);for(let e of S)e.previewUrl&&URL.revokeObjectURL(e.previewUrl);C([]),E.current&&(E.current.style.height=`auto`),D.current&&(D.current.style.height=`auto`)}},[_,S,r,e,a,c]),F=(0,J.useCallback)(e=>{if(e.key===`Enter`&&!e.shiftKey){e.preventDefault(),P();return}if(e.shiftKey&&e.key===`Tab`){e.preventDefault();let t=[`default`,`acceptEdits`,`plan`,`bypassPermissions`],n=t[(t.indexOf(h??`bypassPermissions`)+1)%t.length];g?.(n)}},[P,h,g]),I=(0,J.useCallback)((e,t)=>{let n=e.slice(0,t),r=n.match(/(?:^|\s)\/(\S*)$/);if(r&&k.current.length>0){a?.(!0,r[1]??``),c?.(!1,``);return}let i=n.match(/@(\S*)$/);if(i&&A.current.length>0){c?.(!0,i[1]??``),a?.(!1,``);return}a?.(!1,``),c?.(!1,``)},[a,c]),L=(0,J.useCallback)((e,t)=>{x(e),I(e,t)},[I]),R=(0,J.useCallback)(e=>{let t=e?.target??E.current;t&&(t.style.height=`auto`,t.style.height=Math.min(t.scrollHeight,160)+`px`)},[]),ee=(0,J.useCallback)(e=>{let t=e.clipboardData?.items;if(!t)return;let n=[];for(let e of t)if(e.kind===`file`){let t=e.getAsFile();t&&n.push(t)}n.length>0&&(e.preventDefault(),M(n))},[M]),z=(0,J.useCallback)(e=>{e.preventDefault();let t=Array.from(e.dataTransfer.files);t.length>0&&M(t)},[M]),B=(0,J.useCallback)(e=>{e.preventDefault()},[]),te=(0,J.useCallback)(()=>{O.current?.click()},[]),V=(0,J.useCallback)(e=>{let t=Array.from(e.target.files??[]);t.length>0&&M(t),e.target.value=``},[M]),H=_.trim().length>0||S.some(e=>e.status===`ready`),U=t&&!H;return(0,X.jsxs)(`div`,{className:`p-2 md:p-3 bg-background`,children:[(0,X.jsxs)(`div`,{className:`border border-border rounded-xl md:rounded-2xl bg-surface shadow-sm cursor-text`,onClick:e=>{r||e.target instanceof HTMLTextAreaElement||(window.matchMedia(`(min-width: 768px)`).matches?E.current:D.current)?.focus()},children:[(0,X.jsx)(en,{attachments:S,onRemove:N}),(0,X.jsxs)(`div`,{className:`flex items-center gap-1 px-2 pt-2 md:hidden relative`,children:[(0,X.jsx)(cn,{mode:h??`bypassPermissions`,onClick:()=>T(e=>!e)}),(0,X.jsx)(rn,{value:h??`bypassPermissions`,onChange:e=>g?.(e),open:w,onOpenChange:T})]}),(0,X.jsxs)(`div`,{className:`flex items-end gap-1 md:hidden px-2 py-2`,children:[(0,X.jsx)(`button`,{type:`button`,onClick:e=>{e.stopPropagation(),te()},disabled:r,className:`flex items-center justify-center size-7 shrink-0 rounded-full text-text-subtle hover:text-text-primary transition-colors disabled:opacity-50`,"aria-label":`Attach file`,children:(0,X.jsx)(ke,{className:`size-4`})}),(0,X.jsx)(`textarea`,{ref:D,value:_,onChange:e=>{L(e.target.value,e.target.selectionStart),R(e)},onKeyDown:F,onPaste:ee,onDrop:z,onDragOver:B,placeholder:t?`Follow-up...`:`Ask anything...`,disabled:r,rows:1,className:`flex-1 resize-none bg-transparent py-1.5 text-sm text-foreground placeholder:text-text-subtle focus:outline-none disabled:opacity-50 max-h-20`}),U?(0,X.jsx)(`button`,{onClick:e=>{e.stopPropagation(),n?.()},className:`flex items-center justify-center size-7 shrink-0 rounded-full bg-red-600 text-white hover:bg-red-500 transition-colors`,"aria-label":`Stop`,children:(0,X.jsx)(Pe,{className:`size-3`})}):(0,X.jsx)(`button`,{onClick:e=>{e.stopPropagation(),P()},disabled:r||!H,className:`flex items-center justify-center size-7 shrink-0 rounded-full bg-primary text-primary-foreground hover:bg-primary/90 disabled:opacity-30 transition-colors`,"aria-label":`Send`,children:(0,X.jsx)(xe,{className:`size-3.5`})})]}),(0,X.jsxs)(`div`,{className:`hidden md:block`,children:[(0,X.jsx)(`textarea`,{ref:E,value:_,onChange:e=>{L(e.target.value,e.target.selectionStart),R(e)},onKeyDown:F,onPaste:ee,onDrop:z,onDragOver:B,placeholder:t?`Follow-up or Stop...`:`Ask anything...`,disabled:r,rows:1,className:`w-full resize-none bg-transparent px-4 pt-3 pb-1 text-sm text-foreground placeholder:text-text-subtle focus:outline-none disabled:opacity-50 max-h-40`}),(0,X.jsxs)(`div`,{className:`flex items-center justify-between px-3 pb-2`,children:[(0,X.jsxs)(`div`,{className:`flex items-center gap-1`,children:[(0,X.jsx)(`button`,{type:`button`,onClick:e=>{e.stopPropagation(),te()},disabled:r,className:`flex items-center justify-center size-8 rounded-full text-text-subtle hover:text-text-primary hover:bg-surface-elevated transition-colors disabled:opacity-50`,"aria-label":`Attach file`,children:(0,X.jsx)(ke,{className:`size-4`})}),(0,X.jsxs)(`div`,{className:`relative`,children:[(0,X.jsx)(cn,{mode:h??`bypassPermissions`,onClick:()=>T(e=>!e)}),(0,X.jsx)(rn,{value:h??`bypassPermissions`,onChange:e=>g?.(e),open:w,onOpenChange:T})]})]}),(0,X.jsx)(`div`,{className:`flex items-center gap-1`,children:U?(0,X.jsx)(`button`,{onClick:e=>{e.stopPropagation(),n?.()},className:`flex items-center justify-center size-8 rounded-full bg-red-600 text-white hover:bg-red-500 transition-colors`,"aria-label":`Stop response`,children:(0,X.jsx)(Pe,{className:`size-3.5`})}):(0,X.jsx)(`button`,{onClick:e=>{e.stopPropagation(),P()},disabled:r||!H,className:`flex items-center justify-center size-8 rounded-full bg-primary text-primary-foreground hover:bg-primary/90 disabled:opacity-30 disabled:cursor-not-allowed transition-colors`,"aria-label":`Send message`,children:(0,X.jsx)(xe,{className:`size-4`})})})]})]})]}),(0,X.jsx)(`input`,{ref:O,type:`file`,multiple:!0,className:`hidden`,onChange:V})]})});function cn({mode:e,onClick:t}){let n=nn(e),r=tn(e);return(0,X.jsxs)(`button`,{type:`button`,onClick:e=>{e.stopPropagation(),t()},className:`inline-flex items-center gap-1 px-2 py-1 rounded-md text-[11px] text-text-subtle hover:text-text-primary hover:bg-surface-elevated transition-colors border border-transparent hover:border-border`,"aria-label":`Permission mode: ${r}`,children:[(0,X.jsx)(n,{className:`size-3`}),(0,X.jsx)(`span`,{className:`max-w-[100px] truncate`,children:r})]})}function ln({items:e,filter:t,onSelect:n,onClose:r,visible:i}){let[a,o]=(0,J.useState)(0),s=(0,J.useRef)(null),c=e.filter(e=>{let n=t.toLowerCase();return e.name.toLowerCase().includes(n)||e.description.toLowerCase().includes(n)});(0,J.useEffect)(()=>{o(0)},[t]),(0,J.useEffect)(()=>{let e=s.current;e&&e.children[a]?.scrollIntoView({block:`nearest`})},[a]);let l=(0,J.useCallback)(e=>{if(!i||c.length===0)return!1;switch(e.key){case`ArrowUp`:return e.preventDefault(),o(e=>e>0?e-1:c.length-1),!0;case`ArrowDown`:return e.preventDefault(),o(e=>e<c.length-1?e+1:0),!0;case`Enter`:case`Tab`:return e.preventDefault(),c[a]&&n(c[a]),!0;case`Escape`:return e.preventDefault(),r(),!0}return!1},[i,c,a,n,r]);return(0,J.useEffect)(()=>{if(!i)return;let e=e=>{l(e)&&e.stopPropagation()};return document.addEventListener(`keydown`,e,!0),()=>document.removeEventListener(`keydown`,e,!0)},[i,l]),!i||c.length===0?null:(0,X.jsx)(`div`,{className:`max-h-52 overflow-y-auto border-b border-border bg-surface`,children:(0,X.jsx)(`div`,{ref:s,className:`py-1`,children:c.map((e,t)=>(0,X.jsxs)(`button`,{className:`flex items-start gap-3 w-full px-3 py-2 text-left transition-colors ${t===a?`bg-primary/10 text-primary`:`hover:bg-surface-hover text-text-primary`}`,onMouseEnter:()=>o(t),onClick:()=>n(e),children:[(0,X.jsx)(`span`,{className:`shrink-0 mt-0.5`,children:e.type===`skill`?(0,X.jsx)(Ne,{className:`size-4 text-amber-500`}):(0,X.jsx)(j,{className:`size-4 text-blue-500`})}),(0,X.jsxs)(`div`,{className:`min-w-0 flex-1`,children:[(0,X.jsxs)(`div`,{className:`flex items-baseline gap-2`,children:[(0,X.jsxs)(`span`,{className:`font-medium text-sm`,children:[`/`,e.name]}),e.argumentHint&&(0,X.jsx)(`span`,{className:`text-xs text-text-subtle`,children:e.argumentHint}),(0,X.jsx)(`span`,{className:`text-xs text-text-subtle capitalize ml-auto`,children:e.scope===`user`?`global`:e.type})]}),e.description&&(0,X.jsx)(`p`,{className:`text-xs text-text-subtle mt-0.5 line-clamp-2`,children:e.description})]})]},`${e.type}-${e.name}`))})})}var un=`ppm-hienlh`;function dn({open:e,onOpenChange:t,onSuccess:n}){let[r,i]=(0,J.useState)(``),[a,o]=(0,J.useState)(``),[s,c]=(0,J.useState)(!1),[l,u]=(0,J.useState)(null),[p,m]=(0,J.useState)(null),[h,g]=(0,J.useState)(``),[_,v]=(0,J.useState)(!1),[y,b]=(0,J.useState)(`idle`);function x(){m(null),g(``),b(`idle`),u(null)}function C(){t(!1),x(),i(``),o(``),u(null)}async function w(){v(!0),u(null);try{let{url:e,state:t}=await S();m(t),b(`waiting`),window.open(e,`_blank`)}catch(e){u(e.message)}v(!1)}async function T(){if(!(!h.trim()||!p)){v(!0),u(null);try{let e=h.trim();e.includes(`#`)&&(e=e.split(`#`)[0]??e),await E(e,p),C(),n(`Account connected via OAuth!`)}catch(e){u(e.message)}v(!1)}}async function D(){if(r.trim()){c(!0),u(null);try{await O({apiKey:r.trim(),label:a.trim()||void 0}),C(),n(`Account added!`)}catch(e){u(e.message)}c(!1)}}let k=r.trim()?r.trim().startsWith(`sk-ant-oat`)?`OAuth token (Claude Max/Pro)`:r.trim().startsWith(`sk-ant-api`)?`API key`:`Unknown format`:``;return(0,X.jsx)(se,{open:e,onOpenChange:e=>{e||C()},children:(0,X.jsxs)(de,{className:`sm:max-w-md`,children:[(0,X.jsxs)(W,{children:[(0,X.jsx)(G,{className:`text-sm`,children:`Add Claude Account`}),(0,X.jsx)(ve,{className:`text-xs leading-relaxed`,children:`Connect via OAuth (recommended) or paste a token manually.`})]}),(0,X.jsxs)(`div`,{className:`space-y-3`,children:[(0,X.jsxs)(`div`,{className:`rounded-md border p-3 space-y-2`,children:[(0,X.jsx)(`p`,{className:`text-[11px] font-medium`,children:`Recommended: Login with Claude`}),y===`idle`?(0,X.jsx)(d,{size:`sm`,className:`w-full h-8 text-xs`,onClick:w,disabled:_,children:_?(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(q,{className:`size-3 animate-spin mr-1`}),` Opening...`]}):`Login with Claude`}):(0,X.jsxs)(`div`,{className:`space-y-2`,children:[(0,X.jsx)(`p`,{className:`text-[10px] text-muted-foreground`,children:`Authorize in the opened tab, then paste the code:`}),(0,X.jsx)(f,{placeholder:`Paste code here...`,value:h,onChange:e=>g(e.target.value),className:`text-xs h-8 font-mono`,autoFocus:!0}),(0,X.jsxs)(`div`,{className:`flex gap-1.5`,children:[(0,X.jsx)(d,{size:`sm`,className:`flex-1 h-7 text-xs`,onClick:T,disabled:!h.trim()||_,children:_?(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(q,{className:`size-3 animate-spin mr-1`}),` Connecting...`]}):`Connect`}),(0,X.jsx)(d,{size:`sm`,variant:`ghost`,className:`h-7 text-xs`,onClick:x,children:`Cancel`})]})]})]}),(0,X.jsxs)(`div`,{className:`flex items-center gap-2`,children:[(0,X.jsx)(`div`,{className:`flex-1 border-t`}),(0,X.jsx)(`span`,{className:`text-[10px] text-muted-foreground`,children:`or paste token`}),(0,X.jsx)(`div`,{className:`flex-1 border-t`})]}),(0,X.jsxs)(`div`,{className:`space-y-1.5`,children:[(0,X.jsx)(_e,{htmlFor:`add-token`,className:`text-xs`,children:`Token`}),(0,X.jsx)(f,{id:`add-token`,type:`password`,placeholder:`sk-ant-...`,value:r,onChange:e=>i(e.target.value),className:`text-xs h-8 font-mono`}),k&&(0,X.jsxs)(`p`,{className:`text-[10px] text-muted-foreground`,children:[`Detected: `,k]})]}),(0,X.jsxs)(`div`,{className:`space-y-1.5`,children:[(0,X.jsx)(_e,{htmlFor:`add-label`,className:`text-xs`,children:`Label (optional)`}),(0,X.jsx)(f,{id:`add-label`,placeholder:`e.g. Personal, Work`,value:a,onChange:e=>o(e.target.value),className:`text-xs h-8`})]})]}),l&&(0,X.jsx)(`div`,{className:`text-[11px] p-2 rounded bg-red-500/10 text-red-600`,children:l}),(0,X.jsxs)(ce,{children:[(0,X.jsx)(d,{size:`sm`,variant:`outline`,className:`text-xs h-7`,onClick:C,children:`Cancel`}),(0,X.jsx)(d,{size:`sm`,className:`text-xs h-7`,onClick:D,disabled:!r.trim()||s,children:s?`Adding...`:`Add Token`})]})]})})}function fn({open:e,onOpenChange:t,accounts:n,preselectId:r,onMessage:i}){let a=n.filter(e=>e.hasRefreshToken),[o,s]=(0,J.useState)(new Set),[c,l]=(0,J.useState)(``),[u,p]=(0,J.useState)(!1),[m,h]=(0,J.useState)(!1),[g,_]=(0,J.useState)(!1),[v,b]=(0,J.useState)(!1);e&&!v&&(s(r?new Set([r]):new Set(a.map(e=>e.id))),b(!0)),!e&&v&&b(!1);function x(){t(!1),l(``),p(!1),h(!1)}async function S(e){if(o.size===0)return;_(!0);let t=c.trim()||un;try{let n={"Content-Type":`application/json`},r=y();r&&(n.Authorization=`Bearer ${r}`);let a=await fetch(`/api/accounts/export`,{method:`POST`,headers:n,body:JSON.stringify({password:t,accountIds:[...o],includeRefreshToken:u,refreshBeforeExport:m})});if(!a.ok){let e=await a.json();throw Error(e.error??`Export failed: ${a.status}`)}let s=await a.text();if(e)try{await navigator.clipboard.writeText(s),i?.(`Backup copied to clipboard!`)}catch{mn(s),i?.(`Backup downloaded.`)}else mn(s),i?.(`Backup downloaded.`);x()}catch{}_(!1)}let C=o.size>0&&!g;return(0,X.jsx)(se,{open:e,onOpenChange:e=>{e||x()},children:(0,X.jsxs)(de,{className:`sm:max-w-md`,children:[(0,X.jsxs)(W,{children:[(0,X.jsxs)(G,{className:`text-sm flex items-center gap-1.5`,children:[(0,X.jsx)(U,{className:`size-3.5`}),` Export Accounts`]}),(0,X.jsx)(ve,{className:`text-xs`,children:`Select accounts and set a password to protect the backup.`})]}),(0,X.jsxs)(`div`,{className:`space-y-3`,children:[(0,X.jsxs)(`div`,{className:`space-y-1`,children:[(0,X.jsxs)(`div`,{className:`flex items-center justify-between mb-1`,children:[(0,X.jsx)(`p`,{className:`text-[11px] font-medium text-muted-foreground`,children:`Accounts to export`}),(0,X.jsx)(`button`,{className:`text-[10px] text-primary hover:underline cursor-pointer`,onClick:()=>s(o.size===a.length?new Set:new Set(a.map(e=>e.id))),children:o.size===a.length?`Deselect all`:`Select all`})]}),a.length===0?(0,X.jsx)(`p`,{className:`text-[10px] text-muted-foreground p-2 border rounded`,children:`No exportable accounts.`}):(0,X.jsx)(`div`,{className:`max-h-36 overflow-y-auto space-y-1 border rounded p-2`,children:a.map(e=>(0,X.jsxs)(`div`,{className:`flex items-center gap-2`,children:[(0,X.jsx)(`input`,{type:`checkbox`,id:`exp-${e.id}`,checked:o.has(e.id),onChange:t=>{let n=new Set(o);t.target.checked?n.add(e.id):n.delete(e.id),s(n)},className:`size-3.5 accent-primary cursor-pointer`}),(0,X.jsx)(`label`,{htmlFor:`exp-${e.id}`,className:`text-xs cursor-pointer truncate`,children:e.label??e.email??e.id.slice(0,8)})]},e.id))})]}),(0,X.jsxs)(`div`,{className:`space-y-1.5`,children:[(0,X.jsxs)(_e,{className:`text-xs`,children:[`Password `,(0,X.jsx)(`span`,{className:`text-muted-foreground font-normal`,children:`(optional)`})]}),(0,X.jsx)(f,{type:`password`,placeholder:`Leave empty for default`,value:c,onChange:e=>l(e.target.value),className:`text-xs h-8`,autoComplete:`new-password`})]}),(0,X.jsxs)(`div`,{className:`flex items-center gap-2`,children:[(0,X.jsx)(`input`,{type:`checkbox`,id:`exp-full`,checked:u,onChange:e=>p(e.target.checked),className:`size-3.5 accent-primary cursor-pointer`}),(0,X.jsx)(`label`,{htmlFor:`exp-full`,className:`text-[11px] cursor-pointer`,children:`Include refresh tokens (full transfer)`})]}),(0,X.jsxs)(`div`,{className:`flex items-center gap-2`,children:[(0,X.jsx)(`input`,{type:`checkbox`,id:`exp-refresh`,checked:m,onChange:e=>h(e.target.checked),className:`size-3.5 accent-primary cursor-pointer`}),(0,X.jsx)(`label`,{htmlFor:`exp-refresh`,className:`text-[11px] cursor-pointer`,children:`Refresh tokens before export`})]}),u?(0,X.jsxs)(`div`,{className:`rounded-md border border-red-500/30 bg-red-500/5 p-2.5`,children:[(0,X.jsx)(`p`,{className:`text-[10px] font-medium text-red-600`,children:`Full transfer — source accounts will expire`}),(0,X.jsx)(`p`,{className:`text-[10px] text-muted-foreground`,children:`Refresh tokens included. Source machine expires in ~1h after target refreshes.`})]}):m?(0,X.jsx)(`div`,{className:`rounded-md border border-amber-500/30 bg-amber-500/5 p-2.5`,children:(0,X.jsx)(`p`,{className:`text-[10px] font-medium text-amber-600`,children:`Refresh before export — invalidates previous shares`})}):(0,X.jsx)(`div`,{className:`rounded-md border border-green-500/30 bg-green-500/5 p-2.5`,children:(0,X.jsx)(`p`,{className:`text-[10px] font-medium text-green-600`,children:`Share current token (safe)`})}),(0,X.jsx)(`p`,{className:`text-[10px] text-muted-foreground`,children:`Encrypted with AES-256-GCM + scrypt.`})]}),(0,X.jsxs)(ce,{className:`gap-1.5 flex-col sm:flex-row`,children:[(0,X.jsx)(d,{size:`sm`,variant:`outline`,className:`text-xs h-7 cursor-pointer`,onClick:x,children:`Cancel`}),(0,X.jsxs)(d,{size:`sm`,variant:`outline`,className:`text-xs h-7 cursor-pointer`,disabled:!C,onClick:()=>S(!0),children:[(0,X.jsx)(ie,{className:`size-3 mr-1`}),` Copy`]}),(0,X.jsx)(d,{size:`sm`,className:`text-xs h-7 cursor-pointer`,disabled:!C,onClick:()=>S(!1),children:g?(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(q,{className:`size-3 animate-spin mr-1`}),` Exporting...`]}):(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(L,{className:`size-3 mr-1`}),` Download`]})})]})]})})}function pn({open:e,onOpenChange:t,onSuccess:n}){let[r,i]=(0,J.useState)(``),[a,o]=(0,J.useState)(``),[s,c]=(0,J.useState)(!1),[l,u]=(0,J.useState)(null);function p(){t(!1),i(``),o(``),u(null)}async function m(){if(r.trim()){c(!0),u(null);try{let e=await k({data:r.trim(),password:a.trim()||un});p(),n(`Imported ${e.imported} account(s)`)}catch(e){u(e.message||`Import failed`)}c(!1)}}return(0,X.jsx)(se,{open:e,onOpenChange:e=>{e||p()},children:(0,X.jsxs)(de,{className:`sm:max-w-md`,children:[(0,X.jsxs)(W,{children:[(0,X.jsxs)(G,{className:`text-sm flex items-center gap-1.5`,children:[(0,X.jsx)(U,{className:`size-3.5`}),` Import Accounts`]}),(0,X.jsx)(ve,{className:`text-xs`,children:`Paste backup data and enter the export password. Imported accounts are temporary (~1h).`})]}),(0,X.jsxs)(`div`,{className:`space-y-3`,children:[(0,X.jsxs)(`div`,{className:`space-y-1.5`,children:[(0,X.jsx)(_e,{className:`text-xs`,children:`Backup data`}),(0,X.jsx)(`textarea`,{value:r,onChange:e=>i(e.target.value),placeholder:`Paste backup JSON here...`,rows:4,className:`w-full text-xs p-2 rounded border border-border bg-background font-mono resize-none focus:outline-none focus:ring-1 focus:ring-primary`})]}),(0,X.jsxs)(`div`,{className:`space-y-1.5`,children:[(0,X.jsxs)(_e,{className:`text-xs`,children:[`Password `,(0,X.jsx)(`span`,{className:`text-muted-foreground font-normal`,children:`(optional)`})]}),(0,X.jsx)(f,{type:`password`,placeholder:`Leave empty for default`,value:a,onChange:e=>o(e.target.value),className:`text-xs h-8`,autoComplete:`current-password`})]})]}),l&&(0,X.jsx)(`div`,{className:`text-[11px] p-2 rounded bg-red-500/10 text-red-600`,children:l}),(0,X.jsxs)(ce,{children:[(0,X.jsx)(d,{size:`sm`,variant:`outline`,className:`text-xs h-7 cursor-pointer`,onClick:p,children:`Cancel`}),(0,X.jsx)(d,{size:`sm`,className:`text-xs h-7 cursor-pointer`,disabled:!r.trim()||s,onClick:m,children:s?(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(q,{className:`size-3 animate-spin mr-1`}),` Importing...`]}):`Import`})]})]})})}function mn(e){let t=new Blob([e],{type:`application/json`}),n=document.createElement(`a`);n.href=URL.createObjectURL(t),n.download=`ppm-accounts-backup.json`,n.click(),URL.revokeObjectURL(n.href)}function hn(e){return e>=90?`text-red-500`:e>=70?`text-amber-500`:`text-green-500`}function gn(e){return e>=90?`bg-red-500`:e>=70?`bg-amber-500`:`bg-green-500`}function _n(e){if(!e)return null;let t=null;if(e.resetsInMinutes!=null)t=e.resetsInMinutes;else if(e.resetsInHours!=null)t=Math.round(e.resetsInHours*60);else if(e.resetsAt){let n=new Date(e.resetsAt).getTime()-Date.now();t=n>0?Math.ceil(n/6e4):0}if(t==null)return null;if(t<=0)return`now`;let n=Math.floor(t/1440),r=Math.floor(t%1440/60),i=t%60;return n>0?i>0?`${n}d ${r}h ${i}m`:r>0?`${n}d ${r}h`:`${n}d`:r>0?i>0?`${r}h ${i}m`:`${r}h`:`${i}m`}function $({label:e,bucket:t}){if(!t)return null;let n=Math.round(t.utilization*100),r=_n(t);return(0,X.jsxs)(`div`,{className:`space-y-1`,children:[(0,X.jsxs)(`div`,{className:`flex items-center justify-between`,children:[(0,X.jsx)(`span`,{className:`text-xs font-medium text-text-primary`,children:e}),r&&(0,X.jsxs)(`span`,{className:`text-[10px] text-text-subtle`,title:`Resets in`,children:[`↻ `,r]})]}),(0,X.jsxs)(`div`,{className:`flex items-center gap-2`,children:[(0,X.jsx)(`div`,{className:`flex-1 h-2 rounded-full bg-border overflow-hidden`,children:(0,X.jsx)(`div`,{className:`h-full rounded-full transition-all ${gn(n)}`,style:{width:`${Math.min(n,100)}%`}})}),(0,X.jsxs)(`span`,{className:`text-xs font-medium tabular-nums w-10 text-right ${hn(n)}`,children:[n,`%`]})]})]})}function vn(e){let t=e-Date.now();if(t<=0)return`expired`;let n=Math.ceil(t/6e4),r=Math.floor(n/60),i=Math.floor(r/24);return i>0?`${i}d ${r%24}h`:r>0?`${r}h ${n%60}m`:`${n}m`}function yn(e){if(!e)return{label:`unknown`,tip:`No account info available`,color:`text-text-subtle`};if(!e.expiresAt)return{label:`key`,tip:`API key (no expiry)`,color:`text-text-subtle`};let t=e.expiresAt*1e3<Date.now();return t&&e.hasRefreshToken?{label:`expired`,tip:`Token expired but has refresh token — will auto-renew`,color:`text-amber-500`}:t?{label:`expired`,tip:`Token expired, no refresh token`,color:`text-red-500`}:e.hasRefreshToken?{label:`long-lived`,tip:`OAuth token with refresh — long-lived`,color:`text-green-500`}:{label:`temp`,tip:`Temporary token without refresh — will expire`,color:`text-amber-500`}}function bn(e){if(!e)return null;let t=Math.round((Date.now()-e)/1e3);if(t<5)return`just now`;if(t<60)return`${t}s ago`;let n=Math.floor(t/60);if(n<60)return`${n}m ago`;let r=Math.floor(n/60),i=n%60;return r<24?i>0?`${r}h ${i}m ago`:`${r}h ago`:`${Math.floor(r/24)}d ago`}function xn({entry:e,isActive:t,accountInfo:n,onToggle:r,onExport:i,onViewProfile:a,flash:o}){let{usage:s}=e,c=s.session||s.weekly||s.weeklyOpus||s.weeklySonnet,l=n?.status??e.accountStatus;return(0,X.jsxs)(`div`,{className:`rounded-md border p-2 space-y-1.5 transition-colors duration-500 min-w-[200px] shrink-0 snap-start ${o?`bg-primary/10 border-primary/40`:``} ${t?`border-primary/30 bg-primary/5`:`border-border/50`}`,children:[(0,X.jsxs)(`div`,{className:`flex items-center gap-1.5`,children:[(0,X.jsx)(`span`,{className:`text-xs font-medium truncate flex-1 min-w-0`,children:e.accountLabel??e.accountId.slice(0,8)}),!e.isOAuth&&(0,X.jsx)(`span`,{className:`text-[9px] text-text-subtle shrink-0`,children:`API key`}),(0,X.jsxs)(`div`,{className:`flex items-center gap-0.5 shrink-0`,children:[a&&n?.profileData&&(0,X.jsx)(`button`,{className:`p-1 rounded cursor-pointer text-text-subtle hover:text-foreground hover:bg-surface-elevated transition-colors`,onClick:()=>a(n.profileData),title:`View profile`,children:(0,X.jsx)(R,{className:`size-3`})}),i&&e.isOAuth&&(0,X.jsx)(`button`,{className:`p-1 rounded cursor-pointer text-text-subtle hover:text-blue-500 hover:bg-surface-elevated transition-colors`,onClick:()=>i(e.accountId),title:`Export this account`,children:(0,X.jsx)(L,{className:`size-3`})}),r&&(0,X.jsx)(ae,{checked:l!==`disabled`,onCheckedChange:()=>r(e.accountId,l),disabled:l===`cooldown`,className:`scale-[0.6] cursor-pointer`})]})]}),c?(0,X.jsxs)(`div`,{className:`space-y-1.5`,children:[(0,X.jsx)($,{label:`5-Hour Session`,bucket:s.session}),(0,X.jsx)($,{label:`Weekly`,bucket:s.weekly}),(0,X.jsx)($,{label:`Weekly (Opus)`,bucket:s.weeklyOpus}),(0,X.jsx)($,{label:`Weekly (Sonnet)`,bucket:s.weeklySonnet})]}):(0,X.jsx)(`p`,{className:`text-[10px] text-text-subtle`,children:e.isOAuth?`No usage data yet`:`Usage tracking not available for API keys`}),(()=>{let e=yn(n);return(0,X.jsxs)(`div`,{className:`flex items-center gap-1.5 text-[9px] text-text-subtle flex-wrap`,children:[s.lastFetchedAt&&(0,X.jsxs)(`span`,{title:`Last usage data update`,children:[`↻ `,bn(new Date(s.lastFetchedAt).getTime())]}),n?.expiresAt&&n.expiresAt*1e3>Date.now()&&(0,X.jsxs)(`span`,{title:`Token expires in`,children:[`⏱ `,vn(n.expiresAt*1e3)]}),(0,X.jsxs)(`span`,{className:e.color,title:e.tip,children:[`© `,e.label]})]})})()]})}function Sn({usage:e,visible:t,onClose:n,onReload:r,loading:i,lastFetchedAt:a}){let[o,s]=(0,J.useState)([]),[c,l]=(0,J.useState)([]),[u,d]=(0,J.useState)(null),[f,p]=(0,J.useState)(!0),[m,h]=(0,J.useState)(!1),[g,_]=(0,J.useState)(new Set),[v,y]=(0,J.useState)(null),[b,S]=(0,J.useState)(!1),[w,E]=(0,J.useState)(!1),[O,k]=(0,J.useState)(!1),[A,j]=(0,J.useState)(null),[M,P]=(0,J.useState)(null),F=(0,J.useRef)(void 0),I=(0,J.useRef)([]);function R(e){F.current&&clearTimeout(F.current),P(e),F.current=setTimeout(()=>P(null),4e3)}function ee(e){z(),e&&R(e)}async function z(){let e=o.length>0;e?h(!0):p(!0);let[t,n,r]=await Promise.allSettled([D(),x(),T()]);if(t.status===`fulfilled`){let n=t.value;if(e&&I.current.length>0){let e=new Set,t=new Map(I.current.map(e=>[e.accountId,e]));for(let r of n){let n=t.get(r.accountId);if(!n){e.add(r.accountId);continue}let i=n.usage,a=r.usage;(i.session?.utilization!==a.session?.utilization||i.weekly?.utilization!==a.weekly?.utilization||i.weeklyOpus?.utilization!==a.weeklyOpus?.utilization||i.weeklySonnet?.utilization!==a.weeklySonnet?.utilization)&&e.add(r.accountId)}e.size>0&&(_(e),setTimeout(()=>_(new Set),1500))}I.current=n,s(n)}n.status===`fulfilled`&&l(n.value),r.status===`fulfilled`&&d(r.value?.id??null),p(!1),h(!1)}if((0,J.useEffect)(()=>{t&&z()},[t]),(0,J.useEffect)(()=>{!t||!a||z()},[a]),!t)return null;let H=new Map(c.map(e=>[e.id,e])),U=e.queryCostUsd!=null||e.totalCostUsd!=null,ne=o.length>0;async function re(e,t){await C(e,{status:t===`disabled`?`active`:`disabled`}),z(),r?.()}function ie(){j(null),E(!0)}return(0,X.jsxs)(`div`,{className:`border-b border-border bg-surface px-3 py-2.5 space-y-2.5 max-h-[350px] overflow-y-auto`,children:[(0,X.jsxs)(`div`,{className:`flex items-center justify-between`,children:[(0,X.jsxs)(`div`,{className:`flex items-center gap-2`,children:[(0,X.jsx)(`span`,{className:`text-xs font-semibold text-text-primary`,children:`Usage & Accounts`}),a&&(0,X.jsx)(`span`,{className:`text-[10px] text-text-subtle`,children:bn(new Date(a).getTime())})]}),(0,X.jsxs)(`div`,{className:`flex items-center gap-1`,children:[r&&(0,X.jsx)(`button`,{onClick:()=>{r(),z()},disabled:i||m,className:`text-xs text-text-subtle hover:text-text-primary px-1 disabled:opacity-50 cursor-pointer`,title:`Refresh`,children:(0,X.jsx)(B,{className:`size-3 ${i||m?`animate-spin`:``}`})}),(0,X.jsx)(`button`,{onClick:n,className:`text-xs text-text-subtle hover:text-text-primary px-1 cursor-pointer`,children:(0,X.jsx)(N,{className:`size-3`})})]})]}),M&&(0,X.jsx)(`div`,{className:`text-[11px] p-1.5 rounded bg-green-500/10 text-green-600 text-center animate-in fade-in duration-200`,children:M}),ne||f?(0,X.jsx)(`div`,{className:`flex gap-1.5 overflow-x-auto pb-1 -mx-3 px-3 snap-x snap-mandatory scrollbar-thin`,children:f?(0,X.jsx)(`p`,{className:`text-[10px] text-text-subtle`,children:`Loading...`}):o.map(t=>(0,X.jsx)(xn,{entry:t,isActive:t.accountId===(u??e.activeAccountId),accountInfo:H.get(t.accountId),onToggle:re,onExport:e=>{j(e),E(!0)},onViewProfile:y,flash:g.has(t.accountId)},t.accountId))}):(0,X.jsx)(X.Fragment,{children:e.session||e.weekly||e.weeklyOpus||e.weeklySonnet?(0,X.jsxs)(`div`,{className:`space-y-2.5`,children:[(0,X.jsx)($,{label:`5-Hour Session`,bucket:e.session}),(0,X.jsx)($,{label:`Weekly`,bucket:e.weekly}),(0,X.jsx)($,{label:`Weekly (Opus)`,bucket:e.weeklyOpus}),(0,X.jsx)($,{label:`Weekly (Sonnet)`,bucket:e.weeklySonnet})]}):(0,X.jsx)(`p`,{className:`text-xs text-text-subtle`,children:`No usage data available`})}),U&&(0,X.jsxs)(`div`,{className:`border-t border-border pt-2 space-y-1`,children:[e.queryCostUsd!=null&&(0,X.jsxs)(`div`,{className:`flex items-center justify-between text-xs`,children:[(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`Last query`}),(0,X.jsxs)(`span`,{className:`text-text-primary font-medium tabular-nums`,children:[`$`,e.queryCostUsd.toFixed(4)]})]}),e.totalCostUsd!=null&&(0,X.jsxs)(`div`,{className:`flex items-center justify-between text-xs`,children:[(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`Session total`}),(0,X.jsxs)(`span`,{className:`text-text-primary font-medium tabular-nums`,children:[`$`,e.totalCostUsd.toFixed(4)]})]})]}),v&&(0,X.jsxs)(`div`,{className:`border-t border-border pt-2`,children:[(0,X.jsxs)(`div`,{className:`flex items-center justify-between mb-1`,children:[(0,X.jsx)(`span`,{className:`text-[10px] font-medium text-text-subtle`,children:`Profile`}),(0,X.jsx)(`button`,{className:`text-text-subtle hover:text-foreground cursor-pointer`,onClick:()=>y(null),children:(0,X.jsx)(N,{className:`size-3`})})]}),(0,X.jsxs)(`div`,{className:`grid grid-cols-[70px_1fr] gap-x-2 gap-y-0.5 text-[10px]`,children:[v.account?.display_name&&(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`Name`}),(0,X.jsx)(`span`,{children:v.account.display_name})]}),v.account?.email&&(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`Email`}),(0,X.jsx)(`span`,{children:v.account.email})]}),v.organization?.name&&(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`Org`}),(0,X.jsx)(`span`,{children:v.organization.name})]}),v.organization?.organization_type&&(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`Type`}),(0,X.jsx)(`span`,{children:v.organization.organization_type})]}),v.organization?.rate_limit_tier&&(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`Tier`}),(0,X.jsx)(`span`,{children:v.organization.rate_limit_tier})]}),v.organization?.subscription_status&&(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`Status`}),(0,X.jsx)(`span`,{children:v.organization.subscription_status})]})]})]}),(0,X.jsxs)(`div`,{className:`border-t border-border pt-2 flex gap-1.5`,children:[(0,X.jsxs)(`button`,{onClick:()=>S(!0),className:`flex-1 flex items-center justify-center gap-1 rounded-md border border-border px-2 py-1 text-[11px] text-text-secondary hover:bg-surface-hover transition-colors cursor-pointer`,children:[(0,X.jsx)(V,{className:`size-3`}),` Add`]}),(0,X.jsxs)(`button`,{onClick:ie,className:`flex-1 flex items-center justify-center gap-1 rounded-md border border-border px-2 py-1 text-[11px] text-text-secondary hover:bg-surface-hover transition-colors cursor-pointer`,children:[(0,X.jsx)(L,{className:`size-3`}),` Export`]}),(0,X.jsxs)(`button`,{onClick:()=>k(!0),className:`flex-1 flex items-center justify-center gap-1 rounded-md border border-border px-2 py-1 text-[11px] text-text-secondary hover:bg-surface-hover transition-colors cursor-pointer`,children:[(0,X.jsx)(te,{className:`size-3`}),` Import`]})]}),(0,X.jsx)(dn,{open:b,onOpenChange:S,onSuccess:ee}),(0,X.jsx)(fn,{open:w,onOpenChange:e=>{E(e),e||j(null)},accounts:c,preselectId:A,onMessage:R}),(0,X.jsx)(pn,{open:O,onOpenChange:k,onSuccess:ee})]})}function Cn(e){try{return new Date(e).toLocaleDateString(void 0,{month:`short`,day:`numeric`})}catch{return``}}function wn(e){return e>=90?`text-red-500`:e>=70?`text-amber-500`:`text-green-500`}function Tn({projectName:e,usageInfo:t,contextWindowPct:r,usageLoading:i,refreshUsage:a,lastFetchedAt:o,sessionId:s,onSelectSession:c,onBugReport:l,isConnected:u,onReconnect:d}){let[f,p]=(0,J.useState)(null),[m,h]=(0,J.useState)([]),[g,y]=(0,J.useState)(!1),x=oe(e=>s?e.notifications.has(s):!1),S=oe(e=>e.clearForSession),[C,w]=(0,J.useState)(``),[T,E]=(0,J.useState)(null),[D,O]=(0,J.useState)(``),k=(0,J.useRef)(null),A=_(e=>e.openTab),j=e=>{p(t=>t===e?null:e)},M=(0,J.useCallback)(async()=>{if(e){y(!0);try{h(await b.get(`${v(e)}/chat/sessions`))}catch{}finally{y(!1)}}},[e]);(0,J.useEffect)(()=>{f===`history`&&m.length===0&&M()},[f]);function P(t){c?(c(t),p(null)):A({type:`chat`,title:t.title||`Chat`,projectId:e??null,metadata:{projectName:e,sessionId:t.id},closable:!0})}let I=(0,J.useCallback)((e,t)=>{t.stopPropagation(),E(e.id),O(e.title||``),setTimeout(()=>k.current?.select(),0)},[]),L=(0,J.useCallback)(async()=>{if(!T||!D.trim()||!e){E(null);return}try{await b.patch(`${v(e)}/chat/sessions/${T}`,{title:D.trim()}),h(e=>e.map(e=>e.id===T?{...e,title:D.trim()}:e))}catch{}E(null)},[T,D,e]),R=(0,J.useCallback)(()=>E(null),[]),te=C.trim()?m.filter(e=>(e.title||``).toLowerCase().includes(C.toLowerCase())):m,V=t.fiveHour==null?null:Math.round(t.fiveHour*100),H=t.sevenDay==null?null:Math.round(t.sevenDay*100),U=V!=null||H!=null?wn(Math.max(V??0,H??0)):`text-text-subtle`;return(0,X.jsxs)(`div`,{className:`border-b border-border/50`,children:[(0,X.jsxs)(`div`,{className:`flex items-center gap-1 px-2 py-1`,children:[(0,X.jsxs)(`button`,{onClick:()=>j(`history`),className:`flex items-center gap-1 px-1.5 py-0.5 rounded text-[11px] transition-colors ${f===`history`?`text-primary bg-primary/10`:`text-text-secondary hover:text-foreground hover:bg-surface-elevated`}`,children:[(0,X.jsx)(Ee,{className:`size-3`}),(0,X.jsx)(`span`,{children:`History`})]}),(0,X.jsx)(`button`,{onClick:()=>j(`config`),className:`p-1 rounded transition-colors ${f===`config`?`text-primary bg-primary/10`:`text-text-subtle hover:text-text-secondary hover:bg-surface-elevated`}`,title:`AI Settings`,children:(0,X.jsx)(Ae,{className:`size-3`})}),(0,X.jsxs)(`button`,{onClick:()=>j(`usage`),className:`flex items-center gap-1 px-1.5 py-0.5 rounded text-[11px] font-medium tabular-nums transition-colors hover:bg-surface-elevated ${f===`usage`?`bg-primary/10`:``} ${U}`,title:`Usage limits`,children:[(0,X.jsx)(be,{className:`size-3`}),t.activeAccountLabel&&(0,X.jsxs)(`span`,{className:`text-text-secondary font-normal truncate max-w-[60px]`,children:[`[`,t.activeAccountLabel,`]`]}),(0,X.jsxs)(`span`,{children:[`5h:`,V==null?`--%`:`${V}%`]}),(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`·`}),(0,X.jsxs)(`span`,{children:[`Wk:`,H==null?`--%`:`${H}%`]}),r!=null&&(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(`span`,{className:`text-text-subtle`,children:`·`}),(0,X.jsxs)(`span`,{className:wn(r),children:[`Ctx:`,r,`%`]})]})]}),(0,X.jsx)(`div`,{className:`flex-1`}),x&&s&&(0,X.jsx)(`button`,{onClick:()=>S(s),className:`p-1 rounded text-amber-500 hover:text-amber-400 hover:bg-surface-elevated transition-colors`,title:`Mark as read`,children:(0,X.jsx)(ue,{className:`size-3`})}),d&&(0,X.jsx)(`button`,{onClick:d,className:`size-4 flex items-center justify-center`,title:u?`Connected`:`Disconnected — click to reconnect`,children:(0,X.jsx)(`span`,{className:`size-2 rounded-full ${u?`bg-green-500`:`bg-red-500 animate-pulse`}`})})]}),f===`history`&&(0,X.jsxs)(`div`,{className:`border-t border-border/30 bg-surface`,children:[(0,X.jsxs)(`div`,{className:`flex items-center gap-1.5 px-2 py-1 border-b border-border/30`,children:[(0,X.jsx)(z,{className:`size-3 text-text-subtle shrink-0`}),(0,X.jsx)(`input`,{type:`text`,value:C,onChange:e=>w(e.target.value),placeholder:`Search sessions...`,className:`flex-1 bg-transparent text-[11px] text-text-primary outline-none placeholder:text-text-subtle`}),(0,X.jsx)(`button`,{onClick:M,disabled:g,className:`p-0.5 rounded text-text-subtle hover:text-text-secondary transition-colors disabled:opacity-50`,title:`Refresh`,children:(0,X.jsx)(B,{className:`size-3 ${g?`animate-spin`:``}`})})]}),(0,X.jsx)(`div`,{className:`max-h-[200px] overflow-y-auto`,children:g&&m.length===0?(0,X.jsx)(`div`,{className:`flex items-center justify-center py-3`,children:(0,X.jsx)(q,{className:`size-3.5 animate-spin text-text-subtle`})}):te.length===0?(0,X.jsx)(`div`,{className:`flex items-center justify-center py-3 text-[11px] text-text-subtle`,children:C?`No matching sessions`:`No sessions yet`}):te.map(e=>(0,X.jsxs)(`div`,{className:`flex items-center gap-2 w-full px-3 py-1.5 text-left hover:bg-surface-elevated transition-colors group`,children:[(0,X.jsx)(ee,{className:`size-3 shrink-0 text-text-subtle`}),T===e.id?(0,X.jsxs)(`form`,{className:`flex items-center gap-1 flex-1 min-w-0`,onSubmit:e=>{e.preventDefault(),L()},children:[(0,X.jsx)(`input`,{ref:k,value:D,onChange:e=>O(e.target.value),onBlur:L,onKeyDown:e=>{e.key===`Escape`&&R()},className:`flex-1 min-w-0 bg-surface-elevated text-[11px] text-text-primary px-1 py-0.5 rounded border border-border outline-none focus:border-primary`,autoFocus:!0}),(0,X.jsx)(`button`,{type:`submit`,className:`p-0.5 text-green-500 hover:text-green-400`,onClick:e=>e.stopPropagation(),children:(0,X.jsx)(n,{className:`size-3`})}),(0,X.jsx)(`button`,{type:`button`,className:`p-0.5 text-text-subtle hover:text-text-secondary`,onClick:e=>{e.stopPropagation(),R()},children:(0,X.jsx)(N,{className:`size-3`})})]}):(0,X.jsxs)(X.Fragment,{children:[(0,X.jsx)(`button`,{onClick:()=>P(e),className:`text-[11px] truncate flex-1 text-left`,children:e.title||`Untitled`}),(0,X.jsx)(`button`,{onClick:t=>I(e,t),className:`p-0.5 rounded text-text-subtle hover:text-text-secondary opacity-0 group-hover:opacity-100 transition-opacity`,title:`Rename session`,children:(0,X.jsx)(F,{className:`size-3`})})]}),T!==e.id&&e.updatedAt&&(0,X.jsx)(`span`,{className:`text-[10px] text-text-subtle shrink-0`,children:Cn(e.updatedAt)})]},e.id))})]}),f===`config`&&(0,X.jsx)(`div`,{className:`border-t border-border/30 bg-surface px-3 py-2 max-h-[280px] overflow-y-auto`,children:(0,X.jsx)(pe,{compact:!0})}),f===`usage`&&(0,X.jsx)(Sn,{usage:t,visible:!0,onClose:()=>p(null),onReload:a,loading:i,lastFetchedAt:o})]})}function En({metadata:e,tabId:t}){let[n,r]=(0,J.useState)(e?.sessionId??null),[i,a]=(0,J.useState)(e?.providerId??`claude`),[o,s]=(0,J.useState)([]),[c,d]=(0,J.useState)(!1),[f,p]=(0,J.useState)(``),[m,h]=(0,J.useState)(null),[y,x]=(0,J.useState)([]),[S,C]=(0,J.useState)(!1),[T,E]=(0,J.useState)(``),[D,O]=(0,J.useState)(null),[k,A]=(0,J.useState)(e?.permissionMode??void 0),[j,M]=(0,J.useState)(!1),[N,P]=(0,J.useState)(null),F=(0,J.useRef)(0),I=e?.projectName??``,L=_(e=>e.updateTab),R=u(e=>e.version),{usageInfo:ee,usageLoading:z,lastFetchedAt:B,refreshUsage:V}=Ye(I,i);(0,J.useEffect)(()=>{k||w().then(e=>{let t=e.providers[e.default_provider??`claude`];A(t?.permission_mode??`bypassPermissions`)}).catch(()=>{})},[]),(0,J.useEffect)(()=>{!t||!n||L(t,{metadata:{...e,sessionId:n,providerId:i,permissionMode:k}})},[n,i,k]);let{messages:H,messagesLoading:U,isStreaming:ne,streamingStatus:re,connectingElapsed:ie,thinkingWarningThreshold:ae,pendingApproval:se,contextWindowPct:ce,sessionTitle:le,sendMessage:W,respondToApproval:ue,cancelStreaming:de,reconnect:fe,refetchMessages:pe,isConnected:G}=qe(n,i,I);(0,J.useEffect)(()=>{if(!n||!t)return;let e=()=>{if(document.hidden)return;let{panels:e,focusedPanelId:r}=g.getState();e[r]?.activeTabId===t&&oe.getState().clearForSession(n)};e(),document.addEventListener(`visibilitychange`,e);let r=g.subscribe(e);return()=>{document.removeEventListener(`visibilitychange`,e),r()}},[n,t]),(0,J.useEffect)(()=>{t&&le&&L(t,{title:le})},[le]);let me=(0,J.useRef)(e?.pendingMessage);(0,J.useEffect)(()=>{if(me.current&&G&&n){let n=me.current;me.current=void 0,t&&L(t,{metadata:{...e,pendingMessage:void 0}}),setTimeout(()=>W(n,{permissionMode:k}),100)}},[G,n]),(0,J.useCallback)(()=>{_.getState().openTab({type:`chat`,title:`AI Chat`,metadata:{projectName:I},projectId:I||null,closable:!0})},[I]);let ge=(0,J.useCallback)(e=>{r(e.id),a(e.providerId),t&&L(t,{title:e.title||`Chat`})},[t,L]),_e=(0,J.useCallback)(async e=>{if(!(!n||!I))try{let{api:t,projectUrl:r}=await l(async()=>{let{api:e,projectUrl:t}=await import(`./api-client-DOElml5u.js`).then(e=>e.n);return{api:e,projectUrl:t}},__vite__mapDeps([0,1])),a=await t.post(`${r(I)}/chat/sessions/${n}/fork?providerId=${i}`);_.getState().openTab({type:`chat`,title:`Fork: ${e.slice(0,30)}`,metadata:{projectName:I,sessionId:a.id,providerId:i,pendingMessage:e},projectId:I||null,closable:!0})}catch(e){console.error(`Fork failed:`,e)}},[n,I,i]),K=(0,J.useCallback)((e,t)=>{if(t.length===0)return e;let n=t.filter(e=>e.serverPath).map(e=>e.serverPath).join(`
7
- `);return n?(t.length===1?`[Attached file: ${n}]\n\n`:`[Attached files:\n${n}\n]\n\n`)+e:e},[]),ve=(0,J.useCallback)(async(e,t=[])=>{let o=K(e,t);if(o.trim()){if(!n)try{let t=I,n=await b.post(`${v(t)}/chat/sessions`,{providerId:i,title:e.slice(0,50)});r(n.id),a(n.providerId),setTimeout(()=>{W(o,{permissionMode:k})},500);return}catch(e){console.error(`Failed to create session:`,e);return}W(o,{permissionMode:k})}},[n,i,I,W,K,k]),q=(0,J.useCallback)((e,t)=>{d(e),p(t)},[]),ye=(0,J.useCallback)(e=>{h(e),d(!1),p(``),setTimeout(()=>h(null),50)},[]),be=(0,J.useCallback)(()=>{d(!1),p(``)},[]),xe=(0,J.useCallback)((e,t)=>{C(e),E(t)},[]),Se=(0,J.useCallback)(e=>{O(e),C(!1),E(``),setTimeout(()=>O(null),50)},[]),Ce=(0,J.useCallback)(()=>{C(!1),E(``)},[]);return(0,X.jsxs)(`div`,{className:`flex flex-col h-full relative`,onDragEnter:(0,J.useCallback)(e=>{e.preventDefault(),F.current++,e.dataTransfer.types.includes(`Files`)&&M(!0)},[]),onDragLeave:(0,J.useCallback)(e=>{e.preventDefault(),F.current--,F.current===0&&M(!1)},[]),onDragOver:(0,J.useCallback)(e=>{e.preventDefault()},[]),onDrop:(0,J.useCallback)(e=>{e.preventDefault(),F.current=0,M(!1);let t=Array.from(e.dataTransfer.files);t.length>0&&(P(t),setTimeout(()=>P(null),100))},[]),children:[j&&(0,X.jsx)(`div`,{className:`absolute inset-0 z-50 flex items-center justify-center bg-background/80 backdrop-blur-sm border-2 border-dashed border-primary rounded-lg pointer-events-none`,children:(0,X.jsxs)(`div`,{className:`flex flex-col items-center gap-2 text-primary`,children:[(0,X.jsx)(te,{className:`size-8`}),(0,X.jsx)(`span`,{className:`text-sm font-medium`,children:`Drop files to attach`})]})}),(0,X.jsx)(xt,{messages:H,messagesLoading:U,pendingApproval:se,onApprovalResponse:ue,isStreaming:ne,streamingStatus:re,connectingElapsed:ie,thinkingWarningThreshold:ae,projectName:I,onFork:ne?void 0:_e}),(0,X.jsxs)(`div`,{className:`border-t border-border bg-background shrink-0`,children:[(0,X.jsx)(Tn,{projectName:I,usageInfo:ee,contextWindowPct:ce,usageLoading:z,refreshUsage:V,lastFetchedAt:B,sessionId:n,onSelectSession:ge,onBugReport:n?()=>he(R,{sessionId:n,projectName:I}):void 0,isConnected:G,onReconnect:()=>{G||fe(),pe()}}),(0,X.jsx)(ln,{items:o,filter:f,onSelect:ye,onClose:be,visible:c}),(0,X.jsx)(on,{items:y,filter:T,onSelect:Se,onClose:Ce,visible:S}),(0,X.jsx)(sn,{onSend:ve,isStreaming:ne,onCancel:de,autoFocus:!e?.sessionId,projectName:I,onSlashStateChange:q,onSlashItemsLoaded:s,slashSelected:m,onFileStateChange:xe,onFileItemsLoaded:x,fileSelected:D,externalFiles:N,permissionMode:k,onModeChange:A})]})]})}export{En as ChatTab};
@@ -1,2 +0,0 @@
1
- const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/dagre-KLK3FWXG-sDrRW9MQ.js","assets/dist-BUYzeuKe.js","assets/chunk-CFjPhJqf.js","assets/chunk-PU5JKC2W-CO0zMN-z.js","assets/src-B_cC68fH.js","assets/chunk-GEFDOKGD-BosFEH7G.js","assets/math-B7b0HgJF.js","assets/chunk-7R4GIKGN-DXTbeu5d.js","assets/preload-helper-DeiOTZKJ.js","assets/isArrayLikeObject-BB-mzMLb.js","assets/dagre-BmVoh2At.js","assets/graphlib-CQBb2thr.js","assets/isEmpty-B4kqZBtn.js","assets/_baseUniq-DimLlN0y.js","assets/_basePickBy-5eBmZ_lt.js","assets/clone-CijCFRT5.js","assets/chunk-KYZI473N-FvwP7jUy.js","assets/chunk-PQ6SQG4A-Ci_Prygb.js","assets/chunk-YBOYWFTD-DqSOVcYe.js","assets/rough.esm-Dwml_la6.js","assets/chunk-MX3YWQON-C7Vzk_AI.js","assets/chunk-O4XLMI2P-WPtzgxql.js","assets/line-1gcO63_w.js","assets/path-BAQ3hXlG.js","assets/array-CYkMkqnU.js","assets/cose-bilkent-S5V4N54A-DlL82QHu.js","assets/cytoscape.esm-HeHO0VhB.js"])))=>i.map(i=>d[i]);
2
- import{t as e}from"./preload-helper-DeiOTZKJ.js";import{u as t}from"./chunk-GEFDOKGD-BosFEH7G.js";import{g as n,h as r}from"./src-B_cC68fH.js";import{s as i,y as a}from"./chunk-7R4GIKGN-DXTbeu5d.js";import{a as o,i as s,s as c}from"./chunk-KYZI473N-FvwP7jUy.js";import{a as l,i as u,n as d,r as f}from"./chunk-O4XLMI2P-WPtzgxql.js";var p={common:i,getConfig:a,insertCluster:s,insertEdge:d,insertEdgeLabel:f,insertMarkers:u,insertNode:o,interpolateToCurve:t,labelHelper:c,log:n,positionEdgeLabel:l},m={},h=r(e=>{for(let t of e)m[t.name]=t},`registerLayoutLoaders`);r(()=>{h([{name:`dagre`,loader:r(async()=>await e(()=>import(`./dagre-KLK3FWXG-sDrRW9MQ.js`),__vite__mapDeps([0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24])),`loader`)},...[{name:`cose-bilkent`,loader:r(async()=>await e(()=>import(`./cose-bilkent-S5V4N54A-DlL82QHu.js`),__vite__mapDeps([25,2,26,4])),`loader`)}]])},`registerDefaultLayoutLoaders`)();var g=r(async(e,t)=>{if(!(e.layoutAlgorithm in m))throw Error(`Unknown layout algorithm: ${e.layoutAlgorithm}`);let n=m[e.layoutAlgorithm];return(await n.loader()).render(e,t,p,{algorithm:n.algorithm})},`render`),_=r((e=``,{fallback:t=`dagre`}={})=>{if(e in m)return e;if(t in m)return n.warn(`Layout algorithm ${e} is not registered. Using ${t} as fallback.`),t;throw Error(`Both layout algorithms ${e} and ${t} are not registered.`)},`getRegisteredLayoutAlgorithm`);export{h as n,g as r,_ as t};