claude-mux 0.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (636) hide show
  1. package/.beads/README.md +81 -0
  2. package/.beads/config.yaml +62 -0
  3. package/.beads/interactions.jsonl +0 -0
  4. package/.beads/issues.jsonl +5 -0
  5. package/.beads/metadata.json +4 -0
  6. package/.eslintrc.json +25 -0
  7. package/.gitattributes +3 -0
  8. package/.prettierrc +7 -0
  9. package/CLAUDE.md +123 -0
  10. package/LICENSE +21 -0
  11. package/PLAN-beads-integration.md +250 -0
  12. package/README.md +366 -0
  13. package/dist/app.d.ts +2 -0
  14. package/dist/app.d.ts.map +1 -0
  15. package/dist/app.js +147 -0
  16. package/dist/app.js.map +1 -0
  17. package/dist/cli.d.ts +3 -0
  18. package/dist/cli.d.ts.map +1 -0
  19. package/dist/cli.js +65 -0
  20. package/dist/cli.js.map +1 -0
  21. package/dist/commands/index.d.ts +5 -0
  22. package/dist/commands/index.d.ts.map +1 -0
  23. package/dist/commands/index.js +5 -0
  24. package/dist/commands/index.js.map +1 -0
  25. package/dist/commands/serve.d.ts +8 -0
  26. package/dist/commands/serve.d.ts.map +1 -0
  27. package/dist/commands/serve.js +59 -0
  28. package/dist/commands/serve.js.map +1 -0
  29. package/dist/commands/setup.d.ts +4 -0
  30. package/dist/commands/setup.d.ts.map +1 -0
  31. package/dist/commands/setup.js +12 -0
  32. package/dist/commands/setup.js.map +1 -0
  33. package/dist/commands/tui.d.ts +9 -0
  34. package/dist/commands/tui.d.ts.map +1 -0
  35. package/dist/commands/tui.js +234 -0
  36. package/dist/commands/tui.js.map +1 -0
  37. package/dist/commands/uninstall.d.ts +4 -0
  38. package/dist/commands/uninstall.d.ts.map +1 -0
  39. package/dist/commands/uninstall.js +12 -0
  40. package/dist/commands/uninstall.js.map +1 -0
  41. package/dist/components/Header.d.ts +7 -0
  42. package/dist/components/Header.d.ts.map +1 -0
  43. package/dist/components/Header.js +14 -0
  44. package/dist/components/Header.js.map +1 -0
  45. package/dist/components/HelpDialog.d.ts +6 -0
  46. package/dist/components/HelpDialog.d.ts.map +1 -0
  47. package/dist/components/HelpDialog.js +14 -0
  48. package/dist/components/HelpDialog.js.map +1 -0
  49. package/dist/components/SessionEntry.d.ts +17 -0
  50. package/dist/components/SessionEntry.d.ts.map +1 -0
  51. package/dist/components/SessionEntry.js +102 -0
  52. package/dist/components/SessionEntry.js.map +1 -0
  53. package/dist/components/SessionList.d.ts +14 -0
  54. package/dist/components/SessionList.d.ts.map +1 -0
  55. package/dist/components/SessionList.js +57 -0
  56. package/dist/components/SessionList.js.map +1 -0
  57. package/dist/components/StatusBar.d.ts +6 -0
  58. package/dist/components/StatusBar.d.ts.map +1 -0
  59. package/dist/components/StatusBar.js +7 -0
  60. package/dist/components/StatusBar.js.map +1 -0
  61. package/dist/components/index.d.ts +6 -0
  62. package/dist/components/index.d.ts.map +1 -0
  63. package/dist/components/index.js +6 -0
  64. package/dist/components/index.js.map +1 -0
  65. package/dist/db/index.d.ts +2 -0
  66. package/dist/db/index.d.ts.map +1 -0
  67. package/dist/db/index.js +3 -0
  68. package/dist/db/index.js.map +1 -0
  69. package/dist/db/schema.d.ts +4 -0
  70. package/dist/db/schema.d.ts.map +1 -0
  71. package/dist/db/schema.js +23 -0
  72. package/dist/db/schema.js.map +1 -0
  73. package/dist/db/sessions-json.d.ts +85 -0
  74. package/dist/db/sessions-json.d.ts.map +1 -0
  75. package/dist/db/sessions-json.js +242 -0
  76. package/dist/db/sessions-json.js.map +1 -0
  77. package/dist/db/sessions.d.ts +38 -0
  78. package/dist/db/sessions.d.ts.map +1 -0
  79. package/dist/db/sessions.js +87 -0
  80. package/dist/db/sessions.js.map +1 -0
  81. package/dist/hooks/claude-mux-hook.d.ts +15 -0
  82. package/dist/hooks/claude-mux-hook.d.ts.map +1 -0
  83. package/dist/hooks/claude-mux-hook.js +396 -0
  84. package/dist/hooks/claude-mux-hook.js.map +1 -0
  85. package/dist/hooks/claude-watch-hook.d.ts +15 -0
  86. package/dist/hooks/claude-watch-hook.d.ts.map +1 -0
  87. package/dist/hooks/claude-watch-hook.js +396 -0
  88. package/dist/hooks/claude-watch-hook.js.map +1 -0
  89. package/dist/server/custom-server.d.ts +13 -0
  90. package/dist/server/custom-server.d.ts.map +1 -0
  91. package/dist/server/custom-server.js +63 -0
  92. package/dist/server/custom-server.js.map +1 -0
  93. package/dist/server/index.d.ts +9 -0
  94. package/dist/server/index.d.ts.map +1 -0
  95. package/dist/server/index.js +1143 -0
  96. package/dist/server/index.js.map +1 -0
  97. package/dist/server/middleware/cors.d.ts +2 -0
  98. package/dist/server/middleware/cors.d.ts.map +1 -0
  99. package/dist/server/middleware/cors.js +11 -0
  100. package/dist/server/middleware/cors.js.map +1 -0
  101. package/dist/server/routes/sessions.d.ts +3 -0
  102. package/dist/server/routes/sessions.d.ts.map +1 -0
  103. package/dist/server/routes/sessions.js +78 -0
  104. package/dist/server/routes/sessions.js.map +1 -0
  105. package/dist/server/routes/stream.d.ts +3 -0
  106. package/dist/server/routes/stream.d.ts.map +1 -0
  107. package/dist/server/routes/stream.js +45 -0
  108. package/dist/server/routes/stream.js.map +1 -0
  109. package/dist/server/types.d.ts +28 -0
  110. package/dist/server/types.d.ts.map +1 -0
  111. package/dist/server/types.js +2 -0
  112. package/dist/server/types.js.map +1 -0
  113. package/dist/server/watcher.d.ts +22 -0
  114. package/dist/server/watcher.d.ts.map +1 -0
  115. package/dist/server/watcher.js +119 -0
  116. package/dist/server/watcher.js.map +1 -0
  117. package/dist/server/websocket.d.ts +51 -0
  118. package/dist/server/websocket.d.ts.map +1 -0
  119. package/dist/server/websocket.js +156 -0
  120. package/dist/server/websocket.js.map +1 -0
  121. package/dist/server/ws-handlers.d.ts +174 -0
  122. package/dist/server/ws-handlers.d.ts.map +1 -0
  123. package/dist/server/ws-handlers.js +695 -0
  124. package/dist/server/ws-handlers.js.map +1 -0
  125. package/dist/setup/hooks.d.ts +44 -0
  126. package/dist/setup/hooks.d.ts.map +1 -0
  127. package/dist/setup/hooks.js +267 -0
  128. package/dist/setup/hooks.js.map +1 -0
  129. package/dist/setup/index.d.ts +3 -0
  130. package/dist/setup/index.d.ts.map +1 -0
  131. package/dist/setup/index.js +3 -0
  132. package/dist/setup/index.js.map +1 -0
  133. package/dist/setup/wizard.d.ts +4 -0
  134. package/dist/setup/wizard.d.ts.map +1 -0
  135. package/dist/setup/wizard.js +72 -0
  136. package/dist/setup/wizard.js.map +1 -0
  137. package/dist/tmux/detect.d.ts +25 -0
  138. package/dist/tmux/detect.d.ts.map +1 -0
  139. package/dist/tmux/detect.js +71 -0
  140. package/dist/tmux/detect.js.map +1 -0
  141. package/dist/tmux/navigate.d.ts +13 -0
  142. package/dist/tmux/navigate.d.ts.map +1 -0
  143. package/dist/tmux/navigate.js +41 -0
  144. package/dist/tmux/navigate.js.map +1 -0
  145. package/dist/tmux/pane.d.ts +57 -0
  146. package/dist/tmux/pane.d.ts.map +1 -0
  147. package/dist/tmux/pane.js +156 -0
  148. package/dist/tmux/pane.js.map +1 -0
  149. package/dist/tmux/resize.d.ts +10 -0
  150. package/dist/tmux/resize.d.ts.map +1 -0
  151. package/dist/tmux/resize.js +25 -0
  152. package/dist/tmux/resize.js.map +1 -0
  153. package/dist/utils/paths.d.ts +7 -0
  154. package/dist/utils/paths.d.ts.map +1 -0
  155. package/dist/utils/paths.js +9 -0
  156. package/dist/utils/paths.js.map +1 -0
  157. package/dist/utils/pid.d.ts +5 -0
  158. package/dist/utils/pid.d.ts.map +1 -0
  159. package/dist/utils/pid.js +14 -0
  160. package/dist/utils/pid.js.map +1 -0
  161. package/dist/utils/version.d.ts +6 -0
  162. package/dist/utils/version.d.ts.map +1 -0
  163. package/dist/utils/version.js +6 -0
  164. package/dist/utils/version.js.map +1 -0
  165. package/dist/web/client/_app/immutable/assets/0.WptSHSUl.css +1 -0
  166. package/dist/web/client/_app/immutable/assets/2.s6Kx4oz1.css +1 -0
  167. package/dist/web/client/_app/immutable/assets/4.DoNWy7tW.css +1 -0
  168. package/dist/web/client/_app/immutable/assets/AllSessionsPanel.CGHY3HLy.css +1 -0
  169. package/dist/web/client/_app/immutable/chunks/-3mUPuLP.js +1 -0
  170. package/dist/web/client/_app/immutable/chunks/B5U4_V3d.js +1 -0
  171. package/dist/web/client/_app/immutable/chunks/BHwiZXRv.js +1 -0
  172. package/dist/web/client/_app/immutable/chunks/C9P-coqM.js +1 -0
  173. package/dist/web/client/_app/immutable/chunks/Cegv0r8x.js +1 -0
  174. package/dist/web/client/_app/immutable/chunks/DU91Ml7U.js +3 -0
  175. package/dist/web/client/_app/immutable/chunks/DmdO6ygw.js +1 -0
  176. package/dist/web/client/_app/immutable/chunks/HKNo9LID.js +5 -0
  177. package/dist/web/client/_app/immutable/chunks/U4ip-C0d.js +2 -0
  178. package/dist/web/client/_app/immutable/chunks/cgUjKIhX.js +2 -0
  179. package/dist/web/client/_app/immutable/entry/app.CGIBnoln.js +2 -0
  180. package/dist/web/client/_app/immutable/entry/start.CJk8zB1j.js +1 -0
  181. package/dist/web/client/_app/immutable/nodes/0.CqlJ9a31.js +1 -0
  182. package/dist/web/client/_app/immutable/nodes/1.BQUZh2-w.js +1 -0
  183. package/dist/web/client/_app/immutable/nodes/2.CCV1YdgF.js +1 -0
  184. package/dist/web/client/_app/immutable/nodes/3.D9tDCdq8.js +1 -0
  185. package/dist/web/client/_app/immutable/nodes/4.BqPyNkFA.js +6 -0
  186. package/dist/web/client/_app/version.json +1 -0
  187. package/dist/web/client/robots.txt +3 -0
  188. package/dist/web/env.js +32 -0
  189. package/dist/web/handler.js +744 -0
  190. package/dist/web/index.js +49 -0
  191. package/dist/web/server/chunks/0-BHWsmCJv.js +23 -0
  192. package/dist/web/server/chunks/0-BHWsmCJv.js.map +1 -0
  193. package/dist/web/server/chunks/1-YRx6A8Tm.js +17 -0
  194. package/dist/web/server/chunks/1-YRx6A8Tm.js.map +1 -0
  195. package/dist/web/server/chunks/2-eC6JuGAo.js +22 -0
  196. package/dist/web/server/chunks/2-eC6JuGAo.js.map +1 -0
  197. package/dist/web/server/chunks/3-Bk-wV20p.js +32 -0
  198. package/dist/web/server/chunks/3-Bk-wV20p.js.map +1 -0
  199. package/dist/web/server/chunks/4-nteBgDrW.js +21 -0
  200. package/dist/web/server/chunks/4-nteBgDrW.js.map +1 -0
  201. package/dist/web/server/chunks/AllSessionsPanel.svelte_svelte_type_style_lang-Bt4B0-oi.js +35 -0
  202. package/dist/web/server/chunks/AllSessionsPanel.svelte_svelte_type_style_lang-Bt4B0-oi.js.map +1 -0
  203. package/dist/web/server/chunks/_layout.svelte-BIF9eZCY.js +453 -0
  204. package/dist/web/server/chunks/_layout.svelte-BIF9eZCY.js.map +1 -0
  205. package/dist/web/server/chunks/_page.svelte-Be6iabRn.js +34 -0
  206. package/dist/web/server/chunks/_page.svelte-Be6iabRn.js.map +1 -0
  207. package/dist/web/server/chunks/_page.svelte-C_fGJVSE.js +576 -0
  208. package/dist/web/server/chunks/_page.svelte-C_fGJVSE.js.map +1 -0
  209. package/dist/web/server/chunks/_page.svelte-CnfJk6cu.js +2722 -0
  210. package/dist/web/server/chunks/_page.svelte-CnfJk6cu.js.map +1 -0
  211. package/dist/web/server/chunks/_server.ts-3WAmKvn2.js +34 -0
  212. package/dist/web/server/chunks/_server.ts-3WAmKvn2.js.map +1 -0
  213. package/dist/web/server/chunks/_server.ts-BAWJCSFb.js +29 -0
  214. package/dist/web/server/chunks/_server.ts-BAWJCSFb.js.map +1 -0
  215. package/dist/web/server/chunks/_server.ts-BPpMOZCm.js +24 -0
  216. package/dist/web/server/chunks/_server.ts-BPpMOZCm.js.map +1 -0
  217. package/dist/web/server/chunks/_server.ts-BUKgRb6U.js +13 -0
  218. package/dist/web/server/chunks/_server.ts-BUKgRb6U.js.map +1 -0
  219. package/dist/web/server/chunks/_server.ts-BVHUS8fm.js +41 -0
  220. package/dist/web/server/chunks/_server.ts-BVHUS8fm.js.map +1 -0
  221. package/dist/web/server/chunks/_server.ts-BrF3od0O.js +45 -0
  222. package/dist/web/server/chunks/_server.ts-BrF3od0O.js.map +1 -0
  223. package/dist/web/server/chunks/_server.ts-C4oPmOJR.js +38 -0
  224. package/dist/web/server/chunks/_server.ts-C4oPmOJR.js.map +1 -0
  225. package/dist/web/server/chunks/_server.ts-CDAUUmG_.js +21 -0
  226. package/dist/web/server/chunks/_server.ts-CDAUUmG_.js.map +1 -0
  227. package/dist/web/server/chunks/_server.ts-CR0uWvpz.js +24 -0
  228. package/dist/web/server/chunks/_server.ts-CR0uWvpz.js.map +1 -0
  229. package/dist/web/server/chunks/_server.ts-CSqdCNGi.js +21 -0
  230. package/dist/web/server/chunks/_server.ts-CSqdCNGi.js.map +1 -0
  231. package/dist/web/server/chunks/_server.ts-DI9fzUo9.js +52 -0
  232. package/dist/web/server/chunks/_server.ts-DI9fzUo9.js.map +1 -0
  233. package/dist/web/server/chunks/_server.ts-DNjJTClI.js +46 -0
  234. package/dist/web/server/chunks/_server.ts-DNjJTClI.js.map +1 -0
  235. package/dist/web/server/chunks/_server.ts-DdbOAkOj.js +22 -0
  236. package/dist/web/server/chunks/_server.ts-DdbOAkOj.js.map +1 -0
  237. package/dist/web/server/chunks/_server.ts-Df2isGQc.js +41 -0
  238. package/dist/web/server/chunks/_server.ts-Df2isGQc.js.map +1 -0
  239. package/dist/web/server/chunks/_server.ts-Vpw25_-3.js +12 -0
  240. package/dist/web/server/chunks/_server.ts-Vpw25_-3.js.map +1 -0
  241. package/dist/web/server/chunks/_server.ts-WldRpSRi.js +26 -0
  242. package/dist/web/server/chunks/_server.ts-WldRpSRi.js.map +1 -0
  243. package/dist/web/server/chunks/alert-dialog-description-DDA6u-nS.js +2890 -0
  244. package/dist/web/server/chunks/alert-dialog-description-DDA6u-nS.js.map +1 -0
  245. package/dist/web/server/chunks/auth-DrUf-v4J.js +51 -0
  246. package/dist/web/server/chunks/auth-DrUf-v4J.js.map +1 -0
  247. package/dist/web/server/chunks/button-D6xS9rHt.js +2335 -0
  248. package/dist/web/server/chunks/button-D6xS9rHt.js.map +1 -0
  249. package/dist/web/server/chunks/chunk-EKzHsMy_.js +42 -0
  250. package/dist/web/server/chunks/chunks-DmdqVYC7.js +58 -0
  251. package/dist/web/server/chunks/chunks-DmdqVYC7.js.map +1 -0
  252. package/dist/web/server/chunks/client-CUrSQijh.js +18 -0
  253. package/dist/web/server/chunks/client-CUrSQijh.js.map +1 -0
  254. package/dist/web/server/chunks/clsx-FzI4_gi0.js +332 -0
  255. package/dist/web/server/chunks/clsx-FzI4_gi0.js.map +1 -0
  256. package/dist/web/server/chunks/error.svelte-D-c-9pTE.js +27 -0
  257. package/dist/web/server/chunks/error.svelte-D-c-9pTE.js.map +1 -0
  258. package/dist/web/server/chunks/events-BDBlYddw.js +89 -0
  259. package/dist/web/server/chunks/events-BDBlYddw.js.map +1 -0
  260. package/dist/web/server/chunks/exports-CCurQ-Tl.js +131 -0
  261. package/dist/web/server/chunks/exports-CCurQ-Tl.js.map +1 -0
  262. package/dist/web/server/chunks/hooks.server-BK1bopsh.js +86 -0
  263. package/dist/web/server/chunks/hooks.server-BK1bopsh.js.map +1 -0
  264. package/dist/web/server/chunks/index2-BQnysSj-.js +2588 -0
  265. package/dist/web/server/chunks/index2-BQnysSj-.js.map +1 -0
  266. package/dist/web/server/chunks/internal-DLENj6YI.js +61 -0
  267. package/dist/web/server/chunks/internal-DLENj6YI.js.map +1 -0
  268. package/dist/web/server/chunks/pane-Dg3pKvsm.js +94 -0
  269. package/dist/web/server/chunks/pane-Dg3pKvsm.js.map +1 -0
  270. package/dist/web/server/chunks/sessions-json-DgfkCLO7.js +107 -0
  271. package/dist/web/server/chunks/sessions-json-DgfkCLO7.js.map +1 -0
  272. package/dist/web/server/chunks/sessions.svelte-Ds82MvkB.js +178 -0
  273. package/dist/web/server/chunks/sessions.svelte-Ds82MvkB.js.map +1 -0
  274. package/dist/web/server/chunks/state.svelte-xeAZvWZ6.js +7 -0
  275. package/dist/web/server/chunks/state.svelte-xeAZvWZ6.js.map +1 -0
  276. package/dist/web/server/chunks/ws-handlers-B4r5eSP2.js +733 -0
  277. package/dist/web/server/chunks/ws-handlers-B4r5eSP2.js.map +1 -0
  278. package/dist/web/server/index.js +4907 -0
  279. package/dist/web/server/index.js.map +1 -0
  280. package/dist/web/server/manifest.js +233 -0
  281. package/dist/web/server/manifest.js.map +1 -0
  282. package/docs/images/desktop-dashboard.png +0 -0
  283. package/docs/images/desktop-session.png +0 -0
  284. package/docs/images/mobile-dashboard.png +0 -0
  285. package/docs/images/mobile-session.png +0 -0
  286. package/docs/release-checklist.md +228 -0
  287. package/docs/removing-hooks.md +135 -0
  288. package/docs/state-transitions.md +109 -0
  289. package/package.json +71 -0
  290. package/src/app.tsx +188 -0
  291. package/src/cli.ts +83 -0
  292. package/src/commands/index.ts +4 -0
  293. package/src/commands/serve.ts +75 -0
  294. package/src/commands/setup.ts +13 -0
  295. package/src/commands/tui.ts +255 -0
  296. package/src/commands/uninstall.ts +13 -0
  297. package/src/components/Header.tsx +32 -0
  298. package/src/components/HelpDialog.tsx +45 -0
  299. package/src/components/SessionEntry.tsx +202 -0
  300. package/src/components/SessionList.tsx +98 -0
  301. package/src/components/StatusBar.tsx +26 -0
  302. package/src/components/index.ts +5 -0
  303. package/src/db/index.ts +20 -0
  304. package/src/db/sessions-json.ts +314 -0
  305. package/src/hooks/claude-mux-hook.ts +498 -0
  306. package/src/server/watcher.ts +128 -0
  307. package/src/server/ws-handlers.ts +922 -0
  308. package/src/setup/hooks.ts +333 -0
  309. package/src/setup/index.ts +2 -0
  310. package/src/setup/wizard.ts +81 -0
  311. package/src/tmux/detect.ts +87 -0
  312. package/src/tmux/navigate.ts +42 -0
  313. package/src/tmux/pane.ts +167 -0
  314. package/src/tmux/resize.ts +28 -0
  315. package/src/utils/paths.ts +11 -0
  316. package/src/utils/pid.ts +12 -0
  317. package/src/utils/version.ts +5 -0
  318. package/tests/components/Header.test.tsx +42 -0
  319. package/tests/components/SessionEntry-extended.test.tsx +165 -0
  320. package/tests/components/SessionEntry.test.tsx +138 -0
  321. package/tests/components/SessionList.test.tsx +110 -0
  322. package/tests/components/StatusBar.test.tsx +31 -0
  323. package/tests/db/index.test.ts +78 -0
  324. package/tests/db/sessions.test.ts +230 -0
  325. package/tests/server/integration.test.ts +319 -0
  326. package/tests/server/sessions.test.ts +114 -0
  327. package/tests/setup/hooks-integration.test.ts +148 -0
  328. package/tests/setup/hooks.test.ts +123 -0
  329. package/tests/tmux/detect.test.ts +54 -0
  330. package/tests/tmux/navigate.test.ts +30 -0
  331. package/tests/utils/pid.test.ts +17 -0
  332. package/tsconfig.cli.json +9 -0
  333. package/tsconfig.json +22 -0
  334. package/vitest.config.ts +29 -0
  335. package/web/.svelte-kit/adapter-bun/.vite/manifest.json +408 -0
  336. package/web/.svelte-kit/adapter-bun/_app/immutable/assets/AllSessionsPanel.BKhqOrbV.css +1 -0
  337. package/web/.svelte-kit/adapter-bun/_app/immutable/assets/_layout.WptSHSUl.css +1 -0
  338. package/web/.svelte-kit/adapter-bun/_app/immutable/assets/_page.DldLgTc-.css +1 -0
  339. package/web/.svelte-kit/adapter-bun/_app/immutable/assets/_page.DoNWy7tW.css +1 -0
  340. package/web/.svelte-kit/adapter-bun/chunks/AllSessionsPanel.svelte_svelte_type_style_lang.js +49 -0
  341. package/web/.svelte-kit/adapter-bun/chunks/alert-dialog-description.js +2670 -0
  342. package/web/.svelte-kit/adapter-bun/chunks/auth.js +59 -0
  343. package/web/.svelte-kit/adapter-bun/chunks/button.js +82 -0
  344. package/web/.svelte-kit/adapter-bun/chunks/client.js +29 -0
  345. package/web/.svelte-kit/adapter-bun/chunks/context.js +133 -0
  346. package/web/.svelte-kit/adapter-bun/chunks/environment.js +34 -0
  347. package/web/.svelte-kit/adapter-bun/chunks/events.js +121 -0
  348. package/web/.svelte-kit/adapter-bun/chunks/exports.js +174 -0
  349. package/web/.svelte-kit/adapter-bun/chunks/false.js +4 -0
  350. package/web/.svelte-kit/adapter-bun/chunks/index.js +59 -0
  351. package/web/.svelte-kit/adapter-bun/chunks/index2.js +2828 -0
  352. package/web/.svelte-kit/adapter-bun/chunks/internal.js +920 -0
  353. package/web/.svelte-kit/adapter-bun/chunks/pane.js +82 -0
  354. package/web/.svelte-kit/adapter-bun/chunks/sessions-json.js +124 -0
  355. package/web/.svelte-kit/adapter-bun/chunks/sessions.svelte.js +229 -0
  356. package/web/.svelte-kit/adapter-bun/chunks/shared.js +542 -0
  357. package/web/.svelte-kit/adapter-bun/chunks/state.svelte.js +16 -0
  358. package/web/.svelte-kit/adapter-bun/chunks/utils.js +43 -0
  359. package/web/.svelte-kit/adapter-bun/chunks/ws-handlers.js +782 -0
  360. package/web/.svelte-kit/adapter-bun/entries/endpoints/api/auth/login/_server.ts.js +22 -0
  361. package/web/.svelte-kit/adapter-bun/entries/endpoints/api/auth/logout/_server.ts.js +9 -0
  362. package/web/.svelte-kit/adapter-bun/entries/endpoints/api/beads/_server.ts.js +22 -0
  363. package/web/.svelte-kit/adapter-bun/entries/endpoints/api/browse/_server.ts.js +50 -0
  364. package/web/.svelte-kit/adapter-bun/entries/endpoints/api/chrome/_server.ts.js +30 -0
  365. package/web/.svelte-kit/adapter-bun/entries/endpoints/api/files/image/_server.ts.js +53 -0
  366. package/web/.svelte-kit/adapter-bun/entries/endpoints/api/health/_server.ts.js +7 -0
  367. package/web/.svelte-kit/adapter-bun/entries/endpoints/api/projects/new-session/_server.ts.js +44 -0
  368. package/web/.svelte-kit/adapter-bun/entries/endpoints/api/sessions/_id_/_server.ts.js +20 -0
  369. package/web/.svelte-kit/adapter-bun/entries/endpoints/api/sessions/_id_/kill/_server.ts.js +36 -0
  370. package/web/.svelte-kit/adapter-bun/entries/endpoints/api/sessions/_id_/restart/_server.ts.js +40 -0
  371. package/web/.svelte-kit/adapter-bun/entries/endpoints/api/sessions/_id_/screenshots/_server.ts.js +28 -0
  372. package/web/.svelte-kit/adapter-bun/entries/endpoints/api/sessions/_id_/send/_server.ts.js +29 -0
  373. package/web/.svelte-kit/adapter-bun/entries/endpoints/api/sessions/_server.ts.js +49 -0
  374. package/web/.svelte-kit/adapter-bun/entries/endpoints/api/sessions/_target_/output/_server.ts.js +14 -0
  375. package/web/.svelte-kit/adapter-bun/entries/endpoints/api/tmux/panes/_server.ts.js +21 -0
  376. package/web/.svelte-kit/adapter-bun/entries/fallbacks/error.svelte.js +27 -0
  377. package/web/.svelte-kit/adapter-bun/entries/hooks.server.js +105 -0
  378. package/web/.svelte-kit/adapter-bun/entries/pages/_layout.svelte.js +499 -0
  379. package/web/.svelte-kit/adapter-bun/entries/pages/_page.svelte.js +3057 -0
  380. package/web/.svelte-kit/adapter-bun/entries/pages/login/_page.server.ts.js +15 -0
  381. package/web/.svelte-kit/adapter-bun/entries/pages/login/_page.svelte.js +37 -0
  382. package/web/.svelte-kit/adapter-bun/entries/pages/session/_target_/_page.svelte.js +653 -0
  383. package/web/.svelte-kit/adapter-bun/index.js +3864 -0
  384. package/web/.svelte-kit/adapter-bun/internal.js +13 -0
  385. package/web/.svelte-kit/adapter-bun/manifest-full.js +167 -0
  386. package/web/.svelte-kit/adapter-bun/manifest.js +171 -0
  387. package/web/.svelte-kit/adapter-bun/nodes/0.js +8 -0
  388. package/web/.svelte-kit/adapter-bun/nodes/1.js +8 -0
  389. package/web/.svelte-kit/adapter-bun/nodes/2.js +8 -0
  390. package/web/.svelte-kit/adapter-bun/nodes/3.js +10 -0
  391. package/web/.svelte-kit/adapter-bun/nodes/4.js +8 -0
  392. package/web/.svelte-kit/adapter-bun/remote-entry.js +541 -0
  393. package/web/.svelte-kit/adapter-node/.vite/manifest.json +223 -0
  394. package/web/.svelte-kit/adapter-node/_app/immutable/assets/_layout.4NiX29PU.css +1 -0
  395. package/web/.svelte-kit/adapter-node/_app/immutable/assets/_page.BEMzYUGV.css +1 -0
  396. package/web/.svelte-kit/adapter-node/_app/immutable/assets/_page.DOJn7TG7.css +1 -0
  397. package/web/.svelte-kit/adapter-node/chunks/context.js +121 -0
  398. package/web/.svelte-kit/adapter-node/chunks/environment.js +34 -0
  399. package/web/.svelte-kit/adapter-node/chunks/exports.js +174 -0
  400. package/web/.svelte-kit/adapter-node/chunks/false.js +4 -0
  401. package/web/.svelte-kit/adapter-node/chunks/index.js +59 -0
  402. package/web/.svelte-kit/adapter-node/chunks/index2.js +2710 -0
  403. package/web/.svelte-kit/adapter-node/chunks/internal.js +1005 -0
  404. package/web/.svelte-kit/adapter-node/chunks/sessions-json.js +109 -0
  405. package/web/.svelte-kit/adapter-node/chunks/sessions.svelte.js +67 -0
  406. package/web/.svelte-kit/adapter-node/chunks/shared.js +542 -0
  407. package/web/.svelte-kit/adapter-node/chunks/state.svelte.js +16 -0
  408. package/web/.svelte-kit/adapter-node/chunks/utils.js +43 -0
  409. package/web/.svelte-kit/adapter-node/entries/endpoints/api/browse/_server.ts.js +50 -0
  410. package/web/.svelte-kit/adapter-node/entries/endpoints/api/health/_server.ts.js +7 -0
  411. package/web/.svelte-kit/adapter-node/entries/endpoints/api/projects/new-session/_server.ts.js +44 -0
  412. package/web/.svelte-kit/adapter-node/entries/endpoints/api/sessions/_id_/_server.ts.js +20 -0
  413. package/web/.svelte-kit/adapter-node/entries/endpoints/api/sessions/_id_/kill/_server.ts.js +30 -0
  414. package/web/.svelte-kit/adapter-node/entries/endpoints/api/sessions/_id_/send/_server.ts.js +22 -0
  415. package/web/.svelte-kit/adapter-node/entries/endpoints/api/sessions/_server.ts.js +126 -0
  416. package/web/.svelte-kit/adapter-node/entries/endpoints/api/sessions/_target_/output/_server.ts.js +14 -0
  417. package/web/.svelte-kit/adapter-node/entries/fallbacks/error.svelte.js +44 -0
  418. package/web/.svelte-kit/adapter-node/entries/pages/_layout.svelte.js +12 -0
  419. package/web/.svelte-kit/adapter-node/entries/pages/_page.svelte.js +87 -0
  420. package/web/.svelte-kit/adapter-node/entries/pages/session/_target_/_page.svelte.js +76 -0
  421. package/web/.svelte-kit/adapter-node/index.js +3864 -0
  422. package/web/.svelte-kit/adapter-node/internal.js +13 -0
  423. package/web/.svelte-kit/adapter-node/manifest-full.js +103 -0
  424. package/web/.svelte-kit/adapter-node/manifest.js +107 -0
  425. package/web/.svelte-kit/adapter-node/nodes/0.js +8 -0
  426. package/web/.svelte-kit/adapter-node/nodes/1.js +8 -0
  427. package/web/.svelte-kit/adapter-node/nodes/2.js +8 -0
  428. package/web/.svelte-kit/adapter-node/nodes/3.js +8 -0
  429. package/web/.svelte-kit/adapter-node/remote-entry.js +541 -0
  430. package/web/.svelte-kit/ambient.d.ts +187 -0
  431. package/web/.svelte-kit/generated/client/app.js +33 -0
  432. package/web/.svelte-kit/generated/client/matchers.js +1 -0
  433. package/web/.svelte-kit/generated/client/nodes/0.js +1 -0
  434. package/web/.svelte-kit/generated/client/nodes/1.js +1 -0
  435. package/web/.svelte-kit/generated/client/nodes/2.js +1 -0
  436. package/web/.svelte-kit/generated/client/nodes/3.js +1 -0
  437. package/web/.svelte-kit/generated/client/nodes/4.js +1 -0
  438. package/web/.svelte-kit/generated/client-optimized/app.js +33 -0
  439. package/web/.svelte-kit/generated/client-optimized/matchers.js +1 -0
  440. package/web/.svelte-kit/generated/client-optimized/nodes/0.js +1 -0
  441. package/web/.svelte-kit/generated/client-optimized/nodes/1.js +1 -0
  442. package/web/.svelte-kit/generated/client-optimized/nodes/2.js +1 -0
  443. package/web/.svelte-kit/generated/client-optimized/nodes/3.js +1 -0
  444. package/web/.svelte-kit/generated/client-optimized/nodes/4.js +1 -0
  445. package/web/.svelte-kit/generated/root.js +3 -0
  446. package/web/.svelte-kit/generated/root.svelte +68 -0
  447. package/web/.svelte-kit/generated/server/internal.js +53 -0
  448. package/web/.svelte-kit/non-ambient.d.ts +73 -0
  449. package/web/.svelte-kit/output/client/.vite/manifest.json +203 -0
  450. package/web/.svelte-kit/output/client/_app/immutable/assets/0.WptSHSUl.css +1 -0
  451. package/web/.svelte-kit/output/client/_app/immutable/assets/2.s6Kx4oz1.css +1 -0
  452. package/web/.svelte-kit/output/client/_app/immutable/assets/4.DoNWy7tW.css +1 -0
  453. package/web/.svelte-kit/output/client/_app/immutable/assets/AllSessionsPanel.CGHY3HLy.css +1 -0
  454. package/web/.svelte-kit/output/client/_app/immutable/chunks/-3mUPuLP.js +1 -0
  455. package/web/.svelte-kit/output/client/_app/immutable/chunks/B5U4_V3d.js +1 -0
  456. package/web/.svelte-kit/output/client/_app/immutable/chunks/BHwiZXRv.js +1 -0
  457. package/web/.svelte-kit/output/client/_app/immutable/chunks/C9P-coqM.js +1 -0
  458. package/web/.svelte-kit/output/client/_app/immutable/chunks/Cegv0r8x.js +1 -0
  459. package/web/.svelte-kit/output/client/_app/immutable/chunks/DU91Ml7U.js +3 -0
  460. package/web/.svelte-kit/output/client/_app/immutable/chunks/DmdO6ygw.js +1 -0
  461. package/web/.svelte-kit/output/client/_app/immutable/chunks/HKNo9LID.js +5 -0
  462. package/web/.svelte-kit/output/client/_app/immutable/chunks/U4ip-C0d.js +2 -0
  463. package/web/.svelte-kit/output/client/_app/immutable/chunks/cgUjKIhX.js +2 -0
  464. package/web/.svelte-kit/output/client/_app/immutable/entry/app.CGIBnoln.js +2 -0
  465. package/web/.svelte-kit/output/client/_app/immutable/entry/start.CJk8zB1j.js +1 -0
  466. package/web/.svelte-kit/output/client/_app/immutable/nodes/0.CqlJ9a31.js +1 -0
  467. package/web/.svelte-kit/output/client/_app/immutable/nodes/1.BQUZh2-w.js +1 -0
  468. package/web/.svelte-kit/output/client/_app/immutable/nodes/2.CCV1YdgF.js +1 -0
  469. package/web/.svelte-kit/output/client/_app/immutable/nodes/3.D9tDCdq8.js +1 -0
  470. package/web/.svelte-kit/output/client/_app/immutable/nodes/4.BqPyNkFA.js +6 -0
  471. package/web/.svelte-kit/output/client/_app/version.json +1 -0
  472. package/web/.svelte-kit/output/client/robots.txt +3 -0
  473. package/web/.svelte-kit/output/server/.vite/manifest.json +408 -0
  474. package/web/.svelte-kit/output/server/_app/immutable/assets/AllSessionsPanel.BKhqOrbV.css +1 -0
  475. package/web/.svelte-kit/output/server/_app/immutable/assets/_layout.WptSHSUl.css +1 -0
  476. package/web/.svelte-kit/output/server/_app/immutable/assets/_page.DldLgTc-.css +1 -0
  477. package/web/.svelte-kit/output/server/_app/immutable/assets/_page.DoNWy7tW.css +1 -0
  478. package/web/.svelte-kit/output/server/chunks/AllSessionsPanel.svelte_svelte_type_style_lang.js +49 -0
  479. package/web/.svelte-kit/output/server/chunks/alert-dialog-description.js +2670 -0
  480. package/web/.svelte-kit/output/server/chunks/auth.js +59 -0
  481. package/web/.svelte-kit/output/server/chunks/button.js +82 -0
  482. package/web/.svelte-kit/output/server/chunks/client.js +29 -0
  483. package/web/.svelte-kit/output/server/chunks/context.js +133 -0
  484. package/web/.svelte-kit/output/server/chunks/environment.js +34 -0
  485. package/web/.svelte-kit/output/server/chunks/events.js +121 -0
  486. package/web/.svelte-kit/output/server/chunks/exports.js +174 -0
  487. package/web/.svelte-kit/output/server/chunks/false.js +4 -0
  488. package/web/.svelte-kit/output/server/chunks/index.js +59 -0
  489. package/web/.svelte-kit/output/server/chunks/index2.js +2828 -0
  490. package/web/.svelte-kit/output/server/chunks/internal.js +920 -0
  491. package/web/.svelte-kit/output/server/chunks/pane.js +82 -0
  492. package/web/.svelte-kit/output/server/chunks/sessions-json.js +124 -0
  493. package/web/.svelte-kit/output/server/chunks/sessions.svelte.js +229 -0
  494. package/web/.svelte-kit/output/server/chunks/shared.js +542 -0
  495. package/web/.svelte-kit/output/server/chunks/state.svelte.js +16 -0
  496. package/web/.svelte-kit/output/server/chunks/utils.js +43 -0
  497. package/web/.svelte-kit/output/server/chunks/ws-handlers.js +782 -0
  498. package/web/.svelte-kit/output/server/entries/endpoints/api/auth/login/_server.ts.js +22 -0
  499. package/web/.svelte-kit/output/server/entries/endpoints/api/auth/logout/_server.ts.js +9 -0
  500. package/web/.svelte-kit/output/server/entries/endpoints/api/beads/_server.ts.js +22 -0
  501. package/web/.svelte-kit/output/server/entries/endpoints/api/browse/_server.ts.js +50 -0
  502. package/web/.svelte-kit/output/server/entries/endpoints/api/chrome/_server.ts.js +30 -0
  503. package/web/.svelte-kit/output/server/entries/endpoints/api/files/image/_server.ts.js +53 -0
  504. package/web/.svelte-kit/output/server/entries/endpoints/api/health/_server.ts.js +7 -0
  505. package/web/.svelte-kit/output/server/entries/endpoints/api/projects/new-session/_server.ts.js +44 -0
  506. package/web/.svelte-kit/output/server/entries/endpoints/api/sessions/_id_/_server.ts.js +20 -0
  507. package/web/.svelte-kit/output/server/entries/endpoints/api/sessions/_id_/kill/_server.ts.js +36 -0
  508. package/web/.svelte-kit/output/server/entries/endpoints/api/sessions/_id_/restart/_server.ts.js +40 -0
  509. package/web/.svelte-kit/output/server/entries/endpoints/api/sessions/_id_/screenshots/_server.ts.js +28 -0
  510. package/web/.svelte-kit/output/server/entries/endpoints/api/sessions/_id_/send/_server.ts.js +29 -0
  511. package/web/.svelte-kit/output/server/entries/endpoints/api/sessions/_server.ts.js +49 -0
  512. package/web/.svelte-kit/output/server/entries/endpoints/api/sessions/_target_/output/_server.ts.js +14 -0
  513. package/web/.svelte-kit/output/server/entries/endpoints/api/tmux/panes/_server.ts.js +21 -0
  514. package/web/.svelte-kit/output/server/entries/fallbacks/error.svelte.js +27 -0
  515. package/web/.svelte-kit/output/server/entries/hooks.server.js +105 -0
  516. package/web/.svelte-kit/output/server/entries/pages/_layout.svelte.js +499 -0
  517. package/web/.svelte-kit/output/server/entries/pages/_page.svelte.js +3057 -0
  518. package/web/.svelte-kit/output/server/entries/pages/login/_page.server.ts.js +15 -0
  519. package/web/.svelte-kit/output/server/entries/pages/login/_page.svelte.js +37 -0
  520. package/web/.svelte-kit/output/server/entries/pages/session/_target_/_page.svelte.js +653 -0
  521. package/web/.svelte-kit/output/server/index.js +3864 -0
  522. package/web/.svelte-kit/output/server/internal.js +13 -0
  523. package/web/.svelte-kit/output/server/manifest-full.js +167 -0
  524. package/web/.svelte-kit/output/server/manifest.js +167 -0
  525. package/web/.svelte-kit/output/server/nodes/0.js +8 -0
  526. package/web/.svelte-kit/output/server/nodes/1.js +8 -0
  527. package/web/.svelte-kit/output/server/nodes/2.js +8 -0
  528. package/web/.svelte-kit/output/server/nodes/3.js +10 -0
  529. package/web/.svelte-kit/output/server/nodes/4.js +8 -0
  530. package/web/.svelte-kit/output/server/remote-entry.js +541 -0
  531. package/web/.svelte-kit/tsconfig.json +58 -0
  532. package/web/.svelte-kit/types/route_meta_data.json +55 -0
  533. package/web/.svelte-kit/types/src/routes/$types.d.ts +24 -0
  534. package/web/.svelte-kit/types/src/routes/api/auth/login/$types.d.ts +10 -0
  535. package/web/.svelte-kit/types/src/routes/api/auth/logout/$types.d.ts +10 -0
  536. package/web/.svelte-kit/types/src/routes/api/beads/$types.d.ts +10 -0
  537. package/web/.svelte-kit/types/src/routes/api/browse/$types.d.ts +10 -0
  538. package/web/.svelte-kit/types/src/routes/api/chrome/$types.d.ts +10 -0
  539. package/web/.svelte-kit/types/src/routes/api/files/image/$types.d.ts +10 -0
  540. package/web/.svelte-kit/types/src/routes/api/health/$types.d.ts +10 -0
  541. package/web/.svelte-kit/types/src/routes/api/projects/new-session/$types.d.ts +10 -0
  542. package/web/.svelte-kit/types/src/routes/api/sessions/$types.d.ts +10 -0
  543. package/web/.svelte-kit/types/src/routes/api/sessions/[id]/$types.d.ts +11 -0
  544. package/web/.svelte-kit/types/src/routes/api/sessions/[id]/kill/$types.d.ts +11 -0
  545. package/web/.svelte-kit/types/src/routes/api/sessions/[id]/restart/$types.d.ts +11 -0
  546. package/web/.svelte-kit/types/src/routes/api/sessions/[id]/screenshots/$types.d.ts +11 -0
  547. package/web/.svelte-kit/types/src/routes/api/sessions/[id]/send/$types.d.ts +11 -0
  548. package/web/.svelte-kit/types/src/routes/api/sessions/[target]/output/$types.d.ts +11 -0
  549. package/web/.svelte-kit/types/src/routes/api/tmux/panes/$types.d.ts +10 -0
  550. package/web/.svelte-kit/types/src/routes/login/$types.d.ts +25 -0
  551. package/web/.svelte-kit/types/src/routes/login/proxy+page.server.ts +19 -0
  552. package/web/.svelte-kit/types/src/routes/session/[target]/$types.d.ts +19 -0
  553. package/web/README.md +42 -0
  554. package/web/components.json +16 -0
  555. package/web/package.json +35 -0
  556. package/web/src/app.css +128 -0
  557. package/web/src/app.d.ts +13 -0
  558. package/web/src/app.html +11 -0
  559. package/web/src/hooks.server.ts +156 -0
  560. package/web/src/lib/assets/favicon.svg +1 -0
  561. package/web/src/lib/components/AllSessionsPanel.svelte +789 -0
  562. package/web/src/lib/components/BeadsPanel.svelte +146 -0
  563. package/web/src/lib/components/IssueItem.svelte +287 -0
  564. package/web/src/lib/components/ScreenshotsPanel.svelte +336 -0
  565. package/web/src/lib/components/SessionsSidebar.svelte +312 -0
  566. package/web/src/lib/components/TerminalRenderer.svelte +189 -0
  567. package/web/src/lib/components/ui/alert-dialog/alert-dialog-action.svelte +18 -0
  568. package/web/src/lib/components/ui/alert-dialog/alert-dialog-cancel.svelte +18 -0
  569. package/web/src/lib/components/ui/alert-dialog/alert-dialog-content.svelte +29 -0
  570. package/web/src/lib/components/ui/alert-dialog/alert-dialog-description.svelte +17 -0
  571. package/web/src/lib/components/ui/alert-dialog/alert-dialog-footer.svelte +20 -0
  572. package/web/src/lib/components/ui/alert-dialog/alert-dialog-header.svelte +20 -0
  573. package/web/src/lib/components/ui/alert-dialog/alert-dialog-overlay.svelte +20 -0
  574. package/web/src/lib/components/ui/alert-dialog/alert-dialog-portal.svelte +7 -0
  575. package/web/src/lib/components/ui/alert-dialog/alert-dialog-title.svelte +17 -0
  576. package/web/src/lib/components/ui/alert-dialog/alert-dialog-trigger.svelte +7 -0
  577. package/web/src/lib/components/ui/alert-dialog/alert-dialog.svelte +7 -0
  578. package/web/src/lib/components/ui/alert-dialog/index.ts +37 -0
  579. package/web/src/lib/components/ui/badge/badge.svelte +50 -0
  580. package/web/src/lib/components/ui/badge/index.ts +2 -0
  581. package/web/src/lib/components/ui/button/button.svelte +86 -0
  582. package/web/src/lib/components/ui/button/index.ts +17 -0
  583. package/web/src/lib/components/ui/checkbox/checkbox.svelte +36 -0
  584. package/web/src/lib/components/ui/checkbox/index.ts +6 -0
  585. package/web/src/lib/components/ui/dialog/dialog-close.svelte +7 -0
  586. package/web/src/lib/components/ui/dialog/dialog-content.svelte +45 -0
  587. package/web/src/lib/components/ui/dialog/dialog-description.svelte +17 -0
  588. package/web/src/lib/components/ui/dialog/dialog-footer.svelte +20 -0
  589. package/web/src/lib/components/ui/dialog/dialog-header.svelte +20 -0
  590. package/web/src/lib/components/ui/dialog/dialog-overlay.svelte +20 -0
  591. package/web/src/lib/components/ui/dialog/dialog-portal.svelte +7 -0
  592. package/web/src/lib/components/ui/dialog/dialog-title.svelte +17 -0
  593. package/web/src/lib/components/ui/dialog/dialog-trigger.svelte +7 -0
  594. package/web/src/lib/components/ui/dialog/dialog.svelte +7 -0
  595. package/web/src/lib/components/ui/dialog/index.ts +34 -0
  596. package/web/src/lib/components/ui/scroll-area/index.ts +10 -0
  597. package/web/src/lib/components/ui/scroll-area/scroll-area-scrollbar.svelte +31 -0
  598. package/web/src/lib/components/ui/scroll-area/scroll-area.svelte +43 -0
  599. package/web/src/lib/components/ui/textarea/index.ts +7 -0
  600. package/web/src/lib/components/ui/textarea/textarea.svelte +23 -0
  601. package/web/src/lib/index.ts +1 -0
  602. package/web/src/lib/server/auth.ts +90 -0
  603. package/web/src/lib/stores/beads.svelte.ts +163 -0
  604. package/web/src/lib/stores/input-injection.svelte.ts +39 -0
  605. package/web/src/lib/stores/preferences.svelte.ts +55 -0
  606. package/web/src/lib/stores/sessions.svelte.ts +108 -0
  607. package/web/src/lib/stores/terminal.svelte.ts +96 -0
  608. package/web/src/lib/stores/websocket-base.svelte.ts +209 -0
  609. package/web/src/lib/types/terminal.ts +31 -0
  610. package/web/src/lib/utils/terminal-parser.ts +239 -0
  611. package/web/src/lib/utils.ts +13 -0
  612. package/web/src/routes/+layout.svelte +450 -0
  613. package/web/src/routes/+page.svelte +19 -0
  614. package/web/src/routes/api/auth/login/+server.ts +34 -0
  615. package/web/src/routes/api/auth/logout/+server.ts +10 -0
  616. package/web/src/routes/api/beads/+server.ts +28 -0
  617. package/web/src/routes/api/browse/+server.ts +59 -0
  618. package/web/src/routes/api/chrome/+server.ts +35 -0
  619. package/web/src/routes/api/files/image/+server.ts +64 -0
  620. package/web/src/routes/api/health/+server.ts +6 -0
  621. package/web/src/routes/api/projects/new-session/+server.ts +50 -0
  622. package/web/src/routes/api/sessions/+server.ts +62 -0
  623. package/web/src/routes/api/sessions/[id]/+server.ts +19 -0
  624. package/web/src/routes/api/sessions/[id]/kill/+server.ts +46 -0
  625. package/web/src/routes/api/sessions/[id]/restart/+server.ts +59 -0
  626. package/web/src/routes/api/sessions/[id]/screenshots/+server.ts +32 -0
  627. package/web/src/routes/api/sessions/[id]/send/+server.ts +31 -0
  628. package/web/src/routes/api/sessions/[target]/output/+server.ts +13 -0
  629. package/web/src/routes/api/tmux/panes/+server.ts +32 -0
  630. package/web/src/routes/login/+page.server.ts +18 -0
  631. package/web/src/routes/login/+page.svelte +69 -0
  632. package/web/src/routes/session/[target]/+page.svelte +450 -0
  633. package/web/static/robots.txt +3 -0
  634. package/web/svelte.config.js +20 -0
  635. package/web/tsconfig.json +20 -0
  636. package/web/vite.config.ts +154 -0
@@ -0,0 +1,2722 @@
1
+ import { M as element, N as ensure_array_like, Z as props_id, _ as attr_class, b as bind_props, dt as stringify, g as attr, k as derived, lt as spread_props, pt as unsubscribe_stores, ut as store_get, v as attr_style, w as clsx, y as attributes, z as head } from "./index2-BQnysSj-.js";
2
+ import { d as get_prototype_of, h as is_array, s as escape_html, v as object_prototype } from "./clsx-FzI4_gi0.js";
3
+ import "./chunks-DmdqVYC7.js";
4
+ import { r as on } from "./events-BDBlYddw.js";
5
+ import "./state.svelte-xeAZvWZ6.js";
6
+ import { t as goto } from "./client-CUrSQijh.js";
7
+ import { a as page, n as getProjectColor, o as sessionStore, s as stateColor } from "./sessions.svelte-Ds82MvkB.js";
8
+ import { r as cn, t as Button } from "./button-D6xS9rHt.js";
9
+ import { t as Badge } from "./AllSessionsPanel.svelte_svelte_type_style_lang-Bt4B0-oi.js";
10
+ import { A as executeCallbacks, C as Text_selection_layer, D as boxWith, E as boolToStr, F as simpleBox, I as styleToString, L as useId, M as isHTMLElement, N as mergeProps, O as createBitsAttrs, P as noop, R as watch, S as Scroll_lock, T as boolToEmptyStrOrUndef, _ as ENTER, a as Alert_dialog_description, b as Portal, c as Alert_dialog_title, d as DialogCloseState, f as DialogContentState, g as Dismissible_layer, h as Dialog_title$1, i as Alert_dialog_content, j as getAriaChecked, k as createId, l as Context, m as Dialog_overlay$1, n as Alert_dialog_action, o as Alert_dialog_footer, p as DialogRootState, r as Alert_dialog_cancel, s as Alert_dialog_header, t as Alert_dialog, u as DOMContext, v as Escape_layer, w as attachRef, x as SPACE, y as Focus_scope } from "./alert-dialog-description-DDA6u-nS.js";
11
+
12
+ //#region .svelte-kit/adapter-bun/entries/pages/_page.svelte.js
13
+ const empty = [];
14
+ function snapshot(value, skip_warning = false, no_tojson = false) {
15
+ return clone(value, /* @__PURE__ */ new Map(), "", empty, null, no_tojson);
16
+ }
17
+ function clone(value, cloned, path, paths, original = null, no_tojson = false) {
18
+ if (typeof value === "object" && value !== null) {
19
+ var unwrapped = cloned.get(value);
20
+ if (unwrapped !== void 0) return unwrapped;
21
+ if (value instanceof Map) return new Map(value);
22
+ if (value instanceof Set) return new Set(value);
23
+ if (is_array(value)) {
24
+ var copy = Array(value.length);
25
+ cloned.set(value, copy);
26
+ if (original !== null) cloned.set(original, copy);
27
+ for (var i = 0; i < value.length; i += 1) {
28
+ var element2 = value[i];
29
+ if (i in value) copy[i] = clone(element2, cloned, path, paths, null, no_tojson);
30
+ }
31
+ return copy;
32
+ }
33
+ if (get_prototype_of(value) === object_prototype) {
34
+ copy = {};
35
+ cloned.set(value, copy);
36
+ if (original !== null) cloned.set(original, copy);
37
+ for (var key in value) copy[key] = clone(value[key], cloned, path, paths, null, no_tojson);
38
+ return copy;
39
+ }
40
+ if (value instanceof Date) return structuredClone(value);
41
+ if (typeof value.toJSON === "function" && !no_tojson) return clone(
42
+ /** @type {T & { toJSON(): any } } */
43
+ value.toJSON(),
44
+ cloned,
45
+ path,
46
+ paths,
47
+ value
48
+ );
49
+ }
50
+ if (value instanceof EventTarget) return value;
51
+ try {
52
+ return structuredClone(value);
53
+ } catch (e) {
54
+ return value;
55
+ }
56
+ }
57
+ const srOnlyStylesString = styleToString({
58
+ position: "absolute",
59
+ width: "1px",
60
+ height: "1px",
61
+ padding: "0",
62
+ margin: "-1px",
63
+ overflow: "hidden",
64
+ clip: "rect(0, 0, 0, 0)",
65
+ whiteSpace: "nowrap",
66
+ borderWidth: "0",
67
+ transform: "translateX(-100%)"
68
+ });
69
+ function isFunction(value) {
70
+ return typeof value === "function";
71
+ }
72
+ function extract(value, defaultValue) {
73
+ if (isFunction(value)) {
74
+ const gotten = value();
75
+ if (gotten === void 0) return defaultValue;
76
+ return gotten;
77
+ }
78
+ if (value === void 0) return defaultValue;
79
+ return value;
80
+ }
81
+ function useDebounce(callback, wait) {
82
+ let context = null;
83
+ const wait$ = extract(wait, 250);
84
+ function debounced(...args) {
85
+ if (context) {
86
+ if (context.timeout) clearTimeout(context.timeout);
87
+ } else {
88
+ let resolve;
89
+ let reject;
90
+ context = {
91
+ timeout: null,
92
+ runner: null,
93
+ promise: new Promise((res, rej) => {
94
+ resolve = res;
95
+ reject = rej;
96
+ }),
97
+ resolve,
98
+ reject
99
+ };
100
+ }
101
+ context.runner = async () => {
102
+ if (!context) return;
103
+ const ctx = context;
104
+ context = null;
105
+ try {
106
+ ctx.resolve(await callback.apply(this, args));
107
+ } catch (error) {
108
+ ctx.reject(error);
109
+ }
110
+ };
111
+ context.timeout = setTimeout(context.runner, wait$);
112
+ return context.promise;
113
+ }
114
+ debounced.cancel = async () => {
115
+ if (!context || context.timeout === null) {
116
+ await new Promise((resolve) => setTimeout(resolve, 0));
117
+ if (!context || context.timeout === null) return;
118
+ }
119
+ clearTimeout(context.timeout);
120
+ context.reject("Cancelled");
121
+ context = null;
122
+ };
123
+ debounced.runScheduledNow = async () => {
124
+ if (!context || !context.timeout) {
125
+ await new Promise((resolve) => setTimeout(resolve, 0));
126
+ if (!context || !context.timeout) return;
127
+ }
128
+ clearTimeout(context.timeout);
129
+ context.timeout = null;
130
+ await context.runner?.();
131
+ };
132
+ Object.defineProperty(debounced, "pending", {
133
+ enumerable: true,
134
+ get() {
135
+ return !!context?.timeout;
136
+ }
137
+ });
138
+ return debounced;
139
+ }
140
+ var IsMounted = class {
141
+ #isMounted = false;
142
+ constructor() {}
143
+ get current() {
144
+ return this.#isMounted;
145
+ }
146
+ };
147
+ var Previous = class {
148
+ #previousCallback = () => void 0;
149
+ #previous = derived(() => this.#previousCallback());
150
+ constructor(getter, initialValue) {
151
+ let actualPrevious = void 0;
152
+ if (initialValue !== void 0) actualPrevious = initialValue;
153
+ this.#previousCallback = () => {
154
+ try {
155
+ return actualPrevious;
156
+ } finally {
157
+ actualPrevious = getter();
158
+ }
159
+ };
160
+ }
161
+ get current() {
162
+ return this.#previous();
163
+ }
164
+ };
165
+ const checkboxAttrs = createBitsAttrs({
166
+ component: "checkbox",
167
+ parts: [
168
+ "root",
169
+ "group",
170
+ "group-label",
171
+ "input"
172
+ ]
173
+ });
174
+ const CheckboxGroupContext = new Context("Checkbox.Group");
175
+ const CheckboxRootContext = new Context("Checkbox.Root");
176
+ var CheckboxRootState = class CheckboxRootState {
177
+ static create(opts, group = null) {
178
+ return CheckboxRootContext.set(new CheckboxRootState(opts, group));
179
+ }
180
+ opts;
181
+ group;
182
+ #trueName = derived(() => {
183
+ if (this.group && this.group.opts.name.current) return this.group.opts.name.current;
184
+ return this.opts.name.current;
185
+ });
186
+ get trueName() {
187
+ return this.#trueName();
188
+ }
189
+ set trueName($$value) {
190
+ return this.#trueName($$value);
191
+ }
192
+ #trueRequired = derived(() => {
193
+ if (this.group && this.group.opts.required.current) return true;
194
+ return this.opts.required.current;
195
+ });
196
+ get trueRequired() {
197
+ return this.#trueRequired();
198
+ }
199
+ set trueRequired($$value) {
200
+ return this.#trueRequired($$value);
201
+ }
202
+ #trueDisabled = derived(() => {
203
+ if (this.group && this.group.opts.disabled.current) return true;
204
+ return this.opts.disabled.current;
205
+ });
206
+ get trueDisabled() {
207
+ return this.#trueDisabled();
208
+ }
209
+ set trueDisabled($$value) {
210
+ return this.#trueDisabled($$value);
211
+ }
212
+ #trueReadonly = derived(() => {
213
+ if (this.group && this.group.opts.readonly.current) return true;
214
+ return this.opts.readonly.current;
215
+ });
216
+ get trueReadonly() {
217
+ return this.#trueReadonly();
218
+ }
219
+ set trueReadonly($$value) {
220
+ return this.#trueReadonly($$value);
221
+ }
222
+ attachment;
223
+ constructor(opts, group) {
224
+ this.opts = opts;
225
+ this.group = group;
226
+ this.attachment = attachRef(this.opts.ref);
227
+ this.onkeydown = this.onkeydown.bind(this);
228
+ this.onclick = this.onclick.bind(this);
229
+ watch.pre([() => snapshot(this.group?.opts.value.current), () => this.opts.value.current], ([groupValue, value]) => {
230
+ if (!groupValue || !value) return;
231
+ this.opts.checked.current = groupValue.includes(value);
232
+ });
233
+ watch.pre(() => this.opts.checked.current, (checked) => {
234
+ if (!this.group) return;
235
+ if (checked) this.group?.addValue(this.opts.value.current);
236
+ else this.group?.removeValue(this.opts.value.current);
237
+ });
238
+ }
239
+ onkeydown(e) {
240
+ if (this.trueDisabled || this.trueReadonly) return;
241
+ if (e.key === ENTER) {
242
+ e.preventDefault();
243
+ if (this.opts.type.current === "submit") e.currentTarget.closest("form")?.requestSubmit();
244
+ return;
245
+ }
246
+ if (e.key === SPACE) {
247
+ e.preventDefault();
248
+ this.#toggle();
249
+ }
250
+ }
251
+ #toggle() {
252
+ if (this.opts.indeterminate.current) {
253
+ this.opts.indeterminate.current = false;
254
+ this.opts.checked.current = true;
255
+ } else this.opts.checked.current = !this.opts.checked.current;
256
+ }
257
+ onclick(e) {
258
+ if (this.trueDisabled || this.trueReadonly) return;
259
+ if (this.opts.type.current === "submit") {
260
+ this.#toggle();
261
+ return;
262
+ }
263
+ e.preventDefault();
264
+ this.#toggle();
265
+ }
266
+ #snippetProps = derived(() => ({
267
+ checked: this.opts.checked.current,
268
+ indeterminate: this.opts.indeterminate.current
269
+ }));
270
+ get snippetProps() {
271
+ return this.#snippetProps();
272
+ }
273
+ set snippetProps($$value) {
274
+ return this.#snippetProps($$value);
275
+ }
276
+ #props = derived(() => ({
277
+ id: this.opts.id.current,
278
+ role: "checkbox",
279
+ type: this.opts.type.current,
280
+ disabled: this.trueDisabled,
281
+ "aria-checked": getAriaChecked(this.opts.checked.current, this.opts.indeterminate.current),
282
+ "aria-required": boolToStr(this.trueRequired),
283
+ "aria-readonly": boolToStr(this.trueReadonly),
284
+ "data-disabled": boolToEmptyStrOrUndef(this.trueDisabled),
285
+ "data-readonly": boolToEmptyStrOrUndef(this.trueReadonly),
286
+ "data-state": getCheckboxDataState(this.opts.checked.current, this.opts.indeterminate.current),
287
+ [checkboxAttrs.root]: "",
288
+ onclick: this.onclick,
289
+ onkeydown: this.onkeydown,
290
+ ...this.attachment
291
+ }));
292
+ get props() {
293
+ return this.#props();
294
+ }
295
+ set props($$value) {
296
+ return this.#props($$value);
297
+ }
298
+ };
299
+ var CheckboxInputState = class CheckboxInputState {
300
+ static create() {
301
+ return new CheckboxInputState(CheckboxRootContext.get());
302
+ }
303
+ root;
304
+ #trueChecked = derived(() => {
305
+ if (!this.root.group) return this.root.opts.checked.current;
306
+ if (this.root.opts.value.current !== void 0 && this.root.group.opts.value.current.includes(this.root.opts.value.current)) return true;
307
+ return false;
308
+ });
309
+ get trueChecked() {
310
+ return this.#trueChecked();
311
+ }
312
+ set trueChecked($$value) {
313
+ return this.#trueChecked($$value);
314
+ }
315
+ #shouldRender = derived(() => Boolean(this.root.trueName));
316
+ get shouldRender() {
317
+ return this.#shouldRender();
318
+ }
319
+ set shouldRender($$value) {
320
+ return this.#shouldRender($$value);
321
+ }
322
+ constructor(root) {
323
+ this.root = root;
324
+ this.onfocus = this.onfocus.bind(this);
325
+ }
326
+ onfocus(_) {
327
+ if (!isHTMLElement(this.root.opts.ref.current)) return;
328
+ this.root.opts.ref.current.focus();
329
+ }
330
+ #props = derived(() => ({
331
+ type: "checkbox",
332
+ checked: this.root.opts.checked.current === true,
333
+ disabled: this.root.trueDisabled,
334
+ required: this.root.trueRequired,
335
+ name: this.root.trueName,
336
+ value: this.root.opts.value.current,
337
+ readonly: this.root.trueReadonly,
338
+ onfocus: this.onfocus
339
+ }));
340
+ get props() {
341
+ return this.#props();
342
+ }
343
+ set props($$value) {
344
+ return this.#props($$value);
345
+ }
346
+ };
347
+ function getCheckboxDataState(checked, indeterminate) {
348
+ if (indeterminate) return "indeterminate";
349
+ return checked ? "checked" : "unchecked";
350
+ }
351
+ function Hidden_input($$renderer, $$props) {
352
+ $$renderer.component(($$renderer2) => {
353
+ let { value = void 0, $$slots, $$events, ...restProps } = $$props;
354
+ const mergedProps = mergeProps(restProps, {
355
+ "aria-hidden": "true",
356
+ tabindex: -1,
357
+ style: srOnlyStylesString
358
+ });
359
+ if (mergedProps.type === "checkbox") {
360
+ $$renderer2.push("<!--[-->");
361
+ $$renderer2.push(`<input${attributes({
362
+ ...mergedProps,
363
+ value
364
+ }, void 0, void 0, void 0, 4)}/>`);
365
+ } else {
366
+ $$renderer2.push("<!--[!-->");
367
+ $$renderer2.push(`<input${attributes({
368
+ value,
369
+ ...mergedProps
370
+ }, void 0, void 0, void 0, 4)}/>`);
371
+ }
372
+ $$renderer2.push(`<!--]-->`);
373
+ bind_props($$props, { value });
374
+ });
375
+ }
376
+ function Checkbox_input($$renderer, $$props) {
377
+ $$renderer.component(($$renderer2) => {
378
+ const inputState = CheckboxInputState.create();
379
+ if (inputState.shouldRender) {
380
+ $$renderer2.push("<!--[-->");
381
+ Hidden_input($$renderer2, spread_props([inputState.props]));
382
+ } else $$renderer2.push("<!--[!-->");
383
+ $$renderer2.push(`<!--]-->`);
384
+ });
385
+ }
386
+ function Checkbox$1($$renderer, $$props) {
387
+ $$renderer.component(($$renderer2) => {
388
+ const uid = props_id($$renderer2);
389
+ let { checked = false, ref = null, onCheckedChange, children, disabled = false, required = false, name = void 0, value = "on", id = createId(uid), indeterminate = false, onIndeterminateChange, child, type = "button", readonly, $$slots, $$events, ...restProps } = $$props;
390
+ const group = CheckboxGroupContext.getOr(null);
391
+ if (group && value) if (group.opts.value.current.includes(value)) checked = true;
392
+ else checked = false;
393
+ watch.pre(() => value, () => {
394
+ if (group && value) if (group.opts.value.current.includes(value)) checked = true;
395
+ else checked = false;
396
+ });
397
+ const rootState = CheckboxRootState.create({
398
+ checked: boxWith(() => checked, (v) => {
399
+ checked = v;
400
+ onCheckedChange?.(v);
401
+ }),
402
+ disabled: boxWith(() => disabled ?? false),
403
+ required: boxWith(() => required),
404
+ name: boxWith(() => name),
405
+ value: boxWith(() => value),
406
+ id: boxWith(() => id),
407
+ ref: boxWith(() => ref, (v) => ref = v),
408
+ indeterminate: boxWith(() => indeterminate, (v) => {
409
+ indeterminate = v;
410
+ onIndeterminateChange?.(v);
411
+ }),
412
+ type: boxWith(() => type),
413
+ readonly: boxWith(() => Boolean(readonly))
414
+ }, group);
415
+ const mergedProps = mergeProps({ ...restProps }, rootState.props);
416
+ if (child) {
417
+ $$renderer2.push("<!--[-->");
418
+ child($$renderer2, {
419
+ props: mergedProps,
420
+ ...rootState.snippetProps
421
+ });
422
+ $$renderer2.push(`<!---->`);
423
+ } else {
424
+ $$renderer2.push("<!--[!-->");
425
+ $$renderer2.push(`<button${attributes({ ...mergedProps })}>`);
426
+ children?.($$renderer2, rootState.snippetProps);
427
+ $$renderer2.push(`<!----></button>`);
428
+ }
429
+ $$renderer2.push(`<!--]--> `);
430
+ Checkbox_input($$renderer2);
431
+ $$renderer2.push(`<!---->`);
432
+ bind_props($$props, {
433
+ checked,
434
+ ref,
435
+ indeterminate
436
+ });
437
+ });
438
+ }
439
+ function Dialog$1($$renderer, $$props) {
440
+ $$renderer.component(($$renderer2) => {
441
+ let { open = false, onOpenChange = noop, onOpenChangeComplete = noop, children } = $$props;
442
+ DialogRootState.create({
443
+ variant: boxWith(() => "dialog"),
444
+ open: boxWith(() => open, (v) => {
445
+ open = v;
446
+ onOpenChange(v);
447
+ }),
448
+ onOpenChangeComplete: boxWith(() => onOpenChangeComplete)
449
+ });
450
+ children?.($$renderer2);
451
+ $$renderer2.push(`<!---->`);
452
+ bind_props($$props, { open });
453
+ });
454
+ }
455
+ function Dialog_close($$renderer, $$props) {
456
+ $$renderer.component(($$renderer2) => {
457
+ const uid = props_id($$renderer2);
458
+ let { children, child, id = createId(uid), ref = null, disabled = false, $$slots, $$events, ...restProps } = $$props;
459
+ const mergedProps = mergeProps(restProps, DialogCloseState.create({
460
+ variant: boxWith(() => "close"),
461
+ id: boxWith(() => id),
462
+ ref: boxWith(() => ref, (v) => ref = v),
463
+ disabled: boxWith(() => Boolean(disabled))
464
+ }).props);
465
+ if (child) {
466
+ $$renderer2.push("<!--[-->");
467
+ child($$renderer2, { props: mergedProps });
468
+ $$renderer2.push(`<!---->`);
469
+ } else {
470
+ $$renderer2.push("<!--[!-->");
471
+ $$renderer2.push(`<button${attributes({ ...mergedProps })}>`);
472
+ children?.($$renderer2);
473
+ $$renderer2.push(`<!----></button>`);
474
+ }
475
+ $$renderer2.push(`<!--]-->`);
476
+ bind_props($$props, { ref });
477
+ });
478
+ }
479
+ function Dialog_content$1($$renderer, $$props) {
480
+ $$renderer.component(($$renderer2) => {
481
+ const uid = props_id($$renderer2);
482
+ let { id = createId(uid), children, child, ref = null, forceMount = false, onCloseAutoFocus = noop, onOpenAutoFocus = noop, onEscapeKeydown = noop, onInteractOutside = noop, trapFocus = true, preventScroll = true, restoreScrollDelay = null, $$slots, $$events, ...restProps } = $$props;
483
+ const contentState = DialogContentState.create({
484
+ id: boxWith(() => id),
485
+ ref: boxWith(() => ref, (v) => ref = v)
486
+ });
487
+ const mergedProps = mergeProps(restProps, contentState.props);
488
+ if (contentState.shouldRender || forceMount) {
489
+ $$renderer2.push("<!--[-->");
490
+ {
491
+ let focusScope = function($$renderer3, { props: focusScopeProps }) {
492
+ Escape_layer($$renderer3, spread_props([mergedProps, {
493
+ enabled: contentState.root.opts.open.current,
494
+ ref: contentState.opts.ref,
495
+ onEscapeKeydown: (e) => {
496
+ onEscapeKeydown(e);
497
+ if (e.defaultPrevented) return;
498
+ contentState.root.handleClose();
499
+ },
500
+ children: ($$renderer4) => {
501
+ Dismissible_layer($$renderer4, spread_props([mergedProps, {
502
+ ref: contentState.opts.ref,
503
+ enabled: contentState.root.opts.open.current,
504
+ onInteractOutside: (e) => {
505
+ onInteractOutside(e);
506
+ if (e.defaultPrevented) return;
507
+ contentState.root.handleClose();
508
+ },
509
+ children: ($$renderer5) => {
510
+ Text_selection_layer($$renderer5, spread_props([mergedProps, {
511
+ ref: contentState.opts.ref,
512
+ enabled: contentState.root.opts.open.current,
513
+ children: ($$renderer6) => {
514
+ if (child) {
515
+ $$renderer6.push("<!--[-->");
516
+ if (contentState.root.opts.open.current) {
517
+ $$renderer6.push("<!--[-->");
518
+ Scroll_lock($$renderer6, {
519
+ preventScroll,
520
+ restoreScrollDelay
521
+ });
522
+ } else $$renderer6.push("<!--[!-->");
523
+ $$renderer6.push(`<!--]--> `);
524
+ child($$renderer6, {
525
+ props: mergeProps(mergedProps, focusScopeProps),
526
+ ...contentState.snippetProps
527
+ });
528
+ $$renderer6.push(`<!---->`);
529
+ } else {
530
+ $$renderer6.push("<!--[!-->");
531
+ Scroll_lock($$renderer6, { preventScroll });
532
+ $$renderer6.push(`<!----> <div${attributes({ ...mergeProps(mergedProps, focusScopeProps) })}>`);
533
+ children?.($$renderer6);
534
+ $$renderer6.push(`<!----></div>`);
535
+ }
536
+ $$renderer6.push(`<!--]-->`);
537
+ },
538
+ $$slots: { default: true }
539
+ }]));
540
+ },
541
+ $$slots: { default: true }
542
+ }]));
543
+ },
544
+ $$slots: { default: true }
545
+ }]));
546
+ };
547
+ Focus_scope($$renderer2, {
548
+ ref: contentState.opts.ref,
549
+ loop: true,
550
+ trapFocus,
551
+ enabled: contentState.root.opts.open.current,
552
+ onOpenAutoFocus,
553
+ onCloseAutoFocus,
554
+ focusScope
555
+ });
556
+ }
557
+ } else $$renderer2.push("<!--[!-->");
558
+ $$renderer2.push(`<!--]-->`);
559
+ bind_props($$props, { ref });
560
+ });
561
+ }
562
+ var SvelteResizeObserver = class {
563
+ #node;
564
+ #onResize;
565
+ constructor(node, onResize) {
566
+ this.#node = node;
567
+ this.#onResize = onResize;
568
+ this.handler = this.handler.bind(this);
569
+ }
570
+ handler() {
571
+ let rAF = 0;
572
+ const _node = this.#node();
573
+ if (!_node) return;
574
+ const resizeObserver = new ResizeObserver(() => {
575
+ cancelAnimationFrame(rAF);
576
+ rAF = window.requestAnimationFrame(this.#onResize);
577
+ });
578
+ resizeObserver.observe(_node);
579
+ return () => {
580
+ window.cancelAnimationFrame(rAF);
581
+ resizeObserver.unobserve(_node);
582
+ };
583
+ }
584
+ };
585
+ var StateMachine = class {
586
+ state;
587
+ #machine;
588
+ constructor(initialState, machine) {
589
+ this.state = simpleBox(initialState);
590
+ this.#machine = machine;
591
+ this.dispatch = this.dispatch.bind(this);
592
+ }
593
+ #reducer(event) {
594
+ return this.#machine[this.state.current][event] ?? this.state.current;
595
+ }
596
+ dispatch(event) {
597
+ this.state.current = this.#reducer(event);
598
+ }
599
+ };
600
+ const presenceMachine = {
601
+ mounted: {
602
+ UNMOUNT: "unmounted",
603
+ ANIMATION_OUT: "unmountSuspended"
604
+ },
605
+ unmountSuspended: {
606
+ MOUNT: "mounted",
607
+ ANIMATION_END: "unmounted"
608
+ },
609
+ unmounted: { MOUNT: "mounted" }
610
+ };
611
+ var Presence = class {
612
+ opts;
613
+ prevAnimationNameState = "none";
614
+ styles = {};
615
+ initialStatus;
616
+ previousPresent;
617
+ machine;
618
+ present;
619
+ constructor(opts) {
620
+ this.opts = opts;
621
+ this.present = this.opts.open;
622
+ this.initialStatus = opts.open.current ? "mounted" : "unmounted";
623
+ this.previousPresent = new Previous(() => this.present.current);
624
+ this.machine = new StateMachine(this.initialStatus, presenceMachine);
625
+ this.handleAnimationEnd = this.handleAnimationEnd.bind(this);
626
+ this.handleAnimationStart = this.handleAnimationStart.bind(this);
627
+ watchPresenceChange(this);
628
+ watchStatusChange(this);
629
+ watchRefChange(this);
630
+ }
631
+ /**
632
+ * Triggering an ANIMATION_OUT during an ANIMATION_IN will fire an `animationcancel`
633
+ * event for ANIMATION_IN after we have entered `unmountSuspended` state. So, we
634
+ * make sure we only trigger ANIMATION_END for the currently active animation.
635
+ */
636
+ handleAnimationEnd(event) {
637
+ if (!this.opts.ref.current) return;
638
+ const currAnimationName = getAnimationName(this.opts.ref.current);
639
+ const isCurrentAnimation = currAnimationName.includes(event.animationName) || currAnimationName === "none";
640
+ if (event.target === this.opts.ref.current && isCurrentAnimation) this.machine.dispatch("ANIMATION_END");
641
+ }
642
+ handleAnimationStart(event) {
643
+ if (!this.opts.ref.current) return;
644
+ if (event.target === this.opts.ref.current) this.prevAnimationNameState = getAnimationName(this.opts.ref.current);
645
+ }
646
+ #isPresent = derived(() => {
647
+ return ["mounted", "unmountSuspended"].includes(this.machine.state.current);
648
+ });
649
+ get isPresent() {
650
+ return this.#isPresent();
651
+ }
652
+ set isPresent($$value) {
653
+ return this.#isPresent($$value);
654
+ }
655
+ };
656
+ function watchPresenceChange(state) {
657
+ watch(() => state.present.current, () => {
658
+ if (!state.opts.ref.current) return;
659
+ if (!(state.present.current !== state.previousPresent.current)) return;
660
+ const prevAnimationName = state.prevAnimationNameState;
661
+ const currAnimationName = getAnimationName(state.opts.ref.current);
662
+ if (state.present.current) state.machine.dispatch("MOUNT");
663
+ else if (currAnimationName === "none" || state.styles.display === "none") state.machine.dispatch("UNMOUNT");
664
+ else {
665
+ const isAnimating = prevAnimationName !== currAnimationName;
666
+ if (state.previousPresent.current && isAnimating) state.machine.dispatch("ANIMATION_OUT");
667
+ else state.machine.dispatch("UNMOUNT");
668
+ }
669
+ });
670
+ }
671
+ function watchStatusChange(state) {
672
+ watch(() => state.machine.state.current, () => {
673
+ if (!state.opts.ref.current) return;
674
+ const currAnimationName = getAnimationName(state.opts.ref.current);
675
+ state.prevAnimationNameState = state.machine.state.current === "mounted" ? currAnimationName : "none";
676
+ });
677
+ }
678
+ function watchRefChange(state) {
679
+ watch(() => state.opts.ref.current, () => {
680
+ if (!state.opts.ref.current) return;
681
+ state.styles = getComputedStyle(state.opts.ref.current);
682
+ return executeCallbacks(on(state.opts.ref.current, "animationstart", state.handleAnimationStart), on(state.opts.ref.current, "animationcancel", state.handleAnimationEnd), on(state.opts.ref.current, "animationend", state.handleAnimationEnd));
683
+ });
684
+ }
685
+ function getAnimationName(node) {
686
+ return node ? getComputedStyle(node).animationName || "none" : "none";
687
+ }
688
+ function Presence_layer($$renderer, $$props) {
689
+ $$renderer.component(($$renderer2) => {
690
+ let { open, forceMount, presence, ref } = $$props;
691
+ const presenceState = new Presence({
692
+ open: boxWith(() => open),
693
+ ref
694
+ });
695
+ if (forceMount || open || presenceState.isPresent) {
696
+ $$renderer2.push("<!--[-->");
697
+ presence?.($$renderer2, { present: presenceState.isPresent });
698
+ $$renderer2.push(`<!---->`);
699
+ } else $$renderer2.push("<!--[!-->");
700
+ $$renderer2.push(`<!--]-->`);
701
+ });
702
+ }
703
+ function clamp(n, min, max) {
704
+ return Math.min(max, Math.max(min, n));
705
+ }
706
+ const scrollAreaAttrs = createBitsAttrs({
707
+ component: "scroll-area",
708
+ parts: [
709
+ "root",
710
+ "viewport",
711
+ "corner",
712
+ "thumb",
713
+ "scrollbar"
714
+ ]
715
+ });
716
+ const ScrollAreaRootContext = new Context("ScrollArea.Root");
717
+ const ScrollAreaScrollbarContext = new Context("ScrollArea.Scrollbar");
718
+ const ScrollAreaScrollbarVisibleContext = new Context("ScrollArea.ScrollbarVisible");
719
+ const ScrollAreaScrollbarAxisContext = new Context("ScrollArea.ScrollbarAxis");
720
+ const ScrollAreaScrollbarSharedContext = new Context("ScrollArea.ScrollbarShared");
721
+ var ScrollAreaRootState = class ScrollAreaRootState {
722
+ static create(opts) {
723
+ return ScrollAreaRootContext.set(new ScrollAreaRootState(opts));
724
+ }
725
+ opts;
726
+ attachment;
727
+ scrollAreaNode = null;
728
+ viewportNode = null;
729
+ contentNode = null;
730
+ scrollbarXNode = null;
731
+ scrollbarYNode = null;
732
+ cornerWidth = 0;
733
+ cornerHeight = 0;
734
+ scrollbarXEnabled = false;
735
+ scrollbarYEnabled = false;
736
+ domContext;
737
+ constructor(opts) {
738
+ this.opts = opts;
739
+ this.attachment = attachRef(opts.ref, (v) => this.scrollAreaNode = v);
740
+ this.domContext = new DOMContext(opts.ref);
741
+ }
742
+ #props = derived(() => ({
743
+ id: this.opts.id.current,
744
+ dir: this.opts.dir.current,
745
+ style: {
746
+ position: "relative",
747
+ "--bits-scroll-area-corner-height": `${this.cornerHeight}px`,
748
+ "--bits-scroll-area-corner-width": `${this.cornerWidth}px`
749
+ },
750
+ [scrollAreaAttrs.root]: "",
751
+ ...this.attachment
752
+ }));
753
+ get props() {
754
+ return this.#props();
755
+ }
756
+ set props($$value) {
757
+ return this.#props($$value);
758
+ }
759
+ };
760
+ var ScrollAreaViewportState = class ScrollAreaViewportState {
761
+ static create(opts) {
762
+ return new ScrollAreaViewportState(opts, ScrollAreaRootContext.get());
763
+ }
764
+ opts;
765
+ root;
766
+ attachment;
767
+ #contentId = simpleBox(useId());
768
+ #contentRef = simpleBox(null);
769
+ contentAttachment = attachRef(this.#contentRef, (v) => this.root.contentNode = v);
770
+ constructor(opts, root) {
771
+ this.opts = opts;
772
+ this.root = root;
773
+ this.attachment = attachRef(opts.ref, (v) => this.root.viewportNode = v);
774
+ }
775
+ #props = derived(() => ({
776
+ id: this.opts.id.current,
777
+ style: {
778
+ overflowX: this.root.scrollbarXEnabled ? "scroll" : "hidden",
779
+ overflowY: this.root.scrollbarYEnabled ? "scroll" : "hidden"
780
+ },
781
+ [scrollAreaAttrs.viewport]: "",
782
+ ...this.attachment
783
+ }));
784
+ get props() {
785
+ return this.#props();
786
+ }
787
+ set props($$value) {
788
+ return this.#props($$value);
789
+ }
790
+ #contentProps = derived(() => ({
791
+ id: this.#contentId.current,
792
+ "data-scroll-area-content": "",
793
+ style: { minWidth: this.root.scrollbarXEnabled ? "fit-content" : void 0 },
794
+ ...this.contentAttachment
795
+ }));
796
+ get contentProps() {
797
+ return this.#contentProps();
798
+ }
799
+ set contentProps($$value) {
800
+ return this.#contentProps($$value);
801
+ }
802
+ };
803
+ var ScrollAreaScrollbarState = class ScrollAreaScrollbarState {
804
+ static create(opts) {
805
+ return ScrollAreaScrollbarContext.set(new ScrollAreaScrollbarState(opts, ScrollAreaRootContext.get()));
806
+ }
807
+ opts;
808
+ root;
809
+ #isHorizontal = derived(() => this.opts.orientation.current === "horizontal");
810
+ get isHorizontal() {
811
+ return this.#isHorizontal();
812
+ }
813
+ set isHorizontal($$value) {
814
+ return this.#isHorizontal($$value);
815
+ }
816
+ hasThumb = false;
817
+ constructor(opts, root) {
818
+ this.opts = opts;
819
+ this.root = root;
820
+ watch(() => this.isHorizontal, (isHorizontal) => {
821
+ if (isHorizontal) {
822
+ this.root.scrollbarXEnabled = true;
823
+ return () => {
824
+ this.root.scrollbarXEnabled = false;
825
+ };
826
+ } else {
827
+ this.root.scrollbarYEnabled = true;
828
+ return () => {
829
+ this.root.scrollbarYEnabled = false;
830
+ };
831
+ }
832
+ });
833
+ }
834
+ };
835
+ var ScrollAreaScrollbarHoverState = class ScrollAreaScrollbarHoverState {
836
+ static create() {
837
+ return new ScrollAreaScrollbarHoverState(ScrollAreaScrollbarContext.get());
838
+ }
839
+ scrollbar;
840
+ root;
841
+ isVisible = false;
842
+ constructor(scrollbar) {
843
+ this.scrollbar = scrollbar;
844
+ this.root = scrollbar.root;
845
+ }
846
+ #props = derived(() => ({ "data-state": this.isVisible ? "visible" : "hidden" }));
847
+ get props() {
848
+ return this.#props();
849
+ }
850
+ set props($$value) {
851
+ return this.#props($$value);
852
+ }
853
+ };
854
+ var ScrollAreaScrollbarScrollState = class ScrollAreaScrollbarScrollState {
855
+ static create() {
856
+ return new ScrollAreaScrollbarScrollState(ScrollAreaScrollbarContext.get());
857
+ }
858
+ scrollbar;
859
+ root;
860
+ machine = new StateMachine("hidden", {
861
+ hidden: { SCROLL: "scrolling" },
862
+ scrolling: {
863
+ SCROLL_END: "idle",
864
+ POINTER_ENTER: "interacting"
865
+ },
866
+ interacting: {
867
+ SCROLL: "interacting",
868
+ POINTER_LEAVE: "idle"
869
+ },
870
+ idle: {
871
+ HIDE: "hidden",
872
+ SCROLL: "scrolling",
873
+ POINTER_ENTER: "interacting"
874
+ }
875
+ });
876
+ #isHidden = derived(() => this.machine.state.current === "hidden");
877
+ get isHidden() {
878
+ return this.#isHidden();
879
+ }
880
+ set isHidden($$value) {
881
+ return this.#isHidden($$value);
882
+ }
883
+ constructor(scrollbar) {
884
+ this.scrollbar = scrollbar;
885
+ this.root = scrollbar.root;
886
+ useDebounce(() => this.machine.dispatch("SCROLL_END"), 100);
887
+ this.onpointerenter = this.onpointerenter.bind(this);
888
+ this.onpointerleave = this.onpointerleave.bind(this);
889
+ }
890
+ onpointerenter(_) {
891
+ this.machine.dispatch("POINTER_ENTER");
892
+ }
893
+ onpointerleave(_) {
894
+ this.machine.dispatch("POINTER_LEAVE");
895
+ }
896
+ #props = derived(() => ({
897
+ "data-state": this.machine.state.current === "hidden" ? "hidden" : "visible",
898
+ onpointerenter: this.onpointerenter,
899
+ onpointerleave: this.onpointerleave
900
+ }));
901
+ get props() {
902
+ return this.#props();
903
+ }
904
+ set props($$value) {
905
+ return this.#props($$value);
906
+ }
907
+ };
908
+ var ScrollAreaScrollbarAutoState = class ScrollAreaScrollbarAutoState {
909
+ static create() {
910
+ return new ScrollAreaScrollbarAutoState(ScrollAreaScrollbarContext.get());
911
+ }
912
+ scrollbar;
913
+ root;
914
+ isVisible = false;
915
+ constructor(scrollbar) {
916
+ this.scrollbar = scrollbar;
917
+ this.root = scrollbar.root;
918
+ const handleResize = useDebounce(() => {
919
+ const viewportNode = this.root.viewportNode;
920
+ if (!viewportNode) return;
921
+ const isOverflowX = viewportNode.offsetWidth < viewportNode.scrollWidth;
922
+ const isOverflowY = viewportNode.offsetHeight < viewportNode.scrollHeight;
923
+ this.isVisible = this.scrollbar.isHorizontal ? isOverflowX : isOverflowY;
924
+ }, 10);
925
+ new SvelteResizeObserver(() => this.root.viewportNode, handleResize);
926
+ new SvelteResizeObserver(() => this.root.contentNode, handleResize);
927
+ }
928
+ #props = derived(() => ({ "data-state": this.isVisible ? "visible" : "hidden" }));
929
+ get props() {
930
+ return this.#props();
931
+ }
932
+ set props($$value) {
933
+ return this.#props($$value);
934
+ }
935
+ };
936
+ var ScrollAreaScrollbarVisibleState = class ScrollAreaScrollbarVisibleState {
937
+ static create() {
938
+ return ScrollAreaScrollbarVisibleContext.set(new ScrollAreaScrollbarVisibleState(ScrollAreaScrollbarContext.get()));
939
+ }
940
+ scrollbar;
941
+ root;
942
+ thumbNode = null;
943
+ pointerOffset = 0;
944
+ sizes = {
945
+ content: 0,
946
+ viewport: 0,
947
+ scrollbar: {
948
+ size: 0,
949
+ paddingStart: 0,
950
+ paddingEnd: 0
951
+ }
952
+ };
953
+ #thumbRatio = derived(() => getThumbRatio(this.sizes.viewport, this.sizes.content));
954
+ get thumbRatio() {
955
+ return this.#thumbRatio();
956
+ }
957
+ set thumbRatio($$value) {
958
+ return this.#thumbRatio($$value);
959
+ }
960
+ #hasThumb = derived(() => Boolean(this.thumbRatio > 0 && this.thumbRatio < 1));
961
+ get hasThumb() {
962
+ return this.#hasThumb();
963
+ }
964
+ set hasThumb($$value) {
965
+ return this.#hasThumb($$value);
966
+ }
967
+ prevTransformStyle = "";
968
+ constructor(scrollbar) {
969
+ this.scrollbar = scrollbar;
970
+ this.root = scrollbar.root;
971
+ }
972
+ setSizes(sizes) {
973
+ this.sizes = sizes;
974
+ }
975
+ getScrollPosition(pointerPos, dir) {
976
+ return getScrollPositionFromPointer({
977
+ pointerPos,
978
+ pointerOffset: this.pointerOffset,
979
+ sizes: this.sizes,
980
+ dir
981
+ });
982
+ }
983
+ onThumbPointerUp() {
984
+ this.pointerOffset = 0;
985
+ }
986
+ onThumbPointerDown(pointerPos) {
987
+ this.pointerOffset = pointerPos;
988
+ }
989
+ xOnThumbPositionChange() {
990
+ if (!(this.root.viewportNode && this.thumbNode)) return;
991
+ const scrollPos = this.root.viewportNode.scrollLeft;
992
+ const transformStyle = `translate3d(${getThumbOffsetFromScroll({
993
+ scrollPos,
994
+ sizes: this.sizes,
995
+ dir: this.root.opts.dir.current
996
+ })}px, 0, 0)`;
997
+ this.thumbNode.style.transform = transformStyle;
998
+ this.prevTransformStyle = transformStyle;
999
+ }
1000
+ xOnWheelScroll(scrollPos) {
1001
+ if (!this.root.viewportNode) return;
1002
+ this.root.viewportNode.scrollLeft = scrollPos;
1003
+ }
1004
+ xOnDragScroll(pointerPos) {
1005
+ if (!this.root.viewportNode) return;
1006
+ this.root.viewportNode.scrollLeft = this.getScrollPosition(pointerPos, this.root.opts.dir.current);
1007
+ }
1008
+ yOnThumbPositionChange() {
1009
+ if (!(this.root.viewportNode && this.thumbNode)) return;
1010
+ const scrollPos = this.root.viewportNode.scrollTop;
1011
+ const transformStyle = `translate3d(0, ${getThumbOffsetFromScroll({
1012
+ scrollPos,
1013
+ sizes: this.sizes
1014
+ })}px, 0)`;
1015
+ this.thumbNode.style.transform = transformStyle;
1016
+ this.prevTransformStyle = transformStyle;
1017
+ }
1018
+ yOnWheelScroll(scrollPos) {
1019
+ if (!this.root.viewportNode) return;
1020
+ this.root.viewportNode.scrollTop = scrollPos;
1021
+ }
1022
+ yOnDragScroll(pointerPos) {
1023
+ if (!this.root.viewportNode) return;
1024
+ this.root.viewportNode.scrollTop = this.getScrollPosition(pointerPos, this.root.opts.dir.current);
1025
+ }
1026
+ };
1027
+ var ScrollAreaScrollbarXState = class ScrollAreaScrollbarXState {
1028
+ static create(opts) {
1029
+ return ScrollAreaScrollbarAxisContext.set(new ScrollAreaScrollbarXState(opts, ScrollAreaScrollbarVisibleContext.get()));
1030
+ }
1031
+ opts;
1032
+ scrollbarVis;
1033
+ root;
1034
+ scrollbar;
1035
+ attachment;
1036
+ computedStyle;
1037
+ constructor(opts, scrollbarVis) {
1038
+ this.opts = opts;
1039
+ this.scrollbarVis = scrollbarVis;
1040
+ this.root = scrollbarVis.root;
1041
+ this.scrollbar = scrollbarVis.scrollbar;
1042
+ this.attachment = attachRef(this.scrollbar.opts.ref, (v) => this.root.scrollbarXNode = v);
1043
+ }
1044
+ onThumbPointerDown = (pointerPos) => {
1045
+ this.scrollbarVis.onThumbPointerDown(pointerPos.x);
1046
+ };
1047
+ onDragScroll = (pointerPos) => {
1048
+ this.scrollbarVis.xOnDragScroll(pointerPos.x);
1049
+ };
1050
+ onThumbPointerUp = () => {
1051
+ this.scrollbarVis.onThumbPointerUp();
1052
+ };
1053
+ onThumbPositionChange = () => {
1054
+ this.scrollbarVis.xOnThumbPositionChange();
1055
+ };
1056
+ onWheelScroll = (e, maxScrollPos) => {
1057
+ if (!this.root.viewportNode) return;
1058
+ const scrollPos = this.root.viewportNode.scrollLeft + e.deltaX;
1059
+ this.scrollbarVis.xOnWheelScroll(scrollPos);
1060
+ if (isScrollingWithinScrollbarBounds(scrollPos, maxScrollPos)) e.preventDefault();
1061
+ };
1062
+ onResize = () => {
1063
+ if (!(this.scrollbar.opts.ref.current && this.root.viewportNode && this.computedStyle)) return;
1064
+ this.scrollbarVis.setSizes({
1065
+ content: this.root.viewportNode.scrollWidth,
1066
+ viewport: this.root.viewportNode.offsetWidth,
1067
+ scrollbar: {
1068
+ size: this.scrollbar.opts.ref.current.clientWidth,
1069
+ paddingStart: toInt(this.computedStyle.paddingLeft),
1070
+ paddingEnd: toInt(this.computedStyle.paddingRight)
1071
+ }
1072
+ });
1073
+ };
1074
+ #thumbSize = derived(() => {
1075
+ return getThumbSize(this.scrollbarVis.sizes);
1076
+ });
1077
+ get thumbSize() {
1078
+ return this.#thumbSize();
1079
+ }
1080
+ set thumbSize($$value) {
1081
+ return this.#thumbSize($$value);
1082
+ }
1083
+ #props = derived(() => ({
1084
+ id: this.scrollbar.opts.id.current,
1085
+ "data-orientation": "horizontal",
1086
+ style: {
1087
+ bottom: 0,
1088
+ left: this.root.opts.dir.current === "rtl" ? "var(--bits-scroll-area-corner-width)" : 0,
1089
+ right: this.root.opts.dir.current === "ltr" ? "var(--bits-scroll-area-corner-width)" : 0,
1090
+ "--bits-scroll-area-thumb-width": `${this.thumbSize}px`
1091
+ },
1092
+ ...this.attachment
1093
+ }));
1094
+ get props() {
1095
+ return this.#props();
1096
+ }
1097
+ set props($$value) {
1098
+ return this.#props($$value);
1099
+ }
1100
+ };
1101
+ var ScrollAreaScrollbarYState = class ScrollAreaScrollbarYState {
1102
+ static create(opts) {
1103
+ return ScrollAreaScrollbarAxisContext.set(new ScrollAreaScrollbarYState(opts, ScrollAreaScrollbarVisibleContext.get()));
1104
+ }
1105
+ opts;
1106
+ scrollbarVis;
1107
+ root;
1108
+ scrollbar;
1109
+ attachment;
1110
+ computedStyle;
1111
+ constructor(opts, scrollbarVis) {
1112
+ this.opts = opts;
1113
+ this.scrollbarVis = scrollbarVis;
1114
+ this.root = scrollbarVis.root;
1115
+ this.scrollbar = scrollbarVis.scrollbar;
1116
+ this.attachment = attachRef(this.scrollbar.opts.ref, (v) => this.root.scrollbarYNode = v);
1117
+ this.onThumbPointerDown = this.onThumbPointerDown.bind(this);
1118
+ this.onDragScroll = this.onDragScroll.bind(this);
1119
+ this.onThumbPointerUp = this.onThumbPointerUp.bind(this);
1120
+ this.onThumbPositionChange = this.onThumbPositionChange.bind(this);
1121
+ this.onWheelScroll = this.onWheelScroll.bind(this);
1122
+ this.onResize = this.onResize.bind(this);
1123
+ }
1124
+ onThumbPointerDown(pointerPos) {
1125
+ this.scrollbarVis.onThumbPointerDown(pointerPos.y);
1126
+ }
1127
+ onDragScroll(pointerPos) {
1128
+ this.scrollbarVis.yOnDragScroll(pointerPos.y);
1129
+ }
1130
+ onThumbPointerUp() {
1131
+ this.scrollbarVis.onThumbPointerUp();
1132
+ }
1133
+ onThumbPositionChange() {
1134
+ this.scrollbarVis.yOnThumbPositionChange();
1135
+ }
1136
+ onWheelScroll(e, maxScrollPos) {
1137
+ if (!this.root.viewportNode) return;
1138
+ const scrollPos = this.root.viewportNode.scrollTop + e.deltaY;
1139
+ this.scrollbarVis.yOnWheelScroll(scrollPos);
1140
+ if (isScrollingWithinScrollbarBounds(scrollPos, maxScrollPos)) e.preventDefault();
1141
+ }
1142
+ onResize() {
1143
+ if (!(this.scrollbar.opts.ref.current && this.root.viewportNode && this.computedStyle)) return;
1144
+ this.scrollbarVis.setSizes({
1145
+ content: this.root.viewportNode.scrollHeight,
1146
+ viewport: this.root.viewportNode.offsetHeight,
1147
+ scrollbar: {
1148
+ size: this.scrollbar.opts.ref.current.clientHeight,
1149
+ paddingStart: toInt(this.computedStyle.paddingTop),
1150
+ paddingEnd: toInt(this.computedStyle.paddingBottom)
1151
+ }
1152
+ });
1153
+ }
1154
+ #thumbSize = derived(() => {
1155
+ return getThumbSize(this.scrollbarVis.sizes);
1156
+ });
1157
+ get thumbSize() {
1158
+ return this.#thumbSize();
1159
+ }
1160
+ set thumbSize($$value) {
1161
+ return this.#thumbSize($$value);
1162
+ }
1163
+ #props = derived(() => ({
1164
+ id: this.scrollbar.opts.id.current,
1165
+ "data-orientation": "vertical",
1166
+ style: {
1167
+ top: 0,
1168
+ right: this.root.opts.dir.current === "ltr" ? 0 : void 0,
1169
+ left: this.root.opts.dir.current === "rtl" ? 0 : void 0,
1170
+ bottom: "var(--bits-scroll-area-corner-height)",
1171
+ "--bits-scroll-area-thumb-height": `${this.thumbSize}px`
1172
+ },
1173
+ ...this.attachment
1174
+ }));
1175
+ get props() {
1176
+ return this.#props();
1177
+ }
1178
+ set props($$value) {
1179
+ return this.#props($$value);
1180
+ }
1181
+ };
1182
+ var ScrollAreaScrollbarSharedState = class ScrollAreaScrollbarSharedState {
1183
+ static create() {
1184
+ return ScrollAreaScrollbarSharedContext.set(new ScrollAreaScrollbarSharedState(ScrollAreaScrollbarAxisContext.get()));
1185
+ }
1186
+ scrollbarState;
1187
+ root;
1188
+ scrollbarVis;
1189
+ scrollbar;
1190
+ rect = null;
1191
+ prevWebkitUserSelect = "";
1192
+ handleResize;
1193
+ handleThumbPositionChange;
1194
+ handleWheelScroll;
1195
+ handleThumbPointerDown;
1196
+ handleThumbPointerUp;
1197
+ #maxScrollPos = derived(() => this.scrollbarVis.sizes.content - this.scrollbarVis.sizes.viewport);
1198
+ get maxScrollPos() {
1199
+ return this.#maxScrollPos();
1200
+ }
1201
+ set maxScrollPos($$value) {
1202
+ return this.#maxScrollPos($$value);
1203
+ }
1204
+ constructor(scrollbarState) {
1205
+ this.scrollbarState = scrollbarState;
1206
+ this.root = scrollbarState.root;
1207
+ this.scrollbarVis = scrollbarState.scrollbarVis;
1208
+ this.scrollbar = scrollbarState.scrollbarVis.scrollbar;
1209
+ this.handleResize = useDebounce(() => this.scrollbarState.onResize(), 10);
1210
+ this.handleThumbPositionChange = this.scrollbarState.onThumbPositionChange;
1211
+ this.handleWheelScroll = this.scrollbarState.onWheelScroll;
1212
+ this.handleThumbPointerDown = this.scrollbarState.onThumbPointerDown;
1213
+ this.handleThumbPointerUp = this.scrollbarState.onThumbPointerUp;
1214
+ new SvelteResizeObserver(() => this.scrollbar.opts.ref.current, this.handleResize);
1215
+ new SvelteResizeObserver(() => this.root.contentNode, this.handleResize);
1216
+ this.onpointerdown = this.onpointerdown.bind(this);
1217
+ this.onpointermove = this.onpointermove.bind(this);
1218
+ this.onpointerup = this.onpointerup.bind(this);
1219
+ }
1220
+ handleDragScroll(e) {
1221
+ if (!this.rect) return;
1222
+ const x = e.clientX - this.rect.left;
1223
+ const y = e.clientY - this.rect.top;
1224
+ this.scrollbarState.onDragScroll({
1225
+ x,
1226
+ y
1227
+ });
1228
+ }
1229
+ onpointerdown(e) {
1230
+ if (e.button !== 0) return;
1231
+ e.target.setPointerCapture(e.pointerId);
1232
+ this.rect = this.scrollbar.opts.ref.current?.getBoundingClientRect() ?? null;
1233
+ this.prevWebkitUserSelect = this.root.domContext.getDocument().body.style.webkitUserSelect;
1234
+ this.root.domContext.getDocument().body.style.webkitUserSelect = "none";
1235
+ if (this.root.viewportNode) this.root.viewportNode.style.scrollBehavior = "auto";
1236
+ this.handleDragScroll(e);
1237
+ }
1238
+ onpointermove(e) {
1239
+ this.handleDragScroll(e);
1240
+ }
1241
+ onpointerup(e) {
1242
+ const target = e.target;
1243
+ if (target.hasPointerCapture(e.pointerId)) target.releasePointerCapture(e.pointerId);
1244
+ this.root.domContext.getDocument().body.style.webkitUserSelect = this.prevWebkitUserSelect;
1245
+ if (this.root.viewportNode) this.root.viewportNode.style.scrollBehavior = "";
1246
+ this.rect = null;
1247
+ }
1248
+ #props = derived(() => mergeProps({
1249
+ ...this.scrollbarState.props,
1250
+ style: {
1251
+ position: "absolute",
1252
+ ...this.scrollbarState.props.style
1253
+ },
1254
+ [scrollAreaAttrs.scrollbar]: "",
1255
+ onpointerdown: this.onpointerdown,
1256
+ onpointermove: this.onpointermove,
1257
+ onpointerup: this.onpointerup
1258
+ }));
1259
+ get props() {
1260
+ return this.#props();
1261
+ }
1262
+ set props($$value) {
1263
+ return this.#props($$value);
1264
+ }
1265
+ };
1266
+ var ScrollAreaThumbImplState = class ScrollAreaThumbImplState {
1267
+ static create(opts) {
1268
+ return new ScrollAreaThumbImplState(opts, ScrollAreaScrollbarSharedContext.get());
1269
+ }
1270
+ opts;
1271
+ scrollbarState;
1272
+ attachment;
1273
+ #root;
1274
+ #removeUnlinkedScrollListener;
1275
+ #debounceScrollEnd = useDebounce(() => {
1276
+ if (this.#removeUnlinkedScrollListener) {
1277
+ this.#removeUnlinkedScrollListener();
1278
+ this.#removeUnlinkedScrollListener = void 0;
1279
+ }
1280
+ }, 100);
1281
+ constructor(opts, scrollbarState) {
1282
+ this.opts = opts;
1283
+ this.scrollbarState = scrollbarState;
1284
+ this.#root = scrollbarState.root;
1285
+ this.attachment = attachRef(this.opts.ref, (v) => this.scrollbarState.scrollbarVis.thumbNode = v);
1286
+ this.onpointerdowncapture = this.onpointerdowncapture.bind(this);
1287
+ this.onpointerup = this.onpointerup.bind(this);
1288
+ }
1289
+ onpointerdowncapture(e) {
1290
+ const thumb = e.target;
1291
+ if (!thumb) return;
1292
+ const thumbRect = thumb.getBoundingClientRect();
1293
+ const x = e.clientX - thumbRect.left;
1294
+ const y = e.clientY - thumbRect.top;
1295
+ this.scrollbarState.handleThumbPointerDown({
1296
+ x,
1297
+ y
1298
+ });
1299
+ }
1300
+ onpointerup(_) {
1301
+ this.scrollbarState.handleThumbPointerUp();
1302
+ }
1303
+ #props = derived(() => ({
1304
+ id: this.opts.id.current,
1305
+ "data-state": this.scrollbarState.scrollbarVis.hasThumb ? "visible" : "hidden",
1306
+ style: {
1307
+ width: "var(--bits-scroll-area-thumb-width)",
1308
+ height: "var(--bits-scroll-area-thumb-height)",
1309
+ transform: this.scrollbarState.scrollbarVis.prevTransformStyle
1310
+ },
1311
+ onpointerdowncapture: this.onpointerdowncapture,
1312
+ onpointerup: this.onpointerup,
1313
+ [scrollAreaAttrs.thumb]: "",
1314
+ ...this.attachment
1315
+ }));
1316
+ get props() {
1317
+ return this.#props();
1318
+ }
1319
+ set props($$value) {
1320
+ return this.#props($$value);
1321
+ }
1322
+ };
1323
+ var ScrollAreaCornerImplState = class ScrollAreaCornerImplState {
1324
+ static create(opts) {
1325
+ return new ScrollAreaCornerImplState(opts, ScrollAreaRootContext.get());
1326
+ }
1327
+ opts;
1328
+ root;
1329
+ attachment;
1330
+ #width = 0;
1331
+ #height = 0;
1332
+ #hasSize = derived(() => Boolean(this.#width && this.#height));
1333
+ get hasSize() {
1334
+ return this.#hasSize();
1335
+ }
1336
+ set hasSize($$value) {
1337
+ return this.#hasSize($$value);
1338
+ }
1339
+ constructor(opts, root) {
1340
+ this.opts = opts;
1341
+ this.root = root;
1342
+ this.attachment = attachRef(this.opts.ref);
1343
+ new SvelteResizeObserver(() => this.root.scrollbarXNode, () => {
1344
+ const height = this.root.scrollbarXNode?.offsetHeight || 0;
1345
+ this.root.cornerHeight = height;
1346
+ this.#height = height;
1347
+ });
1348
+ new SvelteResizeObserver(() => this.root.scrollbarYNode, () => {
1349
+ const width = this.root.scrollbarYNode?.offsetWidth || 0;
1350
+ this.root.cornerWidth = width;
1351
+ this.#width = width;
1352
+ });
1353
+ }
1354
+ #props = derived(() => ({
1355
+ id: this.opts.id.current,
1356
+ style: {
1357
+ width: this.#width,
1358
+ height: this.#height,
1359
+ position: "absolute",
1360
+ right: this.root.opts.dir.current === "ltr" ? 0 : void 0,
1361
+ left: this.root.opts.dir.current === "rtl" ? 0 : void 0,
1362
+ bottom: 0
1363
+ },
1364
+ [scrollAreaAttrs.corner]: "",
1365
+ ...this.attachment
1366
+ }));
1367
+ get props() {
1368
+ return this.#props();
1369
+ }
1370
+ set props($$value) {
1371
+ return this.#props($$value);
1372
+ }
1373
+ };
1374
+ function toInt(value) {
1375
+ return value ? Number.parseInt(value, 10) : 0;
1376
+ }
1377
+ function getThumbRatio(viewportSize, contentSize) {
1378
+ const ratio = viewportSize / contentSize;
1379
+ return Number.isNaN(ratio) ? 0 : ratio;
1380
+ }
1381
+ function getThumbSize(sizes) {
1382
+ const ratio = getThumbRatio(sizes.viewport, sizes.content);
1383
+ const scrollbarPadding = sizes.scrollbar.paddingStart + sizes.scrollbar.paddingEnd;
1384
+ const thumbSize = (sizes.scrollbar.size - scrollbarPadding) * ratio;
1385
+ return Math.max(thumbSize, 18);
1386
+ }
1387
+ function getScrollPositionFromPointer({ pointerPos, pointerOffset, sizes, dir = "ltr" }) {
1388
+ const thumbSizePx = getThumbSize(sizes);
1389
+ const thumbCenter = thumbSizePx / 2;
1390
+ const offset = pointerOffset || thumbCenter;
1391
+ const thumbOffsetFromEnd = thumbSizePx - offset;
1392
+ const minPointerPos = sizes.scrollbar.paddingStart + offset;
1393
+ const maxPointerPos = sizes.scrollbar.size - sizes.scrollbar.paddingEnd - thumbOffsetFromEnd;
1394
+ const maxScrollPos = sizes.content - sizes.viewport;
1395
+ const scrollRange = dir === "ltr" ? [0, maxScrollPos] : [maxScrollPos * -1, 0];
1396
+ return linearScale([minPointerPos, maxPointerPos], scrollRange)(pointerPos);
1397
+ }
1398
+ function getThumbOffsetFromScroll({ scrollPos, sizes, dir = "ltr" }) {
1399
+ const thumbSizePx = getThumbSize(sizes);
1400
+ const scrollbarPadding = sizes.scrollbar.paddingStart + sizes.scrollbar.paddingEnd;
1401
+ const scrollbar = sizes.scrollbar.size - scrollbarPadding;
1402
+ const maxScrollPos = sizes.content - sizes.viewport;
1403
+ const maxThumbPos = scrollbar - thumbSizePx;
1404
+ const scrollClampRange = dir === "ltr" ? [0, maxScrollPos] : [maxScrollPos * -1, 0];
1405
+ const scrollWithoutMomentum = clamp(scrollPos, scrollClampRange[0], scrollClampRange[1]);
1406
+ return linearScale([0, maxScrollPos], [0, maxThumbPos])(scrollWithoutMomentum);
1407
+ }
1408
+ function linearScale(input, output) {
1409
+ return (value) => {
1410
+ if (input[0] === input[1] || output[0] === output[1]) return output[0];
1411
+ const ratio = (output[1] - output[0]) / (input[1] - input[0]);
1412
+ return output[0] + ratio * (value - input[0]);
1413
+ };
1414
+ }
1415
+ function isScrollingWithinScrollbarBounds(scrollPos, maxScrollPos) {
1416
+ return scrollPos > 0 && scrollPos < maxScrollPos;
1417
+ }
1418
+ function Scroll_area$1($$renderer, $$props) {
1419
+ $$renderer.component(($$renderer2) => {
1420
+ const uid = props_id($$renderer2);
1421
+ let { ref = null, id = createId(uid), type = "hover", dir = "ltr", scrollHideDelay = 600, children, child, $$slots, $$events, ...restProps } = $$props;
1422
+ const mergedProps = mergeProps(restProps, ScrollAreaRootState.create({
1423
+ type: boxWith(() => type),
1424
+ dir: boxWith(() => dir),
1425
+ scrollHideDelay: boxWith(() => scrollHideDelay),
1426
+ id: boxWith(() => id),
1427
+ ref: boxWith(() => ref, (v) => ref = v)
1428
+ }).props);
1429
+ if (child) {
1430
+ $$renderer2.push("<!--[-->");
1431
+ child($$renderer2, { props: mergedProps });
1432
+ $$renderer2.push(`<!---->`);
1433
+ } else {
1434
+ $$renderer2.push("<!--[!-->");
1435
+ $$renderer2.push(`<div${attributes({ ...mergedProps })}>`);
1436
+ children?.($$renderer2);
1437
+ $$renderer2.push(`<!----></div>`);
1438
+ }
1439
+ $$renderer2.push(`<!--]-->`);
1440
+ bind_props($$props, { ref });
1441
+ });
1442
+ }
1443
+ function Scroll_area_viewport($$renderer, $$props) {
1444
+ $$renderer.component(($$renderer2) => {
1445
+ const uid = props_id($$renderer2);
1446
+ let { ref = null, id = createId(uid), children, $$slots, $$events, ...restProps } = $$props;
1447
+ const viewportState = ScrollAreaViewportState.create({
1448
+ id: boxWith(() => id),
1449
+ ref: boxWith(() => ref, (v) => ref = v)
1450
+ });
1451
+ const mergedProps = mergeProps(restProps, viewportState.props);
1452
+ const mergedContentProps = mergeProps({}, viewportState.contentProps);
1453
+ $$renderer2.push(`<div${attributes({ ...mergedProps })}><div${attributes({ ...mergedContentProps })}>`);
1454
+ children?.($$renderer2);
1455
+ $$renderer2.push(`<!----></div></div>`);
1456
+ bind_props($$props, { ref });
1457
+ });
1458
+ }
1459
+ function Scroll_area_scrollbar_shared($$renderer, $$props) {
1460
+ $$renderer.component(($$renderer2) => {
1461
+ let { child, children, $$slots, $$events, ...restProps } = $$props;
1462
+ const mergedProps = mergeProps(restProps, ScrollAreaScrollbarSharedState.create().props);
1463
+ if (child) {
1464
+ $$renderer2.push("<!--[-->");
1465
+ child($$renderer2, { props: mergedProps });
1466
+ $$renderer2.push(`<!---->`);
1467
+ } else {
1468
+ $$renderer2.push("<!--[!-->");
1469
+ $$renderer2.push(`<div${attributes({ ...mergedProps })}>`);
1470
+ children?.($$renderer2);
1471
+ $$renderer2.push(`<!----></div>`);
1472
+ }
1473
+ $$renderer2.push(`<!--]-->`);
1474
+ });
1475
+ }
1476
+ function Scroll_area_scrollbar_x($$renderer, $$props) {
1477
+ $$renderer.component(($$renderer2) => {
1478
+ let { $$slots, $$events, ...restProps } = $$props;
1479
+ const isMounted = new IsMounted();
1480
+ Scroll_area_scrollbar_shared($$renderer2, spread_props([mergeProps(restProps, ScrollAreaScrollbarXState.create({ mounted: boxWith(() => isMounted.current) }).props)]));
1481
+ });
1482
+ }
1483
+ function Scroll_area_scrollbar_y($$renderer, $$props) {
1484
+ $$renderer.component(($$renderer2) => {
1485
+ let { $$slots, $$events, ...restProps } = $$props;
1486
+ const isMounted = new IsMounted();
1487
+ Scroll_area_scrollbar_shared($$renderer2, spread_props([mergeProps(restProps, ScrollAreaScrollbarYState.create({ mounted: boxWith(() => isMounted.current) }).props)]));
1488
+ });
1489
+ }
1490
+ function Scroll_area_scrollbar_visible($$renderer, $$props) {
1491
+ $$renderer.component(($$renderer2) => {
1492
+ let { $$slots, $$events, ...restProps } = $$props;
1493
+ if (ScrollAreaScrollbarVisibleState.create().scrollbar.opts.orientation.current === "horizontal") {
1494
+ $$renderer2.push("<!--[-->");
1495
+ Scroll_area_scrollbar_x($$renderer2, spread_props([restProps]));
1496
+ } else {
1497
+ $$renderer2.push("<!--[!-->");
1498
+ Scroll_area_scrollbar_y($$renderer2, spread_props([restProps]));
1499
+ }
1500
+ $$renderer2.push(`<!--]-->`);
1501
+ });
1502
+ }
1503
+ function Scroll_area_scrollbar_auto($$renderer, $$props) {
1504
+ $$renderer.component(($$renderer2) => {
1505
+ let { forceMount = false, $$slots, $$events, ...restProps } = $$props;
1506
+ const scrollbarAutoState = ScrollAreaScrollbarAutoState.create();
1507
+ const mergedProps = mergeProps(restProps, scrollbarAutoState.props);
1508
+ {
1509
+ let presence = function($$renderer3) {
1510
+ Scroll_area_scrollbar_visible($$renderer3, spread_props([mergedProps]));
1511
+ };
1512
+ Presence_layer($$renderer2, {
1513
+ open: forceMount || scrollbarAutoState.isVisible,
1514
+ ref: scrollbarAutoState.scrollbar.opts.ref,
1515
+ presence
1516
+ });
1517
+ }
1518
+ });
1519
+ }
1520
+ function Scroll_area_scrollbar_scroll($$renderer, $$props) {
1521
+ $$renderer.component(($$renderer2) => {
1522
+ let { forceMount = false, $$slots, $$events, ...restProps } = $$props;
1523
+ const scrollbarScrollState = ScrollAreaScrollbarScrollState.create();
1524
+ const mergedProps = mergeProps(restProps, scrollbarScrollState.props);
1525
+ {
1526
+ let presence = function($$renderer3) {
1527
+ Scroll_area_scrollbar_visible($$renderer3, spread_props([mergedProps]));
1528
+ };
1529
+ Presence_layer($$renderer2, spread_props([mergedProps, {
1530
+ open: forceMount || !scrollbarScrollState.isHidden,
1531
+ ref: scrollbarScrollState.scrollbar.opts.ref,
1532
+ presence,
1533
+ $$slots: { presence: true }
1534
+ }]));
1535
+ }
1536
+ });
1537
+ }
1538
+ function Scroll_area_scrollbar_hover($$renderer, $$props) {
1539
+ $$renderer.component(($$renderer2) => {
1540
+ let { forceMount = false, $$slots, $$events, ...restProps } = $$props;
1541
+ const scrollbarHoverState = ScrollAreaScrollbarHoverState.create();
1542
+ const scrollbarAutoState = ScrollAreaScrollbarAutoState.create();
1543
+ const mergedProps = mergeProps(restProps, scrollbarHoverState.props, scrollbarAutoState.props, { "data-state": scrollbarHoverState.isVisible ? "visible" : "hidden" });
1544
+ const open = forceMount || scrollbarHoverState.isVisible && scrollbarAutoState.isVisible;
1545
+ {
1546
+ let presence = function($$renderer3) {
1547
+ Scroll_area_scrollbar_visible($$renderer3, spread_props([mergedProps]));
1548
+ };
1549
+ Presence_layer($$renderer2, {
1550
+ open,
1551
+ ref: scrollbarAutoState.scrollbar.opts.ref,
1552
+ presence
1553
+ });
1554
+ }
1555
+ });
1556
+ }
1557
+ function Scroll_area_scrollbar$1($$renderer, $$props) {
1558
+ $$renderer.component(($$renderer2) => {
1559
+ const uid = props_id($$renderer2);
1560
+ let { ref = null, id = createId(uid), orientation, $$slots, $$events, ...restProps } = $$props;
1561
+ const type = ScrollAreaScrollbarState.create({
1562
+ orientation: boxWith(() => orientation),
1563
+ id: boxWith(() => id),
1564
+ ref: boxWith(() => ref, (v) => ref = v)
1565
+ }).root.opts.type.current;
1566
+ if (type === "hover") {
1567
+ $$renderer2.push("<!--[-->");
1568
+ Scroll_area_scrollbar_hover($$renderer2, spread_props([restProps, { id }]));
1569
+ } else {
1570
+ $$renderer2.push("<!--[!-->");
1571
+ if (type === "scroll") {
1572
+ $$renderer2.push("<!--[-->");
1573
+ Scroll_area_scrollbar_scroll($$renderer2, spread_props([restProps, { id }]));
1574
+ } else {
1575
+ $$renderer2.push("<!--[!-->");
1576
+ if (type === "auto") {
1577
+ $$renderer2.push("<!--[-->");
1578
+ Scroll_area_scrollbar_auto($$renderer2, spread_props([restProps, { id }]));
1579
+ } else {
1580
+ $$renderer2.push("<!--[!-->");
1581
+ if (type === "always") {
1582
+ $$renderer2.push("<!--[-->");
1583
+ Scroll_area_scrollbar_visible($$renderer2, spread_props([restProps, { id }]));
1584
+ } else $$renderer2.push("<!--[!-->");
1585
+ $$renderer2.push(`<!--]-->`);
1586
+ }
1587
+ $$renderer2.push(`<!--]-->`);
1588
+ }
1589
+ $$renderer2.push(`<!--]-->`);
1590
+ }
1591
+ $$renderer2.push(`<!--]-->`);
1592
+ bind_props($$props, { ref });
1593
+ });
1594
+ }
1595
+ function Scroll_area_thumb_impl($$renderer, $$props) {
1596
+ $$renderer.component(($$renderer2) => {
1597
+ let { ref = null, id, child, children, present, $$slots, $$events, ...restProps } = $$props;
1598
+ const isMounted = new IsMounted();
1599
+ const mergedProps = mergeProps(restProps, ScrollAreaThumbImplState.create({
1600
+ id: boxWith(() => id),
1601
+ ref: boxWith(() => ref, (v) => ref = v),
1602
+ mounted: boxWith(() => isMounted.current)
1603
+ }).props, { style: { hidden: !present } });
1604
+ if (child) {
1605
+ $$renderer2.push("<!--[-->");
1606
+ child($$renderer2, { props: mergedProps });
1607
+ $$renderer2.push(`<!---->`);
1608
+ } else {
1609
+ $$renderer2.push("<!--[!-->");
1610
+ $$renderer2.push(`<div${attributes({ ...mergedProps })}>`);
1611
+ children?.($$renderer2);
1612
+ $$renderer2.push(`<!----></div>`);
1613
+ }
1614
+ $$renderer2.push(`<!--]-->`);
1615
+ bind_props($$props, { ref });
1616
+ });
1617
+ }
1618
+ function Scroll_area_thumb($$renderer, $$props) {
1619
+ $$renderer.component(($$renderer2) => {
1620
+ const uid = props_id($$renderer2);
1621
+ let { id = createId(uid), ref = null, forceMount = false, $$slots, $$events, ...restProps } = $$props;
1622
+ const scrollbarState = ScrollAreaScrollbarVisibleContext.get();
1623
+ let $$settled = true;
1624
+ let $$inner_renderer;
1625
+ function $$render_inner($$renderer3) {
1626
+ {
1627
+ let presence = function($$renderer4, { present }) {
1628
+ Scroll_area_thumb_impl($$renderer4, spread_props([restProps, {
1629
+ id,
1630
+ present,
1631
+ get ref() {
1632
+ return ref;
1633
+ },
1634
+ set ref($$value) {
1635
+ ref = $$value;
1636
+ $$settled = false;
1637
+ }
1638
+ }]));
1639
+ };
1640
+ Presence_layer($$renderer3, {
1641
+ open: forceMount || scrollbarState.hasThumb,
1642
+ ref: scrollbarState.scrollbar.opts.ref,
1643
+ presence
1644
+ });
1645
+ }
1646
+ }
1647
+ do {
1648
+ $$settled = true;
1649
+ $$inner_renderer = $$renderer2.copy();
1650
+ $$render_inner($$inner_renderer);
1651
+ } while (!$$settled);
1652
+ $$renderer2.subsume($$inner_renderer);
1653
+ bind_props($$props, { ref });
1654
+ });
1655
+ }
1656
+ function Scroll_area_corner_impl($$renderer, $$props) {
1657
+ $$renderer.component(($$renderer2) => {
1658
+ let { ref = null, id, children, child, $$slots, $$events, ...restProps } = $$props;
1659
+ const mergedProps = mergeProps(restProps, ScrollAreaCornerImplState.create({
1660
+ id: boxWith(() => id),
1661
+ ref: boxWith(() => ref, (v) => ref = v)
1662
+ }).props);
1663
+ if (child) {
1664
+ $$renderer2.push("<!--[-->");
1665
+ child($$renderer2, { props: mergedProps });
1666
+ $$renderer2.push(`<!---->`);
1667
+ } else {
1668
+ $$renderer2.push("<!--[!-->");
1669
+ $$renderer2.push(`<div${attributes({ ...mergedProps })}>`);
1670
+ children?.($$renderer2);
1671
+ $$renderer2.push(`<!----></div>`);
1672
+ }
1673
+ $$renderer2.push(`<!--]-->`);
1674
+ bind_props($$props, { ref });
1675
+ });
1676
+ }
1677
+ function Scroll_area_corner($$renderer, $$props) {
1678
+ $$renderer.component(($$renderer2) => {
1679
+ const uid = props_id($$renderer2);
1680
+ let { ref = null, id = createId(uid), $$slots, $$events, ...restProps } = $$props;
1681
+ const scrollAreaState = ScrollAreaRootContext.get();
1682
+ const hasBothScrollbarsVisible = Boolean(scrollAreaState.scrollbarXNode && scrollAreaState.scrollbarYNode);
1683
+ const hasCorner = scrollAreaState.opts.type.current !== "scroll" && hasBothScrollbarsVisible;
1684
+ let $$settled = true;
1685
+ let $$inner_renderer;
1686
+ function $$render_inner($$renderer3) {
1687
+ if (hasCorner) {
1688
+ $$renderer3.push("<!--[-->");
1689
+ Scroll_area_corner_impl($$renderer3, spread_props([restProps, {
1690
+ id,
1691
+ get ref() {
1692
+ return ref;
1693
+ },
1694
+ set ref($$value) {
1695
+ ref = $$value;
1696
+ $$settled = false;
1697
+ }
1698
+ }]));
1699
+ } else $$renderer3.push("<!--[!-->");
1700
+ $$renderer3.push(`<!--]-->`);
1701
+ }
1702
+ do {
1703
+ $$settled = true;
1704
+ $$inner_renderer = $$renderer2.copy();
1705
+ $$render_inner($$inner_renderer);
1706
+ } while (!$$settled);
1707
+ $$renderer2.subsume($$inner_renderer);
1708
+ bind_props($$props, { ref });
1709
+ });
1710
+ }
1711
+ const defaultAttributes = {
1712
+ xmlns: "http://www.w3.org/2000/svg",
1713
+ width: 24,
1714
+ height: 24,
1715
+ viewBox: "0 0 24 24",
1716
+ fill: "none",
1717
+ stroke: "currentColor",
1718
+ "stroke-width": 2,
1719
+ "stroke-linecap": "round",
1720
+ "stroke-linejoin": "round"
1721
+ };
1722
+ function Icon($$renderer, $$props) {
1723
+ $$renderer.component(($$renderer2) => {
1724
+ const { name, color = "currentColor", size = 24, strokeWidth = 2, absoluteStrokeWidth = false, iconNode = [], children, $$slots, $$events, ...props } = $$props;
1725
+ $$renderer2.push(`<svg${attributes({
1726
+ ...defaultAttributes,
1727
+ ...props,
1728
+ width: size,
1729
+ height: size,
1730
+ stroke: color,
1731
+ "stroke-width": absoluteStrokeWidth ? Number(strokeWidth) * 24 / Number(size) : strokeWidth,
1732
+ class: clsx([
1733
+ "lucide-icon lucide",
1734
+ name && `lucide-${name}`,
1735
+ props.class
1736
+ ])
1737
+ }, void 0, void 0, void 0, 3)}><!--[-->`);
1738
+ const each_array = ensure_array_like(iconNode);
1739
+ for (let $$index = 0, $$length = each_array.length; $$index < $$length; $$index++) {
1740
+ let [tag, attrs] = each_array[$$index];
1741
+ element($$renderer2, tag, () => {
1742
+ $$renderer2.push(`${attributes({ ...attrs }, void 0, void 0, void 0, 3)}`);
1743
+ });
1744
+ }
1745
+ $$renderer2.push(`<!--]-->`);
1746
+ children?.($$renderer2);
1747
+ $$renderer2.push(`<!----></svg>`);
1748
+ });
1749
+ }
1750
+ function Check($$renderer, $$props) {
1751
+ $$renderer.component(($$renderer2) => {
1752
+ let { $$slots, $$events, ...props } = $$props;
1753
+ Icon($$renderer2, spread_props([
1754
+ { name: "check" },
1755
+ props,
1756
+ {
1757
+ iconNode: [["path", { "d": "M20 6 9 17l-5-5" }]],
1758
+ children: ($$renderer3) => {
1759
+ props.children?.($$renderer3);
1760
+ $$renderer3.push(`<!---->`);
1761
+ },
1762
+ $$slots: { default: true }
1763
+ }
1764
+ ]));
1765
+ });
1766
+ }
1767
+ function Minus($$renderer, $$props) {
1768
+ $$renderer.component(($$renderer2) => {
1769
+ let { $$slots, $$events, ...props } = $$props;
1770
+ Icon($$renderer2, spread_props([
1771
+ { name: "minus" },
1772
+ props,
1773
+ {
1774
+ iconNode: [["path", { "d": "M5 12h14" }]],
1775
+ children: ($$renderer3) => {
1776
+ props.children?.($$renderer3);
1777
+ $$renderer3.push(`<!---->`);
1778
+ },
1779
+ $$slots: { default: true }
1780
+ }
1781
+ ]));
1782
+ });
1783
+ }
1784
+ function Checkbox($$renderer, $$props) {
1785
+ $$renderer.component(($$renderer2) => {
1786
+ let { ref = null, checked = false, indeterminate = false, class: className, $$slots, $$events, ...restProps } = $$props;
1787
+ let $$settled = true;
1788
+ let $$inner_renderer;
1789
+ function $$render_inner($$renderer3) {
1790
+ $$renderer3.push(`<!---->`);
1791
+ {
1792
+ let children = function($$renderer4, { checked: checked2, indeterminate: indeterminate2 }) {
1793
+ $$renderer4.push(`<div data-slot="checkbox-indicator" class="text-current transition-none">`);
1794
+ if (checked2) {
1795
+ $$renderer4.push("<!--[-->");
1796
+ Check($$renderer4, { class: "size-3.5" });
1797
+ } else {
1798
+ $$renderer4.push("<!--[!-->");
1799
+ if (indeterminate2) {
1800
+ $$renderer4.push("<!--[-->");
1801
+ Minus($$renderer4, { class: "size-3.5" });
1802
+ } else $$renderer4.push("<!--[!-->");
1803
+ $$renderer4.push(`<!--]-->`);
1804
+ }
1805
+ $$renderer4.push(`<!--]--></div>`);
1806
+ };
1807
+ Checkbox$1?.($$renderer3, spread_props([
1808
+ {
1809
+ "data-slot": "checkbox",
1810
+ class: cn("border-input dark:bg-input/30 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground dark:data-[state=checked]:bg-primary data-[state=checked]:border-primary focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive peer flex size-4 shrink-0 items-center justify-center rounded-[4px] border shadow-xs transition-shadow outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50", className)
1811
+ },
1812
+ restProps,
1813
+ {
1814
+ get ref() {
1815
+ return ref;
1816
+ },
1817
+ set ref($$value) {
1818
+ ref = $$value;
1819
+ $$settled = false;
1820
+ },
1821
+ get checked() {
1822
+ return checked;
1823
+ },
1824
+ set checked($$value) {
1825
+ checked = $$value;
1826
+ $$settled = false;
1827
+ },
1828
+ get indeterminate() {
1829
+ return indeterminate;
1830
+ },
1831
+ set indeterminate($$value) {
1832
+ indeterminate = $$value;
1833
+ $$settled = false;
1834
+ },
1835
+ children,
1836
+ $$slots: { default: true }
1837
+ }
1838
+ ]));
1839
+ }
1840
+ $$renderer3.push(`<!---->`);
1841
+ }
1842
+ do {
1843
+ $$settled = true;
1844
+ $$inner_renderer = $$renderer2.copy();
1845
+ $$render_inner($$inner_renderer);
1846
+ } while (!$$settled);
1847
+ $$renderer2.subsume($$inner_renderer);
1848
+ bind_props($$props, {
1849
+ ref,
1850
+ checked,
1851
+ indeterminate
1852
+ });
1853
+ });
1854
+ }
1855
+ function Dialog($$renderer, $$props) {
1856
+ $$renderer.component(($$renderer2) => {
1857
+ let { open = false, $$slots, $$events, ...restProps } = $$props;
1858
+ let $$settled = true;
1859
+ let $$inner_renderer;
1860
+ function $$render_inner($$renderer3) {
1861
+ $$renderer3.push(`<!---->`);
1862
+ Dialog$1?.($$renderer3, spread_props([restProps, {
1863
+ get open() {
1864
+ return open;
1865
+ },
1866
+ set open($$value) {
1867
+ open = $$value;
1868
+ $$settled = false;
1869
+ }
1870
+ }]));
1871
+ $$renderer3.push(`<!---->`);
1872
+ }
1873
+ do {
1874
+ $$settled = true;
1875
+ $$inner_renderer = $$renderer2.copy();
1876
+ $$render_inner($$inner_renderer);
1877
+ } while (!$$settled);
1878
+ $$renderer2.subsume($$inner_renderer);
1879
+ bind_props($$props, { open });
1880
+ });
1881
+ }
1882
+ function Dialog_portal($$renderer, $$props) {
1883
+ let { $$slots, $$events, ...restProps } = $$props;
1884
+ $$renderer.push(`<!---->`);
1885
+ Portal?.($$renderer, spread_props([restProps]));
1886
+ $$renderer.push(`<!---->`);
1887
+ }
1888
+ function Dialog_title($$renderer, $$props) {
1889
+ $$renderer.component(($$renderer2) => {
1890
+ let { ref = null, class: className, $$slots, $$events, ...restProps } = $$props;
1891
+ let $$settled = true;
1892
+ let $$inner_renderer;
1893
+ function $$render_inner($$renderer3) {
1894
+ $$renderer3.push(`<!---->`);
1895
+ Dialog_title$1?.($$renderer3, spread_props([
1896
+ {
1897
+ "data-slot": "dialog-title",
1898
+ class: cn("text-lg leading-none font-semibold", className)
1899
+ },
1900
+ restProps,
1901
+ {
1902
+ get ref() {
1903
+ return ref;
1904
+ },
1905
+ set ref($$value) {
1906
+ ref = $$value;
1907
+ $$settled = false;
1908
+ }
1909
+ }
1910
+ ]));
1911
+ $$renderer3.push(`<!---->`);
1912
+ }
1913
+ do {
1914
+ $$settled = true;
1915
+ $$inner_renderer = $$renderer2.copy();
1916
+ $$render_inner($$inner_renderer);
1917
+ } while (!$$settled);
1918
+ $$renderer2.subsume($$inner_renderer);
1919
+ bind_props($$props, { ref });
1920
+ });
1921
+ }
1922
+ function Dialog_footer($$renderer, $$props) {
1923
+ $$renderer.component(($$renderer2) => {
1924
+ let { ref = null, class: className, children, $$slots, $$events, ...restProps } = $$props;
1925
+ $$renderer2.push(`<div${attributes({
1926
+ "data-slot": "dialog-footer",
1927
+ class: clsx(cn("flex flex-col-reverse gap-2 sm:flex-row sm:justify-end", className)),
1928
+ ...restProps
1929
+ })}>`);
1930
+ children?.($$renderer2);
1931
+ $$renderer2.push(`<!----></div>`);
1932
+ bind_props($$props, { ref });
1933
+ });
1934
+ }
1935
+ function Dialog_header($$renderer, $$props) {
1936
+ $$renderer.component(($$renderer2) => {
1937
+ let { ref = null, class: className, children, $$slots, $$events, ...restProps } = $$props;
1938
+ $$renderer2.push(`<div${attributes({
1939
+ "data-slot": "dialog-header",
1940
+ class: clsx(cn("flex flex-col gap-2 text-center sm:text-start", className)),
1941
+ ...restProps
1942
+ })}>`);
1943
+ children?.($$renderer2);
1944
+ $$renderer2.push(`<!----></div>`);
1945
+ bind_props($$props, { ref });
1946
+ });
1947
+ }
1948
+ function Dialog_overlay($$renderer, $$props) {
1949
+ $$renderer.component(($$renderer2) => {
1950
+ let { ref = null, class: className, $$slots, $$events, ...restProps } = $$props;
1951
+ let $$settled = true;
1952
+ let $$inner_renderer;
1953
+ function $$render_inner($$renderer3) {
1954
+ $$renderer3.push(`<!---->`);
1955
+ Dialog_overlay$1?.($$renderer3, spread_props([
1956
+ {
1957
+ "data-slot": "dialog-overlay",
1958
+ class: cn("data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 fixed inset-0 z-50 bg-black/50", className)
1959
+ },
1960
+ restProps,
1961
+ {
1962
+ get ref() {
1963
+ return ref;
1964
+ },
1965
+ set ref($$value) {
1966
+ ref = $$value;
1967
+ $$settled = false;
1968
+ }
1969
+ }
1970
+ ]));
1971
+ $$renderer3.push(`<!---->`);
1972
+ }
1973
+ do {
1974
+ $$settled = true;
1975
+ $$inner_renderer = $$renderer2.copy();
1976
+ $$render_inner($$inner_renderer);
1977
+ } while (!$$settled);
1978
+ $$renderer2.subsume($$inner_renderer);
1979
+ bind_props($$props, { ref });
1980
+ });
1981
+ }
1982
+ function X($$renderer, $$props) {
1983
+ $$renderer.component(($$renderer2) => {
1984
+ let { $$slots, $$events, ...props } = $$props;
1985
+ Icon($$renderer2, spread_props([
1986
+ { name: "x" },
1987
+ props,
1988
+ {
1989
+ iconNode: [["path", { "d": "M18 6 6 18" }], ["path", { "d": "m6 6 12 12" }]],
1990
+ children: ($$renderer3) => {
1991
+ props.children?.($$renderer3);
1992
+ $$renderer3.push(`<!---->`);
1993
+ },
1994
+ $$slots: { default: true }
1995
+ }
1996
+ ]));
1997
+ });
1998
+ }
1999
+ function Dialog_content($$renderer, $$props) {
2000
+ $$renderer.component(($$renderer2) => {
2001
+ let { ref = null, class: className, portalProps, children, showCloseButton = true, $$slots, $$events, ...restProps } = $$props;
2002
+ let $$settled = true;
2003
+ let $$inner_renderer;
2004
+ function $$render_inner($$renderer3) {
2005
+ Dialog_portal($$renderer3, spread_props([portalProps, {
2006
+ children: ($$renderer4) => {
2007
+ $$renderer4.push(`<!---->`);
2008
+ Dialog_overlay?.($$renderer4, {});
2009
+ $$renderer4.push(`<!----> <!---->`);
2010
+ Dialog_content$1?.($$renderer4, spread_props([
2011
+ {
2012
+ "data-slot": "dialog-content",
2013
+ class: cn("bg-background data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 fixed top-[50%] left-[50%] z-50 grid w-full max-w-[calc(100%-2rem)] translate-x-[-50%] translate-y-[-50%] gap-4 rounded-lg border p-6 shadow-lg duration-200 sm:max-w-lg", className)
2014
+ },
2015
+ restProps,
2016
+ {
2017
+ get ref() {
2018
+ return ref;
2019
+ },
2020
+ set ref($$value) {
2021
+ ref = $$value;
2022
+ $$settled = false;
2023
+ },
2024
+ children: ($$renderer5) => {
2025
+ children?.($$renderer5);
2026
+ $$renderer5.push(`<!----> `);
2027
+ if (showCloseButton) {
2028
+ $$renderer5.push("<!--[-->");
2029
+ $$renderer5.push(`<!---->`);
2030
+ Dialog_close?.($$renderer5, {
2031
+ class: "ring-offset-background focus:ring-ring absolute end-4 top-4 rounded-xs opacity-70 transition-opacity hover:opacity-100 focus:ring-2 focus:ring-offset-2 focus:outline-hidden disabled:pointer-events-none [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
2032
+ children: ($$renderer6) => {
2033
+ X($$renderer6, {});
2034
+ $$renderer6.push(`<!----> <span class="sr-only">Close</span>`);
2035
+ },
2036
+ $$slots: { default: true }
2037
+ });
2038
+ $$renderer5.push(`<!---->`);
2039
+ } else $$renderer5.push("<!--[!-->");
2040
+ $$renderer5.push(`<!--]-->`);
2041
+ },
2042
+ $$slots: { default: true }
2043
+ }
2044
+ ]));
2045
+ $$renderer4.push(`<!---->`);
2046
+ },
2047
+ $$slots: { default: true }
2048
+ }]));
2049
+ }
2050
+ do {
2051
+ $$settled = true;
2052
+ $$inner_renderer = $$renderer2.copy();
2053
+ $$render_inner($$inner_renderer);
2054
+ } while (!$$settled);
2055
+ $$renderer2.subsume($$inner_renderer);
2056
+ bind_props($$props, { ref });
2057
+ });
2058
+ }
2059
+ function Scroll_area_scrollbar($$renderer, $$props) {
2060
+ $$renderer.component(($$renderer2) => {
2061
+ let { ref = null, class: className, orientation = "vertical", children, $$slots, $$events, ...restProps } = $$props;
2062
+ let $$settled = true;
2063
+ let $$inner_renderer;
2064
+ function $$render_inner($$renderer3) {
2065
+ $$renderer3.push(`<!---->`);
2066
+ Scroll_area_scrollbar$1?.($$renderer3, spread_props([
2067
+ {
2068
+ "data-slot": "scroll-area-scrollbar",
2069
+ orientation,
2070
+ class: cn("flex touch-none p-px transition-colors select-none", orientation === "vertical" && "h-full w-2.5 border-s border-s-transparent", orientation === "horizontal" && "h-2.5 flex-col border-t border-t-transparent", className)
2071
+ },
2072
+ restProps,
2073
+ {
2074
+ get ref() {
2075
+ return ref;
2076
+ },
2077
+ set ref($$value) {
2078
+ ref = $$value;
2079
+ $$settled = false;
2080
+ },
2081
+ children: ($$renderer4) => {
2082
+ children?.($$renderer4);
2083
+ $$renderer4.push(`<!----> <!---->`);
2084
+ Scroll_area_thumb?.($$renderer4, {
2085
+ "data-slot": "scroll-area-thumb",
2086
+ class: "bg-border relative flex-1 rounded-full"
2087
+ });
2088
+ $$renderer4.push(`<!---->`);
2089
+ },
2090
+ $$slots: { default: true }
2091
+ }
2092
+ ]));
2093
+ $$renderer3.push(`<!---->`);
2094
+ }
2095
+ do {
2096
+ $$settled = true;
2097
+ $$inner_renderer = $$renderer2.copy();
2098
+ $$render_inner($$inner_renderer);
2099
+ } while (!$$settled);
2100
+ $$renderer2.subsume($$inner_renderer);
2101
+ bind_props($$props, { ref });
2102
+ });
2103
+ }
2104
+ function Scroll_area($$renderer, $$props) {
2105
+ $$renderer.component(($$renderer2) => {
2106
+ let { ref = null, viewportRef = null, class: className, orientation = "vertical", scrollbarXClasses = "", scrollbarYClasses = "", children, $$slots, $$events, ...restProps } = $$props;
2107
+ let $$settled = true;
2108
+ let $$inner_renderer;
2109
+ function $$render_inner($$renderer3) {
2110
+ $$renderer3.push(`<!---->`);
2111
+ Scroll_area$1?.($$renderer3, spread_props([
2112
+ {
2113
+ "data-slot": "scroll-area",
2114
+ class: cn("relative", className)
2115
+ },
2116
+ restProps,
2117
+ {
2118
+ get ref() {
2119
+ return ref;
2120
+ },
2121
+ set ref($$value) {
2122
+ ref = $$value;
2123
+ $$settled = false;
2124
+ },
2125
+ children: ($$renderer4) => {
2126
+ $$renderer4.push(`<!---->`);
2127
+ Scroll_area_viewport?.($$renderer4, {
2128
+ "data-slot": "scroll-area-viewport",
2129
+ class: "ring-ring/10 dark:ring-ring/20 dark:outline-ring/40 outline-ring/50 size-full rounded-[inherit] transition-[color,box-shadow] focus-visible:ring-4 focus-visible:outline-1",
2130
+ get ref() {
2131
+ return viewportRef;
2132
+ },
2133
+ set ref($$value) {
2134
+ viewportRef = $$value;
2135
+ $$settled = false;
2136
+ },
2137
+ children: ($$renderer5) => {
2138
+ children?.($$renderer5);
2139
+ $$renderer5.push(`<!---->`);
2140
+ },
2141
+ $$slots: { default: true }
2142
+ });
2143
+ $$renderer4.push(`<!----> `);
2144
+ if (orientation === "vertical" || orientation === "both") {
2145
+ $$renderer4.push("<!--[-->");
2146
+ Scroll_area_scrollbar($$renderer4, {
2147
+ orientation: "vertical",
2148
+ class: scrollbarYClasses
2149
+ });
2150
+ } else $$renderer4.push("<!--[!-->");
2151
+ $$renderer4.push(`<!--]--> `);
2152
+ if (orientation === "horizontal" || orientation === "both") {
2153
+ $$renderer4.push("<!--[-->");
2154
+ Scroll_area_scrollbar($$renderer4, {
2155
+ orientation: "horizontal",
2156
+ class: scrollbarXClasses
2157
+ });
2158
+ } else $$renderer4.push("<!--[!-->");
2159
+ $$renderer4.push(`<!--]--> <!---->`);
2160
+ Scroll_area_corner?.($$renderer4, {});
2161
+ $$renderer4.push(`<!---->`);
2162
+ },
2163
+ $$slots: { default: true }
2164
+ }
2165
+ ]));
2166
+ $$renderer3.push(`<!---->`);
2167
+ }
2168
+ do {
2169
+ $$settled = true;
2170
+ $$inner_renderer = $$renderer2.copy();
2171
+ $$render_inner($$inner_renderer);
2172
+ } while (!$$settled);
2173
+ $$renderer2.subsume($$inner_renderer);
2174
+ bind_props($$props, {
2175
+ ref,
2176
+ viewportRef
2177
+ });
2178
+ });
2179
+ }
2180
+ function AllSessionsPanel($$renderer, $$props) {
2181
+ $$renderer.component(($$renderer2) => {
2182
+ var $$store_subs;
2183
+ let { onSessionSelect, compact = false } = $$props;
2184
+ let tmuxPanes = [];
2185
+ let showFolderBrowser = false;
2186
+ let browserPath = "";
2187
+ let browserFolders = [];
2188
+ let browserShowHidden = false;
2189
+ let browserIsRoot = false;
2190
+ let browserParent = null;
2191
+ let browserError = "";
2192
+ let alertOpen = false;
2193
+ let alertTitle = "";
2194
+ let alertMessage = "";
2195
+ let alertOnConfirm = () => {};
2196
+ function showConfirm(title, message, onConfirm) {
2197
+ alertTitle = title;
2198
+ alertMessage = message;
2199
+ alertOnConfirm = onConfirm;
2200
+ alertOpen = true;
2201
+ }
2202
+ const sessionsByProject = (() => {
2203
+ const groups = /* @__PURE__ */ new Map();
2204
+ for (const session of sessionStore.sessions) {
2205
+ const key = session.cwd || "unknown";
2206
+ if (!groups.has(key)) groups.set(key, []);
2207
+ groups.get(key).push(session);
2208
+ }
2209
+ return groups;
2210
+ })();
2211
+ const allProjects = (() => {
2212
+ const projects = /* @__PURE__ */ new Set();
2213
+ for (const session of sessionStore.sessions) if (session.cwd) projects.add(session.cwd);
2214
+ for (const cwd of sessionStore.savedProjects) projects.add(cwd);
2215
+ return [...projects].sort();
2216
+ })();
2217
+ function flattenTree(nodes) {
2218
+ const result = [];
2219
+ for (const node of nodes) {
2220
+ result.push(node);
2221
+ if (node.children.length > 0) result.push(...flattenTree(node.children));
2222
+ }
2223
+ return result;
2224
+ }
2225
+ const flatProjects = flattenTree((() => {
2226
+ const projects = allProjects;
2227
+ const sessionsMap = sessionsByProject;
2228
+ const sorted = [...projects].sort((a, b) => a.length - b.length);
2229
+ const roots = [];
2230
+ const nodeMap = /* @__PURE__ */ new Map();
2231
+ for (const cwd of sorted) {
2232
+ const node = {
2233
+ cwd,
2234
+ sessions: sessionsMap.get(cwd) || [],
2235
+ children: [],
2236
+ depth: 0
2237
+ };
2238
+ let parent = null;
2239
+ for (const potentialParent of sorted) {
2240
+ if (potentialParent === cwd) continue;
2241
+ if (cwd.startsWith(potentialParent + "/")) {
2242
+ const parentNode = nodeMap.get(potentialParent);
2243
+ if (parentNode && (!parent || potentialParent.length > parent.cwd.length)) parent = parentNode;
2244
+ }
2245
+ }
2246
+ if (parent) {
2247
+ node.depth = parent.depth + 1;
2248
+ parent.children.push(node);
2249
+ } else roots.push(node);
2250
+ nodeMap.set(cwd, node);
2251
+ }
2252
+ return roots;
2253
+ })());
2254
+ const otherTmuxPanes = (() => {
2255
+ const claudeTargets = new Set(sessionStore.sessions.map((s) => s.tmux_target));
2256
+ return tmuxPanes.filter((p) => !claudeTargets.has(p.target));
2257
+ })();
2258
+ const currentTarget = store_get($$store_subs ??= {}, "$page", page).url.pathname.startsWith("/session/") ? decodeURIComponent(store_get($$store_subs ??= {}, "$page", page).url.pathname.split("/session/")[1]) : null;
2259
+ async function fetchTmuxPanes() {
2260
+ try {
2261
+ tmuxPanes = await (await fetch("/api/tmux/panes")).json();
2262
+ } catch {
2263
+ tmuxPanes = [];
2264
+ }
2265
+ }
2266
+ function killSession(id, pid, tmux_target) {
2267
+ showConfirm("Kill Session", "Are you sure you want to kill this session?", async () => {
2268
+ await fetch(`/api/sessions/${encodeURIComponent(id)}/kill`, {
2269
+ method: "POST",
2270
+ headers: { "Content-Type": "application/json" },
2271
+ body: JSON.stringify({
2272
+ pid,
2273
+ tmux_target
2274
+ })
2275
+ });
2276
+ });
2277
+ }
2278
+ function deleteProject(cwd) {
2279
+ showConfirm("Delete Project", `Delete project "${cwd}" and all its sessions?`, async () => {
2280
+ const sessions = sessionsByProject.get(cwd) || [];
2281
+ for (const s of sessions) await fetch(`/api/sessions/${encodeURIComponent(s.id)}/kill`, {
2282
+ method: "POST",
2283
+ headers: { "Content-Type": "application/json" },
2284
+ body: JSON.stringify({
2285
+ pid: s.pid,
2286
+ tmux_target: s.tmux_target
2287
+ })
2288
+ });
2289
+ sessionStore.removeProject(cwd);
2290
+ });
2291
+ }
2292
+ async function newSessionInProject(cwd) {
2293
+ const data = await (await fetch("/api/projects/new-session", {
2294
+ method: "POST",
2295
+ headers: { "Content-Type": "application/json" },
2296
+ body: JSON.stringify({ cwd })
2297
+ })).json();
2298
+ sessionStore.saveProject(cwd);
2299
+ if (data.ok && data.session) {
2300
+ data.session + "";
2301
+ goto();
2302
+ onSessionSelect?.();
2303
+ }
2304
+ }
2305
+ async function openFolderBrowser() {
2306
+ showFolderBrowser = true;
2307
+ await browseTo("~");
2308
+ }
2309
+ async function browseTo(path) {
2310
+ browserError = "";
2311
+ const data = await (await fetch(`/api/browse?path=${encodeURIComponent(path)}&showHidden=${browserShowHidden}`)).json();
2312
+ if (data.error) {
2313
+ browserError = data.error;
2314
+ return;
2315
+ }
2316
+ browserPath = data.current;
2317
+ browserFolders = data.folders;
2318
+ browserIsRoot = data.isRoot;
2319
+ browserParent = data.parent;
2320
+ }
2321
+ async function selectFolder() {
2322
+ showFolderBrowser = false;
2323
+ await newSessionInProject(browserPath);
2324
+ }
2325
+ function getProjectName(cwd) {
2326
+ return cwd.split("/").pop() || cwd;
2327
+ }
2328
+ async function closeChrome() {
2329
+ await fetch("/api/chrome", { method: "DELETE" });
2330
+ }
2331
+ let $$settled = true;
2332
+ let $$inner_renderer;
2333
+ function $$render_inner($$renderer3) {
2334
+ $$renderer3.push(`<div${attr_class("all-sessions-panel svelte-183q6rw", void 0, { "compact": compact })}><header class="header svelte-183q6rw"><a href="/" class="title-link svelte-183q6rw"><h1 class="svelte-183q6rw">claude-mux</h1></a> <div class="header-actions svelte-183q6rw">`);
2335
+ if (!compact) {
2336
+ $$renderer3.push("<!--[-->");
2337
+ Button($$renderer3, {
2338
+ variant: "secondary",
2339
+ size: "icon",
2340
+ onclick: closeChrome,
2341
+ title: "Close Chrome/Brave debugging instances",
2342
+ children: ($$renderer4) => {
2343
+ $$renderer4.push(`<iconify-icon icon="mdi:google-chrome"></iconify-icon>`);
2344
+ },
2345
+ $$slots: { default: true }
2346
+ });
2347
+ } else $$renderer3.push("<!--[!-->");
2348
+ $$renderer3.push(`<!--]--> `);
2349
+ Button($$renderer3, {
2350
+ variant: sessionStore.paused ? "destructive" : "secondary",
2351
+ size: "icon",
2352
+ onclick: () => sessionStore.togglePause(),
2353
+ title: sessionStore.paused ? "Resume" : "Pause",
2354
+ children: ($$renderer4) => {
2355
+ $$renderer4.push(`<iconify-icon${attr("icon", sessionStore.paused ? "mdi:play" : "mdi:pause")}></iconify-icon>`);
2356
+ },
2357
+ $$slots: { default: true }
2358
+ });
2359
+ $$renderer3.push(`<!----> `);
2360
+ Button($$renderer3, {
2361
+ variant: "secondary",
2362
+ size: "icon",
2363
+ onclick: openFolderBrowser,
2364
+ title: "New Project",
2365
+ children: ($$renderer4) => {
2366
+ $$renderer4.push(`<iconify-icon icon="mdi:plus"></iconify-icon>`);
2367
+ },
2368
+ $$slots: { default: true }
2369
+ });
2370
+ $$renderer3.push(`<!----></div></header> <p class="count svelte-183q6rw">${escape_html(sessionStore.sessions.length)} session${escape_html(sessionStore.sessions.length !== 1 ? "s" : "")}</p> <div class="scroll-content svelte-183q6rw">`);
2371
+ if (flatProjects.length === 0) {
2372
+ $$renderer3.push("<!--[-->");
2373
+ $$renderer3.push(`<div class="empty svelte-183q6rw">No sessions yet. Click + to add a project.</div>`);
2374
+ } else {
2375
+ $$renderer3.push("<!--[!-->");
2376
+ $$renderer3.push(`<!--[-->`);
2377
+ const each_array = ensure_array_like(flatProjects);
2378
+ for (let $$index_1 = 0, $$length = each_array.length; $$index_1 < $$length; $$index_1++) {
2379
+ let project = each_array[$$index_1];
2380
+ const color = getProjectColor(project.cwd);
2381
+ const isNested = project.depth > 0;
2382
+ const firstSession = project.sessions[0];
2383
+ $$renderer3.push(`<div${attr_class("project-group svelte-183q6rw", void 0, { "nested": isNested })}${attr_style(`margin-left: ${stringify(project.depth * (compact ? 16 : 24))}px; border-left-color: ${stringify(color)}`)}><div class="project-header svelte-183q6rw"><div class="project-info svelte-183q6rw">`);
2384
+ if (isNested) {
2385
+ $$renderer3.push("<!--[-->");
2386
+ $$renderer3.push(`<span class="nest-indicator svelte-183q6rw">└</span>`);
2387
+ } else $$renderer3.push("<!--[!-->");
2388
+ $$renderer3.push(`<!--]--> <span class="name svelte-183q6rw">${escape_html(getProjectName(project.cwd))}</span> <div class="meta svelte-183q6rw">`);
2389
+ Badge($$renderer3, {
2390
+ variant: "secondary",
2391
+ class: "text-xs",
2392
+ children: ($$renderer4) => {
2393
+ $$renderer4.push(`<!---->${escape_html(project.sessions.length)}`);
2394
+ },
2395
+ $$slots: { default: true }
2396
+ });
2397
+ $$renderer3.push(`<!----> `);
2398
+ if (!compact) {
2399
+ $$renderer3.push("<!--[-->");
2400
+ if (firstSession?.git_root) {
2401
+ $$renderer3.push("<!--[-->");
2402
+ Badge($$renderer3, {
2403
+ variant: "outline",
2404
+ class: "border-orange-700 text-orange-400",
2405
+ children: ($$renderer4) => {
2406
+ $$renderer4.push(`<!---->git`);
2407
+ },
2408
+ $$slots: { default: true }
2409
+ });
2410
+ } else $$renderer3.push("<!--[!-->");
2411
+ $$renderer3.push(`<!--]--> `);
2412
+ if (firstSession?.beads_enabled) {
2413
+ $$renderer3.push("<!--[-->");
2414
+ Badge($$renderer3, {
2415
+ variant: "outline",
2416
+ class: "border-purple-700 text-purple-400",
2417
+ children: ($$renderer4) => {
2418
+ $$renderer4.push(`<!---->beads`);
2419
+ },
2420
+ $$slots: { default: true }
2421
+ });
2422
+ } else $$renderer3.push("<!--[!-->");
2423
+ $$renderer3.push(`<!--]-->`);
2424
+ } else $$renderer3.push("<!--[!-->");
2425
+ $$renderer3.push(`<!--]--></div></div> <div class="project-actions svelte-183q6rw">`);
2426
+ Button($$renderer3, {
2427
+ variant: "ghost",
2428
+ size: "icon-sm",
2429
+ onclick: () => newSessionInProject(project.cwd),
2430
+ title: "New Session",
2431
+ children: ($$renderer4) => {
2432
+ $$renderer4.push(`<iconify-icon icon="mdi:plus"></iconify-icon>`);
2433
+ },
2434
+ $$slots: { default: true }
2435
+ });
2436
+ $$renderer3.push(`<!----> `);
2437
+ if (!compact) {
2438
+ $$renderer3.push("<!--[-->");
2439
+ Button($$renderer3, {
2440
+ variant: "ghost",
2441
+ size: "icon-sm",
2442
+ class: "hover:bg-red-900/50 hover:text-red-300",
2443
+ onclick: () => deleteProject(project.cwd),
2444
+ title: "Delete Project",
2445
+ children: ($$renderer4) => {
2446
+ $$renderer4.push(`<iconify-icon icon="mdi:delete"></iconify-icon>`);
2447
+ },
2448
+ $$slots: { default: true }
2449
+ });
2450
+ } else $$renderer3.push("<!--[!-->");
2451
+ $$renderer3.push(`<!--]--></div></div> <div class="project-sessions svelte-183q6rw">`);
2452
+ const each_array_1 = ensure_array_like(project.sessions);
2453
+ if (each_array_1.length !== 0) {
2454
+ $$renderer3.push("<!--[-->");
2455
+ for (let $$index = 0, $$length2 = each_array_1.length; $$index < $$length2; $$index++) {
2456
+ let session = each_array_1[$$index];
2457
+ if (session.tmux_target) {
2458
+ $$renderer3.push("<!--[-->");
2459
+ const isActive = session.tmux_target === currentTarget;
2460
+ $$renderer3.push(`<a${attr("href", `/session/${stringify(encodeURIComponent(session.tmux_target))}`)}${attr_class(`session ${stringify(session.state)}`, "svelte-183q6rw", { "active": isActive })}><span class="state svelte-183q6rw"${attr_style(`background: ${stringify(stateColor(session.state))}`)}></span> <div class="session-info svelte-183q6rw"><div class="target svelte-183q6rw">${escape_html(session.pane_title || session.tmux_target)}</div> <div class="action svelte-183q6rw">${escape_html(session.current_action || session.state)}</div></div> `);
2461
+ if (!compact) {
2462
+ $$renderer3.push("<!--[-->");
2463
+ $$renderer3.push(`<div class="actions svelte-183q6rw">`);
2464
+ Button($$renderer3, {
2465
+ variant: "ghost-destructive",
2466
+ size: "icon-sm",
2467
+ onclick: (e) => {
2468
+ e.preventDefault();
2469
+ e.stopPropagation();
2470
+ killSession(session.id, session.pid, session.tmux_target);
2471
+ },
2472
+ title: "Kill",
2473
+ children: ($$renderer4) => {
2474
+ $$renderer4.push(`<iconify-icon icon="mdi:power"></iconify-icon>`);
2475
+ },
2476
+ $$slots: { default: true }
2477
+ });
2478
+ $$renderer3.push(`<!----></div>`);
2479
+ } else $$renderer3.push("<!--[!-->");
2480
+ $$renderer3.push(`<!--]--></a>`);
2481
+ } else {
2482
+ $$renderer3.push("<!--[!-->");
2483
+ $$renderer3.push(`<div${attr_class(`session ${stringify(session.state)} no-tmux`, "svelte-183q6rw")}><span class="state svelte-183q6rw"${attr_style(`background: ${stringify(stateColor(session.state))}`)}></span> <div class="session-info svelte-183q6rw"><div class="target svelte-183q6rw">${escape_html(session.id)}</div> <div class="action svelte-183q6rw">${escape_html(session.current_action || session.state)}</div> <div class="no-tmux-label svelte-183q6rw">No tmux pane</div></div> `);
2484
+ if (!compact) {
2485
+ $$renderer3.push("<!--[-->");
2486
+ $$renderer3.push(`<div class="actions svelte-183q6rw">`);
2487
+ Button($$renderer3, {
2488
+ variant: "ghost-destructive",
2489
+ size: "icon-sm",
2490
+ onclick: () => killSession(session.id, session.pid, session.tmux_target),
2491
+ title: "Kill",
2492
+ children: ($$renderer4) => {
2493
+ $$renderer4.push(`<iconify-icon icon="mdi:power"></iconify-icon>`);
2494
+ },
2495
+ $$slots: { default: true }
2496
+ });
2497
+ $$renderer3.push(`<!----></div>`);
2498
+ } else $$renderer3.push("<!--[!-->");
2499
+ $$renderer3.push(`<!--]--></div>`);
2500
+ }
2501
+ $$renderer3.push(`<!--]-->`);
2502
+ }
2503
+ } else {
2504
+ $$renderer3.push("<!--[!-->");
2505
+ $$renderer3.push(`<div class="empty-project svelte-183q6rw">No active sessions</div>`);
2506
+ }
2507
+ $$renderer3.push(`<!--]--></div></div>`);
2508
+ }
2509
+ $$renderer3.push(`<!--]-->`);
2510
+ }
2511
+ $$renderer3.push(`<!--]--> `);
2512
+ if (otherTmuxPanes.length > 0) {
2513
+ $$renderer3.push("<!--[-->");
2514
+ $$renderer3.push(`<div class="other-tmux svelte-183q6rw"><div class="other-tmux-header svelte-183q6rw"><h2 class="svelte-183q6rw">Other tmux</h2> `);
2515
+ Button($$renderer3, {
2516
+ variant: "ghost",
2517
+ size: "icon-sm",
2518
+ onclick: fetchTmuxPanes,
2519
+ title: "Refresh",
2520
+ children: ($$renderer4) => {
2521
+ $$renderer4.push(`<iconify-icon icon="mdi:refresh"></iconify-icon>`);
2522
+ },
2523
+ $$slots: { default: true }
2524
+ });
2525
+ $$renderer3.push(`<!----></div> <div class="other-tmux-list svelte-183q6rw"><!--[-->`);
2526
+ const each_array_2 = ensure_array_like(otherTmuxPanes);
2527
+ for (let $$index_2 = 0, $$length = each_array_2.length; $$index_2 < $$length; $$index_2++) {
2528
+ let pane = each_array_2[$$index_2];
2529
+ $$renderer3.push(`<a${attr("href", `/session/${stringify(encodeURIComponent(pane.target))}`)} class="tmux-pane svelte-183q6rw"><iconify-icon icon="mdi:console" class="pane-icon svelte-183q6rw"></iconify-icon> <div class="pane-info svelte-183q6rw"><span class="pane-target svelte-183q6rw">${escape_html(pane.target)}</span> `);
2530
+ if (!compact) {
2531
+ $$renderer3.push("<!--[-->");
2532
+ $$renderer3.push(`<span class="pane-command svelte-183q6rw">${escape_html(pane.command)}</span>`);
2533
+ } else $$renderer3.push("<!--[!-->");
2534
+ $$renderer3.push(`<!--]--></div></a>`);
2535
+ }
2536
+ $$renderer3.push(`<!--]--></div></div>`);
2537
+ } else $$renderer3.push("<!--[!-->");
2538
+ $$renderer3.push(`<!--]--></div></div> <!---->`);
2539
+ Dialog?.($$renderer3, {
2540
+ get open() {
2541
+ return showFolderBrowser;
2542
+ },
2543
+ set open($$value) {
2544
+ showFolderBrowser = $$value;
2545
+ $$settled = false;
2546
+ },
2547
+ children: ($$renderer4) => {
2548
+ $$renderer4.push(`<!---->`);
2549
+ Dialog_content?.($$renderer4, {
2550
+ class: "max-w-md",
2551
+ children: ($$renderer5) => {
2552
+ $$renderer5.push(`<!---->`);
2553
+ Dialog_header?.($$renderer5, {
2554
+ children: ($$renderer6) => {
2555
+ $$renderer6.push(`<!---->`);
2556
+ Dialog_title?.($$renderer6, {
2557
+ children: ($$renderer7) => {
2558
+ $$renderer7.push(`<!---->Select Folder`);
2559
+ },
2560
+ $$slots: { default: true }
2561
+ });
2562
+ $$renderer6.push(`<!---->`);
2563
+ },
2564
+ $$slots: { default: true }
2565
+ });
2566
+ $$renderer5.push(`<!----> <div class="fb-path svelte-183q6rw">${escape_html(browserPath)}</div> `);
2567
+ if (browserError) {
2568
+ $$renderer5.push("<!--[-->");
2569
+ $$renderer5.push(`<p class="text-sm text-destructive">${escape_html(browserError)}</p>`);
2570
+ } else $$renderer5.push("<!--[!-->");
2571
+ $$renderer5.push(`<!--]--> <div class="flex items-center gap-2 py-2">`);
2572
+ Checkbox($$renderer5, {
2573
+ id: "show-hidden",
2574
+ checked: browserShowHidden,
2575
+ onCheckedChange: (v) => {
2576
+ browserShowHidden = !!v;
2577
+ browseTo(browserPath);
2578
+ }
2579
+ });
2580
+ $$renderer5.push(`<!----> <label for="show-hidden" class="text-sm text-muted-foreground cursor-pointer">Show hidden</label></div> `);
2581
+ Scroll_area($$renderer5, {
2582
+ class: "h-64 rounded-md border",
2583
+ children: ($$renderer6) => {
2584
+ $$renderer6.push(`<div class="p-2">`);
2585
+ if (!browserIsRoot && browserParent) {
2586
+ $$renderer6.push("<!--[-->");
2587
+ $$renderer6.push(`<button class="fb-item svelte-183q6rw"><iconify-icon icon="mdi:folder-arrow-up"></iconify-icon> ..</button>`);
2588
+ } else $$renderer6.push("<!--[!-->");
2589
+ $$renderer6.push(`<!--]--> <!--[-->`);
2590
+ const each_array_3 = ensure_array_like(browserFolders);
2591
+ for (let $$index_3 = 0, $$length = each_array_3.length; $$index_3 < $$length; $$index_3++) {
2592
+ let folder = each_array_3[$$index_3];
2593
+ $$renderer6.push(`<button class="fb-item svelte-183q6rw"><iconify-icon icon="mdi:folder"></iconify-icon> ${escape_html(folder.name)}</button>`);
2594
+ }
2595
+ $$renderer6.push(`<!--]--></div>`);
2596
+ },
2597
+ $$slots: { default: true }
2598
+ });
2599
+ $$renderer5.push(`<!----> <!---->`);
2600
+ Dialog_footer?.($$renderer5, {
2601
+ children: ($$renderer6) => {
2602
+ Button($$renderer6, {
2603
+ variant: "outline",
2604
+ onclick: () => showFolderBrowser = false,
2605
+ children: ($$renderer7) => {
2606
+ $$renderer7.push(`<!---->Cancel`);
2607
+ },
2608
+ $$slots: { default: true }
2609
+ });
2610
+ $$renderer6.push(`<!----> `);
2611
+ Button($$renderer6, {
2612
+ onclick: selectFolder,
2613
+ children: ($$renderer7) => {
2614
+ $$renderer7.push(`<!---->Select`);
2615
+ },
2616
+ $$slots: { default: true }
2617
+ });
2618
+ $$renderer6.push(`<!---->`);
2619
+ },
2620
+ $$slots: { default: true }
2621
+ });
2622
+ $$renderer5.push(`<!---->`);
2623
+ },
2624
+ $$slots: { default: true }
2625
+ });
2626
+ $$renderer4.push(`<!---->`);
2627
+ },
2628
+ $$slots: { default: true }
2629
+ });
2630
+ $$renderer3.push(`<!----> <!---->`);
2631
+ Alert_dialog?.($$renderer3, {
2632
+ get open() {
2633
+ return alertOpen;
2634
+ },
2635
+ set open($$value) {
2636
+ alertOpen = $$value;
2637
+ $$settled = false;
2638
+ },
2639
+ children: ($$renderer4) => {
2640
+ $$renderer4.push(`<!---->`);
2641
+ Alert_dialog_content?.($$renderer4, {
2642
+ children: ($$renderer5) => {
2643
+ $$renderer5.push(`<!---->`);
2644
+ Alert_dialog_header?.($$renderer5, {
2645
+ children: ($$renderer6) => {
2646
+ $$renderer6.push(`<!---->`);
2647
+ Alert_dialog_title?.($$renderer6, {
2648
+ children: ($$renderer7) => {
2649
+ $$renderer7.push(`<!---->${escape_html(alertTitle)}`);
2650
+ },
2651
+ $$slots: { default: true }
2652
+ });
2653
+ $$renderer6.push(`<!----> <!---->`);
2654
+ Alert_dialog_description?.($$renderer6, {
2655
+ children: ($$renderer7) => {
2656
+ $$renderer7.push(`<!---->${escape_html(alertMessage)}`);
2657
+ },
2658
+ $$slots: { default: true }
2659
+ });
2660
+ $$renderer6.push(`<!---->`);
2661
+ },
2662
+ $$slots: { default: true }
2663
+ });
2664
+ $$renderer5.push(`<!----> <!---->`);
2665
+ Alert_dialog_footer?.($$renderer5, {
2666
+ children: ($$renderer6) => {
2667
+ $$renderer6.push(`<!---->`);
2668
+ Alert_dialog_cancel?.($$renderer6, {
2669
+ children: ($$renderer7) => {
2670
+ $$renderer7.push(`<!---->Cancel`);
2671
+ },
2672
+ $$slots: { default: true }
2673
+ });
2674
+ $$renderer6.push(`<!----> <!---->`);
2675
+ Alert_dialog_action?.($$renderer6, {
2676
+ onclick: () => {
2677
+ alertOnConfirm();
2678
+ alertOpen = false;
2679
+ },
2680
+ class: "bg-destructive text-destructive-foreground hover:bg-destructive/90",
2681
+ children: ($$renderer7) => {
2682
+ $$renderer7.push(`<!---->Confirm`);
2683
+ },
2684
+ $$slots: { default: true }
2685
+ });
2686
+ $$renderer6.push(`<!---->`);
2687
+ },
2688
+ $$slots: { default: true }
2689
+ });
2690
+ $$renderer5.push(`<!---->`);
2691
+ },
2692
+ $$slots: { default: true }
2693
+ });
2694
+ $$renderer4.push(`<!---->`);
2695
+ },
2696
+ $$slots: { default: true }
2697
+ });
2698
+ $$renderer3.push(`<!---->`);
2699
+ }
2700
+ do {
2701
+ $$settled = true;
2702
+ $$inner_renderer = $$renderer2.copy();
2703
+ $$render_inner($$inner_renderer);
2704
+ } while (!$$settled);
2705
+ $$renderer2.subsume($$inner_renderer);
2706
+ if ($$store_subs) unsubscribe_stores($$store_subs);
2707
+ });
2708
+ }
2709
+ function _page($$renderer) {
2710
+ head("1uha8ag", $$renderer, ($$renderer2) => {
2711
+ $$renderer2.title(($$renderer3) => {
2712
+ $$renderer3.push(`<title>claude-mux</title>`);
2713
+ });
2714
+ });
2715
+ $$renderer.push(`<div class="root-page svelte-1uha8ag">`);
2716
+ AllSessionsPanel($$renderer, {});
2717
+ $$renderer.push(`<!----></div>`);
2718
+ }
2719
+
2720
+ //#endregion
2721
+ export { _page as default };
2722
+ //# sourceMappingURL=_page.svelte-CnfJk6cu.js.map