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