@juspay/shooter 1.20.0 → 1.22.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 (275) hide show
  1. package/.claude/hooks/notifier.cjs +94 -1
  2. package/build/client/_app/immutable/assets/2.JWRrnR-w.css +1 -0
  3. package/build/client/_app/immutable/assets/2.JWRrnR-w.css.br +0 -0
  4. package/build/client/_app/immutable/assets/2.JWRrnR-w.css.gz +0 -0
  5. package/build/client/_app/immutable/chunks/{ZS5XYDx_.js → B1bOvemT.js} +1 -1
  6. package/build/client/_app/immutable/chunks/B1bOvemT.js.br +0 -0
  7. package/build/client/_app/immutable/chunks/{ZS5XYDx_.js.gz → B1bOvemT.js.gz} +0 -0
  8. package/build/client/_app/immutable/chunks/BfbPKMXz.js +3 -0
  9. package/build/client/_app/immutable/chunks/BfbPKMXz.js.br +0 -0
  10. package/build/client/_app/immutable/chunks/BfbPKMXz.js.gz +0 -0
  11. package/build/client/_app/immutable/chunks/C4Hns_Wl.js +1 -0
  12. package/build/client/_app/immutable/chunks/C4Hns_Wl.js.br +0 -0
  13. package/build/client/_app/immutable/chunks/C4Hns_Wl.js.gz +0 -0
  14. package/build/client/_app/immutable/chunks/C87ZRWX0.js +1 -0
  15. package/build/client/_app/immutable/chunks/C87ZRWX0.js.br +0 -0
  16. package/build/client/_app/immutable/chunks/C87ZRWX0.js.gz +0 -0
  17. package/build/client/_app/immutable/chunks/{BvmdJful.js → CJulw9ux.js} +1 -1
  18. package/build/client/_app/immutable/chunks/CJulw9ux.js.br +0 -0
  19. package/build/client/_app/immutable/chunks/CJulw9ux.js.gz +0 -0
  20. package/build/client/_app/immutable/chunks/{DT4H19pV.js → CZg4kn4E.js} +1 -1
  21. package/build/client/_app/immutable/chunks/CZg4kn4E.js.br +0 -0
  22. package/build/client/_app/immutable/chunks/CZg4kn4E.js.gz +0 -0
  23. package/build/client/_app/immutable/chunks/{DIZ3Qst5.js → DhK7PwI_.js} +1 -1
  24. package/build/client/_app/immutable/chunks/DhK7PwI_.js.br +0 -0
  25. package/build/client/_app/immutable/chunks/{DIZ3Qst5.js.gz → DhK7PwI_.js.gz} +0 -0
  26. package/build/client/_app/immutable/chunks/{ClIPTXf3.js → DomZZqvG.js} +1 -1
  27. package/build/client/_app/immutable/chunks/DomZZqvG.js.br +0 -0
  28. package/build/client/_app/immutable/chunks/DomZZqvG.js.gz +0 -0
  29. package/build/client/_app/immutable/chunks/{BB2l8o4X.js → i5iZvmIH.js} +1 -1
  30. package/build/client/_app/immutable/chunks/i5iZvmIH.js.br +0 -0
  31. package/build/client/_app/immutable/chunks/i5iZvmIH.js.gz +0 -0
  32. package/build/client/_app/immutable/entry/{app.Bd-DfeJi.js → app.CTqz33nP.js} +2 -2
  33. package/build/client/_app/immutable/entry/app.CTqz33nP.js.br +0 -0
  34. package/build/client/_app/immutable/entry/app.CTqz33nP.js.gz +0 -0
  35. package/build/client/_app/immutable/entry/start.Dj-Kvgwo.js +1 -0
  36. package/build/client/_app/immutable/entry/start.Dj-Kvgwo.js.br +2 -0
  37. package/build/client/_app/immutable/entry/start.Dj-Kvgwo.js.gz +0 -0
  38. package/build/client/_app/immutable/nodes/0.Qn7Ktiht.js +10 -0
  39. package/build/client/_app/immutable/nodes/0.Qn7Ktiht.js.br +0 -0
  40. package/build/client/_app/immutable/nodes/0.Qn7Ktiht.js.gz +0 -0
  41. package/build/client/_app/immutable/nodes/{1.DT4dq6Ay.js → 1.BxWOfNlo.js} +1 -1
  42. package/build/client/_app/immutable/nodes/1.BxWOfNlo.js.br +0 -0
  43. package/build/client/_app/immutable/nodes/1.BxWOfNlo.js.gz +0 -0
  44. package/build/client/_app/immutable/nodes/{10.CF7RGXpe.js → 10.BGPYD1s1.js} +1 -1
  45. package/build/client/_app/immutable/nodes/10.BGPYD1s1.js.br +0 -0
  46. package/build/client/_app/immutable/nodes/10.BGPYD1s1.js.gz +0 -0
  47. package/build/client/_app/immutable/nodes/{11.BV_G7yLI.js → 11.BxY1PUjC.js} +1 -1
  48. package/build/client/_app/immutable/nodes/11.BxY1PUjC.js.br +0 -0
  49. package/build/client/_app/immutable/nodes/11.BxY1PUjC.js.gz +0 -0
  50. package/build/client/_app/immutable/nodes/2.Bc2qALkX.js +23 -0
  51. package/build/client/_app/immutable/nodes/2.Bc2qALkX.js.br +0 -0
  52. package/build/client/_app/immutable/nodes/2.Bc2qALkX.js.gz +0 -0
  53. package/build/client/_app/immutable/nodes/{3.0MMe3oxR.js → 3.N2-A8noI.js} +1 -1
  54. package/build/client/_app/immutable/nodes/3.N2-A8noI.js.br +0 -0
  55. package/build/client/_app/immutable/nodes/3.N2-A8noI.js.gz +0 -0
  56. package/build/client/_app/immutable/nodes/{4.CBX9A3ka.js → 4.BFYS2g9C.js} +3 -3
  57. package/build/client/_app/immutable/nodes/4.BFYS2g9C.js.br +0 -0
  58. package/build/client/_app/immutable/nodes/4.BFYS2g9C.js.gz +0 -0
  59. package/build/client/_app/immutable/nodes/{5.DIVKuZc9.js → 5.DziEu9rx.js} +1 -1
  60. package/build/client/_app/immutable/nodes/5.DziEu9rx.js.br +0 -0
  61. package/build/client/_app/immutable/nodes/5.DziEu9rx.js.gz +0 -0
  62. package/build/client/_app/immutable/nodes/{6.ComiWlV6.js → 6.BWF9Qx6F.js} +1 -1
  63. package/build/client/_app/immutable/nodes/6.BWF9Qx6F.js.br +0 -0
  64. package/build/client/_app/immutable/nodes/6.BWF9Qx6F.js.gz +0 -0
  65. package/build/client/_app/immutable/nodes/{7.vkPx1kVP.js → 7.DHuDIdpz.js} +1 -1
  66. package/build/client/_app/immutable/nodes/7.DHuDIdpz.js.br +0 -0
  67. package/build/client/_app/immutable/nodes/7.DHuDIdpz.js.gz +0 -0
  68. package/build/client/_app/immutable/nodes/{8.Bmr3sWbS.js → 8.D0Ijt9Vv.js} +1 -1
  69. package/build/client/_app/immutable/nodes/8.D0Ijt9Vv.js.br +0 -0
  70. package/build/client/_app/immutable/nodes/8.D0Ijt9Vv.js.gz +0 -0
  71. package/build/client/_app/immutable/nodes/{9.CAJucyeI.js → 9.2Piwo35J.js} +1 -1
  72. package/build/client/_app/immutable/nodes/9.2Piwo35J.js.br +0 -0
  73. package/build/client/_app/immutable/nodes/9.2Piwo35J.js.gz +0 -0
  74. package/build/client/_app/version.json +1 -1
  75. package/build/client/_app/version.json.br +0 -0
  76. package/build/client/_app/version.json.gz +0 -0
  77. package/build/pty-holder.cjs +6 -0
  78. package/build/server/chunks/{0-DDGB6CRT.js → 0-CVGsyVKN.js} +4 -2
  79. package/build/server/chunks/0-CVGsyVKN.js.map +1 -0
  80. package/build/server/chunks/{1-DEjonQXD.js → 1-BAlAsKdp.js} +2 -2
  81. package/build/server/chunks/{1-DEjonQXD.js.map → 1-BAlAsKdp.js.map} +1 -1
  82. package/build/server/chunks/{10-BK1kiiiw.js → 10-BUCX7Aqz.js} +2 -2
  83. package/build/server/chunks/{10-BK1kiiiw.js.map → 10-BUCX7Aqz.js.map} +1 -1
  84. package/build/server/chunks/{11-CJPjkEF3.js → 11-DHPvc2yA.js} +2 -2
  85. package/build/server/chunks/{11-CJPjkEF3.js.map → 11-DHPvc2yA.js.map} +1 -1
  86. package/build/server/chunks/{2-RLnhlWh5.js → 2-DLOMdCHW.js} +4 -4
  87. package/build/server/chunks/{2-RLnhlWh5.js.map → 2-DLOMdCHW.js.map} +1 -1
  88. package/build/server/chunks/{3-Dd4pJBqZ.js → 3-DCf69LYo.js} +2 -2
  89. package/build/server/chunks/{3-Dd4pJBqZ.js.map → 3-DCf69LYo.js.map} +1 -1
  90. package/build/server/chunks/{4-Bb5VFhsO.js → 4-D92KnTmb.js} +3 -3
  91. package/build/server/chunks/{4-Bb5VFhsO.js.map → 4-D92KnTmb.js.map} +1 -1
  92. package/build/server/chunks/{5-oNoWuIsn.js → 5-D-Uv1voC.js} +2 -2
  93. package/build/server/chunks/{5-oNoWuIsn.js.map → 5-D-Uv1voC.js.map} +1 -1
  94. package/build/server/chunks/{6-DdRMnKNa.js → 6-DUrC2Naz.js} +2 -2
  95. package/build/server/chunks/{6-DdRMnKNa.js.map → 6-DUrC2Naz.js.map} +1 -1
  96. package/build/server/chunks/{7-vLOMMetm.js → 7-TXwjMHt2.js} +2 -2
  97. package/build/server/chunks/{7-vLOMMetm.js.map → 7-TXwjMHt2.js.map} +1 -1
  98. package/build/server/chunks/{8-rJyiQLFs.js → 8-D2X_jBsT.js} +2 -2
  99. package/build/server/chunks/{8-rJyiQLFs.js.map → 8-D2X_jBsT.js.map} +1 -1
  100. package/build/server/chunks/{9-CVSNNYED.js → 9-DK0hH5Xa.js} +2 -2
  101. package/build/server/chunks/{9-CVSNNYED.js.map → 9-DK0hH5Xa.js.map} +1 -1
  102. package/build/server/chunks/Banner-BgaAs1rs.js.map +1 -1
  103. package/build/server/chunks/Button-D0hZ7JYt.js.map +1 -1
  104. package/build/server/chunks/Icon-D0GBnDcs.js.map +1 -1
  105. package/build/server/chunks/Input-OmIiydSx.js.map +1 -1
  106. package/build/server/chunks/Pill-4xJ-VhAA.js.map +1 -1
  107. package/build/server/chunks/Shimmer-Dw2uvTC1.js.map +1 -1
  108. package/build/server/chunks/_error.svelte-CZnkxeLr.js.map +1 -1
  109. package/build/server/chunks/_layout.svelte-DfgNGGiM.js.map +1 -1
  110. package/build/server/chunks/_page.svelte-8OFzwdNA.js +758 -0
  111. package/build/server/chunks/_page.svelte-8OFzwdNA.js.map +1 -0
  112. package/build/server/chunks/_page.svelte-BTlfUsBp.js.map +1 -1
  113. package/build/server/chunks/_page.svelte-C7B0qdrC.js.map +1 -1
  114. package/build/server/chunks/{_page.svelte-BLo2v_8E.js → _page.svelte-Gv9p8nlS.js} +3 -4
  115. package/build/server/chunks/_page.svelte-Gv9p8nlS.js.map +1 -0
  116. package/build/server/chunks/_page.svelte-dabsQl9c.js.map +1 -1
  117. package/build/server/chunks/{_server.ts-bk_EeAdY.js → _server.ts-05JJOdcX.js} +20 -14
  118. package/build/server/chunks/_server.ts-05JJOdcX.js.map +1 -0
  119. package/build/server/chunks/{_server.ts-DEx9-epI.js → _server.ts-B54Pvhgc.js} +4 -3
  120. package/build/server/chunks/_server.ts-B54Pvhgc.js.map +1 -0
  121. package/build/server/chunks/_server.ts-BB46Fbqn.js +59 -0
  122. package/build/server/chunks/_server.ts-BB46Fbqn.js.map +1 -0
  123. package/build/server/chunks/{_server.ts-BRAzC6W1.js → _server.ts-BCljU9Sg.js} +33 -8
  124. package/build/server/chunks/_server.ts-BCljU9Sg.js.map +1 -0
  125. package/build/server/chunks/{_server.ts-D-vgx5UZ.js → _server.ts-BTmknWpO.js} +2 -2
  126. package/build/server/chunks/{_server.ts-D-vgx5UZ.js.map → _server.ts-BTmknWpO.js.map} +1 -1
  127. package/build/server/chunks/{_server.ts-tChyh9FX.js → _server.ts-BXhmLZwN.js} +4 -2
  128. package/build/server/chunks/{_server.ts-tChyh9FX.js.map → _server.ts-BXhmLZwN.js.map} +1 -1
  129. package/build/server/chunks/{_server.ts-CvJKTS3Z.js → _server.ts-BbRSpB74.js} +4 -2
  130. package/build/server/chunks/{_server.ts-CvJKTS3Z.js.map → _server.ts-BbRSpB74.js.map} +1 -1
  131. package/build/server/chunks/{_server.ts-DKNIsQeH.js → _server.ts-Bol54_Qo.js} +4 -3
  132. package/build/server/chunks/_server.ts-Bol54_Qo.js.map +1 -0
  133. package/build/server/chunks/{_server.ts-Dz9Jd9Jh.js → _server.ts-C0PO_cAu.js} +4 -3
  134. package/build/server/chunks/{_server.ts-Dz9Jd9Jh.js.map → _server.ts-C0PO_cAu.js.map} +1 -1
  135. package/build/server/chunks/_server.ts-C6NRpe7e.js +33 -0
  136. package/build/server/chunks/_server.ts-C6NRpe7e.js.map +1 -0
  137. package/build/server/chunks/_server.ts-CGqCOCdK.js +53 -0
  138. package/build/server/chunks/_server.ts-CGqCOCdK.js.map +1 -0
  139. package/build/server/chunks/{_server.ts-B2wIgsW4.js → _server.ts-CZb-BI5H.js} +4 -3
  140. package/build/server/chunks/_server.ts-CZb-BI5H.js.map +1 -0
  141. package/build/server/chunks/_server.ts-DPHRUFYS.js +159 -0
  142. package/build/server/chunks/_server.ts-DPHRUFYS.js.map +1 -0
  143. package/build/server/chunks/{_server.ts-AnBXfZXh.js → _server.ts-D_WRex0k.js} +5 -3
  144. package/build/server/chunks/_server.ts-D_WRex0k.js.map +1 -0
  145. package/build/server/chunks/{_server.ts-CJGyN8mw.js → _server.ts-DiBMY7Ho.js} +4 -3
  146. package/build/server/chunks/_server.ts-DiBMY7Ho.js.map +1 -0
  147. package/build/server/chunks/cache-BlMaDsHi.js.map +1 -1
  148. package/build/server/chunks/{guest-registry-t0-7Zv5q.js → guest-registry-Dxvd7p-g.js} +10 -1
  149. package/build/server/chunks/guest-registry-Dxvd7p-g.js.map +1 -0
  150. package/build/server/chunks/index-CoYB03g7.js.map +1 -1
  151. package/build/server/chunks/index2-dSGQ9Eaa.js.map +1 -1
  152. package/build/server/chunks/{library-apns-Dl3iRE2h.js → library-apns-D8RPINlv.js} +62 -7
  153. package/build/server/chunks/library-apns-D8RPINlv.js.map +1 -0
  154. package/build/server/chunks/{pending-requests-C9p57WoU.js → pending-requests-8rWjrF6d.js} +3 -2
  155. package/build/server/chunks/pending-requests-8rWjrF6d.js.map +1 -0
  156. package/build/server/chunks/presence-store-Bx_g0-Gd.js +23 -0
  157. package/build/server/chunks/presence-store-Bx_g0-Gd.js.map +1 -0
  158. package/build/server/chunks/{pty-manager-CkZNoW1t.js → pty-manager-CoWVT56F.js} +27 -6
  159. package/build/server/chunks/pty-manager-CoWVT56F.js.map +1 -0
  160. package/build/server/chunks/root-D4IoFC8F.js.map +1 -1
  161. package/build/server/chunks/shooter-home-4f_HkdGI.js +10 -0
  162. package/build/server/chunks/shooter-home-4f_HkdGI.js.map +1 -0
  163. package/build/server/chunks/state.svelte-CmHqngc_.js.map +1 -1
  164. package/build/server/index.js +1 -1
  165. package/build/server/index.js.map +1 -1
  166. package/build/server/manifest.js +52 -24
  167. package/build/server/manifest.js.map +1 -1
  168. package/package.json +2 -2
  169. package/server.ts +2 -0
  170. package/src/lib/modules/client/common/index.ts +1 -0
  171. package/src/lib/modules/client/common/presence.ts +47 -0
  172. package/src/lib/modules/client/dashboard/AutopilotPanel.svelte +584 -0
  173. package/src/lib/modules/client/dashboard/autopilot-driver.svelte.ts +681 -0
  174. package/src/lib/modules/client/dashboard/decide-injection.ts +127 -0
  175. package/src/lib/modules/client/dashboard/index.ts +1 -0
  176. package/src/lib/modules/client/dashboard/store.svelte.ts +65 -24
  177. package/src/lib/modules/client/neurolink/fetch-proxy.ts +38 -1
  178. package/src/lib/modules/client/neurolink/provider-config.ts +13 -37
  179. package/src/lib/modules/server/apn/apns-payload.ts +50 -0
  180. package/src/lib/modules/server/apn/library-apns.ts +50 -8
  181. package/src/lib/modules/server/apn/pending-requests.ts +3 -1
  182. package/src/lib/modules/server/sessions/autopilot-context.ts +57 -0
  183. package/src/lib/modules/server/sessions/autopilot-engine.ts +451 -0
  184. package/src/lib/modules/server/sessions/litellm-client.ts +171 -0
  185. package/src/lib/modules/server/sessions/next-step-consensus.ts +210 -0
  186. package/src/lib/modules/server/sessions/summary-store.ts +113 -0
  187. package/src/lib/modules/server/terminal/agent-launch.ts +26 -0
  188. package/src/lib/modules/server/terminal/pty-holder.cjs +6 -0
  189. package/src/lib/modules/server/terminal/pty-manager.ts +13 -3
  190. package/src/lib/modules/server/terminal/session-watcher.ts +12 -2
  191. package/src/lib/modules/server/terminal/terminal-store.ts +3 -1
  192. package/src/lib/modules/server/utils/shooter-home.ts +16 -0
  193. package/src/lib/modules/server/ws/events-handler.ts +32 -0
  194. package/src/lib/modules/server/ws/presence-store.ts +50 -0
  195. package/src/lib/types/autopilot.ts +138 -0
  196. package/src/lib/types/index.ts +1 -0
  197. package/src/lib/types/terminal-client.ts +2 -0
  198. package/src/routes/+layout.server.ts +2 -0
  199. package/src/routes/+layout.svelte +19 -4
  200. package/src/routes/+page.svelte +9 -1
  201. package/src/routes/api/autopilot/+server.ts +74 -0
  202. package/src/routes/api/autopilot/goal/+server.ts +72 -0
  203. package/src/routes/api/neurolink-proxy/+server.ts +39 -8
  204. package/src/routes/api/notify/+server.ts +38 -14
  205. package/src/routes/api/presence/+server.ts +39 -0
  206. package/src/routes/api/summaries/+server.ts +99 -0
  207. package/src/routes/api/ws-status/+server.ts +8 -5
  208. package/build/client/_app/immutable/assets/2.DjiwkLqE.css +0 -1
  209. package/build/client/_app/immutable/assets/2.DjiwkLqE.css.br +0 -0
  210. package/build/client/_app/immutable/assets/2.DjiwkLqE.css.gz +0 -0
  211. package/build/client/_app/immutable/chunks/BB2l8o4X.js.br +0 -0
  212. package/build/client/_app/immutable/chunks/BB2l8o4X.js.gz +0 -0
  213. package/build/client/_app/immutable/chunks/BvmdJful.js.br +0 -0
  214. package/build/client/_app/immutable/chunks/BvmdJful.js.gz +0 -0
  215. package/build/client/_app/immutable/chunks/CRkG7oE4.js +0 -1
  216. package/build/client/_app/immutable/chunks/CRkG7oE4.js.br +0 -0
  217. package/build/client/_app/immutable/chunks/CRkG7oE4.js.gz +0 -0
  218. package/build/client/_app/immutable/chunks/C_YNQL8b.js +0 -3
  219. package/build/client/_app/immutable/chunks/C_YNQL8b.js.br +0 -0
  220. package/build/client/_app/immutable/chunks/C_YNQL8b.js.gz +0 -0
  221. package/build/client/_app/immutable/chunks/ClIPTXf3.js.br +0 -0
  222. package/build/client/_app/immutable/chunks/ClIPTXf3.js.gz +0 -0
  223. package/build/client/_app/immutable/chunks/DIZ3Qst5.js.br +0 -0
  224. package/build/client/_app/immutable/chunks/DT4H19pV.js.br +0 -0
  225. package/build/client/_app/immutable/chunks/DT4H19pV.js.gz +0 -0
  226. package/build/client/_app/immutable/chunks/ZS5XYDx_.js.br +0 -0
  227. package/build/client/_app/immutable/chunks/pRcLbE0d.js +0 -1
  228. package/build/client/_app/immutable/chunks/pRcLbE0d.js.br +0 -0
  229. package/build/client/_app/immutable/chunks/pRcLbE0d.js.gz +0 -0
  230. package/build/client/_app/immutable/entry/app.Bd-DfeJi.js.br +0 -0
  231. package/build/client/_app/immutable/entry/app.Bd-DfeJi.js.gz +0 -0
  232. package/build/client/_app/immutable/entry/start.evvp4tX7.js +0 -1
  233. package/build/client/_app/immutable/entry/start.evvp4tX7.js.br +0 -2
  234. package/build/client/_app/immutable/entry/start.evvp4tX7.js.gz +0 -0
  235. package/build/client/_app/immutable/nodes/0.Bl-1LQWM.js +0 -10
  236. package/build/client/_app/immutable/nodes/0.Bl-1LQWM.js.br +0 -0
  237. package/build/client/_app/immutable/nodes/0.Bl-1LQWM.js.gz +0 -0
  238. package/build/client/_app/immutable/nodes/1.DT4dq6Ay.js.br +0 -0
  239. package/build/client/_app/immutable/nodes/1.DT4dq6Ay.js.gz +0 -0
  240. package/build/client/_app/immutable/nodes/10.CF7RGXpe.js.br +0 -0
  241. package/build/client/_app/immutable/nodes/10.CF7RGXpe.js.gz +0 -0
  242. package/build/client/_app/immutable/nodes/11.BV_G7yLI.js.br +0 -0
  243. package/build/client/_app/immutable/nodes/11.BV_G7yLI.js.gz +0 -0
  244. package/build/client/_app/immutable/nodes/2.DcRhsjYp.js +0 -13
  245. package/build/client/_app/immutable/nodes/2.DcRhsjYp.js.br +0 -0
  246. package/build/client/_app/immutable/nodes/2.DcRhsjYp.js.gz +0 -0
  247. package/build/client/_app/immutable/nodes/3.0MMe3oxR.js.br +0 -0
  248. package/build/client/_app/immutable/nodes/3.0MMe3oxR.js.gz +0 -0
  249. package/build/client/_app/immutable/nodes/4.CBX9A3ka.js.br +0 -0
  250. package/build/client/_app/immutable/nodes/4.CBX9A3ka.js.gz +0 -0
  251. package/build/client/_app/immutable/nodes/5.DIVKuZc9.js.br +0 -0
  252. package/build/client/_app/immutable/nodes/5.DIVKuZc9.js.gz +0 -0
  253. package/build/client/_app/immutable/nodes/6.ComiWlV6.js.br +0 -0
  254. package/build/client/_app/immutable/nodes/6.ComiWlV6.js.gz +0 -0
  255. package/build/client/_app/immutable/nodes/7.vkPx1kVP.js.br +0 -0
  256. package/build/client/_app/immutable/nodes/7.vkPx1kVP.js.gz +0 -0
  257. package/build/client/_app/immutable/nodes/8.Bmr3sWbS.js.br +0 -0
  258. package/build/client/_app/immutable/nodes/8.Bmr3sWbS.js.gz +0 -0
  259. package/build/client/_app/immutable/nodes/9.CAJucyeI.js.br +0 -0
  260. package/build/client/_app/immutable/nodes/9.CAJucyeI.js.gz +0 -0
  261. package/build/server/chunks/0-DDGB6CRT.js.map +0 -1
  262. package/build/server/chunks/_page.svelte-BLo2v_8E.js.map +0 -1
  263. package/build/server/chunks/_page.svelte-tBuIq8Pg.js +0 -159
  264. package/build/server/chunks/_page.svelte-tBuIq8Pg.js.map +0 -1
  265. package/build/server/chunks/_server.ts-AnBXfZXh.js.map +0 -1
  266. package/build/server/chunks/_server.ts-B2wIgsW4.js.map +0 -1
  267. package/build/server/chunks/_server.ts-BRAzC6W1.js.map +0 -1
  268. package/build/server/chunks/_server.ts-CJGyN8mw.js.map +0 -1
  269. package/build/server/chunks/_server.ts-DEx9-epI.js.map +0 -1
  270. package/build/server/chunks/_server.ts-DKNIsQeH.js.map +0 -1
  271. package/build/server/chunks/_server.ts-bk_EeAdY.js.map +0 -1
  272. package/build/server/chunks/guest-registry-t0-7Zv5q.js.map +0 -1
  273. package/build/server/chunks/library-apns-Dl3iRE2h.js.map +0 -1
  274. package/build/server/chunks/pending-requests-C9p57WoU.js.map +0 -1
  275. package/build/server/chunks/pty-manager-CkZNoW1t.js.map +0 -1
@@ -1,2 +1,2 @@
1
- import{p as fe,j as Ve,i as H,a as _,s as D,f as b,t as We}from"../chunks/BPDiEZo0.js";import{p as ke,v as $e,A as _e,w as De,b as i,c as n,r as s,t as K,g as e,s as P,x as C,q as Ke,d as c,B as he,y as Ye,D as Ue,$ as Xe}from"../chunks/DWmC0QM7.js";import{T as Pe,s as Le,d as le,f as et,e as ge,C as tt,S as at,I as st,B as ne,b as Be,c as Ae,i as rt,P as Ie,g as nt}from"../chunks/ZS5XYDx_.js";import{h as lt}from"../chunks/2rBV5OkJ.js";import{g as Oe}from"../chunks/C_YNQL8b.js";import{R as it,S as ot}from"../chunks/BvmdJful.js";import{S as ct}from"../chunks/CG453M9q.js";import{T as dt}from"../chunks/CSjf4fBs.js";import{c as ut,s as Ee,g as vt}from"../chunks/xs1Xl3_e.js";import{i as mt}from"../chunks/gQJcRhou.js";import"../chunks/BDcFu3l7.js";import{A as pt}from"../chunks/BdtLzPpO.js";import{E as Ne}from"../chunks/ClIPTXf3.js";var ft=b("<time> </time>"),ht=b("<time> </time>");function je(ie,d){ke(d,!0);let U=fe(d,"format",3,"long"),L=fe(d,"updateInterval",3,6e4),B=fe(d,"tooltip",3,!1),v=C(()=>d.date instanceof Date?d.date:new Date(d.date)),w=C(()=>e(v).toISOString()),M=C(()=>e(v).toLocaleString(d.locale,{dateStyle:"full",timeStyle:"short"})),x=P("");function h(){const S=Date.now(),f=e(v).getTime()-S,u=Math.abs(f),g=Math.round(u/1e3),J=Math.round(u/6e4),R=Math.round(u/36e5),z=Math.round(u/864e5),F=Math.round(u/6048e5),ee=Math.round(u/2592e6),Q=Math.round(u/31536e6),te=new Intl.RelativeTimeFormat(d.locale,{style:U()});let A,o;g<60?(A="second",o=g):J<60?(A="minute",o=J):R<24?(A="hour",o=R):z<7?(A="day",o=z):F<4?(A="week",o=F):ee<12?(A="month",o=ee):(A="year",o=Q);const E=f<0?-1:1;return te.format(E*o,A)}function O(){i(x,h(),!0)}$e(()=>{if(O(),L()>0){const S=setInterval(O,L());return()=>clearInterval(S)}});var X=Ve(),oe=_e(X);{var ce=S=>{Pe(S,{get text(){return e(M)},children:(m,f)=>{var u=ft(),g=n(u,!0);s(u),K(()=>{Le(u,1,`relative-time ${d.classes??""??""}`,"svelte-o98vko"),le(u,"datetime",e(w)),le(u,"data-pw",typeof d.testId=="string"?d.testId:null),D(g,e(x))}),_(m,u)},$$slots:{default:!0}})},q=S=>{var m=ht(),f=n(m,!0);s(m),K(()=>{Le(m,1,`relative-time ${d.classes??""??""}`,"svelte-o98vko"),le(m,"datetime",e(w)),le(m,"data-pw",typeof d.testId=="string"?d.testId:null),D(f,e(x))}),_(S,m)};H(oe,S=>{B()?S(ce):S(q,-1)})}_(ie,X),De()}var gt=b('<div class="section svelte-plslui"><span class="section-label svelte-plslui">Quick Launch</span> <div class="preset-grid svelte-plslui"></div></div> <div class="section svelte-plslui"><span class="section-label svelte-plslui">Working Directory</span> <!> <div class="custom-cwd-group svelte-plslui"><!></div></div> <!> <!>',1);function _t(ie,d){ke(d,!0);let U=fe(d,"open",15,!1);const L=[{args:[],command:"claude",label:"Claude Code"},{args:[],command:"codex",label:"Codex"},{args:[],command:"gemini",label:"Gemini"},{args:[],command:"qwen",label:"Qwen"},{args:[],command:"cursor-agent",label:"Cursor"},{args:[],command:"copilot",label:"Copilot"},{args:[],command:"amp",label:"Amp"},{args:[],command:"opencode",label:"OpenCode"},{args:[],command:"zsh",label:"Shell / zsh"},{args:[],command:"bash",label:"Bash"}];let B=P(0),v=P(Ke([])),w=P(""),M=P(""),x=P(!1),h=P("");$e(()=>{O()});async function O(){try{const m=await fetch("/api/sessions?limit=50&offset=0",{headers:{Authorization:`Bearer ${d.apiKey}`}});if(!m.ok)return;const u=(await m.json()).projects.map(g=>g.fullPath).filter(g=>typeof g=="string"&&g.length>0);i(v,[...new Set(u)],!0),e(v).length>0&&!e(w)&&i(w,e(v)[0],!0)}catch{}}function X(m){i(B,m,!0)}function oe(){return L[e(B)].command}function ce(){return L[e(B)].args}function q(){const m=e(M).trim();return m||(e(w)?e(w):"/tmp")}async function S(){const m=oe();if(m){i(x,!0),i(h,"");try{const f=await fetch("/api/terminals",{body:JSON.stringify({args:ce(),command:m,cwd:q()||void 0}),headers:{Authorization:`Bearer ${d.apiKey}`,"Content-Type":"application/json"},method:"POST"});if(!f.ok){const g=await f.json().catch(()=>({}));i(h,(typeof g.error=="string"?g.error:"")||`Failed to launch (${f.status})`,!0);return}const u=await f.json();d.onLaunch(u)}catch{i(h,"Network error — is the server running?")}finally{i(x,!1)}}}et(ie,{side:"bottom",title:"New Terminal",get onclose(){return d.onClose},classes:"launch-sheet",get open(){return U()},set open(f){U(f)},content:f=>{var u=gt(),g=_e(u),J=c(n(g),2);ge(J,23,()=>L,o=>o.label,(o,E,k)=>{{let de=C(()=>e(B)===e(k));tt(o,{mode:"radio",get selected(){return e(de)},onclick:()=>{X(e(k))},classes:"preset-choice",children:(ue,we)=>{he();var ve=We();K(()=>D(ve,e(E).label)),_(ue,ve)},$$slots:{default:!0}})}}),s(J),s(g);var R=c(g,2),z=c(n(R),2);{let o=C(()=>e(v).length>0?e(v).map(k=>({id:k,label:k})):[{id:"",label:"No recent projects"}]),E=C(()=>e(w)?[e(w)]:e(v).length>0?[e(v)[0]]:[""]);at(z,{get items(){return e(o)},get value(){return e(E)},placeholder:"Select a project",onchange:k=>{i(w,k[0]||"",!0)},classes:"launch-select"})}var F=c(z,2),ee=n(F);st(ee,{label:"Or enter a custom path",dataType:"text",placeholder:"/path/to/project",classes:"input-mono launch-input",get value(){return e(M)},set value(o){i(M,o,!0)}}),s(F),s(R);var Q=c(R,2);{let o=C(()=>e(x)?"Launching...":"Launch Terminal");ne(Q,{classes:"btn-launch",get disabled(){return e(x)},onclick:S,get showLoader(){return e(x)},get text(){return e(o)}})}var te=c(Q,2);{var A=o=>{Be(o,{get text(){return e(h)},classes:"banner-error launch-error-banner"})};H(te,o=>{e(h)&&o(A)})}_(f,u)},$$slots:{content:!0}}),De()}var wt=b('<meta name="description" content="Active terminal sessions on this machine"/>'),bt=b("<!> Refresh",1),xt=b('<span class="plus-icon svelte-1ewpmn2">+</span> New Terminal',1),yt=b('<div class="loading-container"></div>'),St=b('<span class="plus-icon svelte-1ewpmn2">+</span> New Terminal',1),Ct=b('<span class="terminal-cwd svelte-1ewpmn2"> </span>'),Tt=b('<div class="terminal-preview svelte-1ewpmn2"><span class="terminal-preview-text svelte-1ewpmn2"> </span></div>'),At=b('<a class="terminal-card svelte-1ewpmn2"><div class="terminal-card-header svelte-1ewpmn2"><div class="terminal-card-left svelte-1ewpmn2"><span class="status-indicator status-running svelte-1ewpmn2"><span></span></span> <span class="terminal-command svelte-1ewpmn2"> </span> <!></div> <!></div> <div class="terminal-card-meta svelte-1ewpmn2"><!> <span class="terminal-pid svelte-1ewpmn2"> </span></div> <!></a>'),It=b('<span class="terminal-cwd svelte-1ewpmn2"> </span>'),Pt=b('<div class="terminal-preview svelte-1ewpmn2"><span class="terminal-preview-text svelte-1ewpmn2"> </span></div>'),Lt=b('<a class="terminal-card terminal-card-exited svelte-1ewpmn2"><div class="terminal-card-header svelte-1ewpmn2"><div class="terminal-card-left svelte-1ewpmn2"><span class="status-indicator status-exited svelte-1ewpmn2"><span class="status-dot-static"></span></span> <span class="terminal-command svelte-1ewpmn2"> </span> <!> <!></div> <div class="terminal-card-right svelte-1ewpmn2"><!> <!></div></div> <div class="terminal-card-meta svelte-1ewpmn2"><!></div> <!></a>'),kt=b('<div class="terminals-container svelte-1ewpmn2"><!> <!></div>'),$t=b('<main class="main"><div class="page-header"><div class="page-header-content"><div><h1 class="page-title">Terminals</h1> <p class="page-description">Active terminal sessions on this machine</p></div> <div class="page-actions"><!> <!></div></div></div> <!> <!></main> <!>',1);function Jt(ie,d){ke(d,!0);const U=1e4,L="shooter_terminals",B=["zsh","bash","sh","fish"];let v=P(Ke([])),w=P(!1),M=!1,x=P(null),h=P(null),O=null;const X=C(()=>e(v).filter(t=>t.status==="running")),oe=C(()=>e(v).filter(t=>t.status==="exited"));$e(()=>{ce();const t=vt(L,1e4);t&&(i(v,t,!0),i(w,!1)),q(),O=setInterval(()=>{e(h)?.apiKey&&q()},U)}),Ye(()=>{O&&(clearInterval(O),O=null)});function ce(){try{const t=localStorage.getItem("shooter_config");if(t){const a=JSON.parse(t);mt(a)?i(h,a,!0):(localStorage.removeItem("shooter_config"),i(h,null))}}catch{}}async function q(){if(!(!e(h)?.apiKey||M)){M=!0,e(v).length===0&&i(w,!0);try{const a=await fetch("/api/terminals",{headers:{Authorization:`Bearer ${e(h).apiKey}`}});if(!a.ok){i(x,`Failed to load terminals (HTTP ${a.status})`);return}i(x,null);const r=await a.json();i(v,r.terminals.map(y=>({...y,lastOutput:y.lastOutput??null})),!0),Ee(L,e(v))}catch(t){i(x,"Failed to load terminals"),console.error("Failed to fetch terminals:",t)}finally{i(w,!1),M=!1}}}async function S(){i(w,!0),ut(L),await q()}function m(){Oe("/config")}let f=P(!1);function u(){i(f,!0)}function g(){i(f,!1)}function J(t){i(f,!1),Oe(`/terminals/${t.id}`)}function R(t){const a=t.split("/").pop()||t;return pt.includes(a)?"ai":(B.includes(a),"shell")}function z(t){return t.status==="exited"?{class:"pill-badge-ended",label:"ENDED"}:R(t.command)==="ai"?{class:"pill-badge-ai",label:"AI"}:{class:"pill-badge-shell",label:"SHELL"}}function F(t,a=40){if(t.length<=a)return t;const r=t.split("/");return r.length<=3?t:`${r[0]}/.../${r.slice(-2).join("/")}`}function ee(t){return t.replace(/\x1b\[[0-9;]*[a-zA-Z]|\x1b\][^\x07]*\x07|\x1b\[[\?]?[0-9;]*[a-zA-Z]|\x1b/g,"").replace(/[\x00-\x1f]/g,"").trim()}function Q(t,a=80){if(!t)return"";const r=t.split(`
1
+ import{p as fe,j as Ve,i as H,a as _,s as D,f as b,t as We}from"../chunks/BPDiEZo0.js";import{p as ke,v as $e,A as _e,w as De,b as i,c as n,r as s,t as K,g as e,s as P,x as C,q as Ke,d as c,B as he,y as Ye,D as Ue,$ as Xe}from"../chunks/DWmC0QM7.js";import{T as Pe,s as Le,d as le,f as et,e as ge,C as tt,S as at,I as st,B as ne,b as Be,c as Ae,i as rt,P as Ie,g as nt}from"../chunks/B1bOvemT.js";import{h as lt}from"../chunks/2rBV5OkJ.js";import{g as Oe}from"../chunks/BfbPKMXz.js";import{R as it,S as ot}from"../chunks/CJulw9ux.js";import{S as ct}from"../chunks/CG453M9q.js";import{T as dt}from"../chunks/CSjf4fBs.js";import{c as ut,s as Ee,g as vt}from"../chunks/xs1Xl3_e.js";import{i as mt}from"../chunks/gQJcRhou.js";import"../chunks/BDcFu3l7.js";import{A as pt}from"../chunks/BdtLzPpO.js";import{E as Ne}from"../chunks/DomZZqvG.js";var ft=b("<time> </time>"),ht=b("<time> </time>");function je(ie,d){ke(d,!0);let U=fe(d,"format",3,"long"),L=fe(d,"updateInterval",3,6e4),B=fe(d,"tooltip",3,!1),v=C(()=>d.date instanceof Date?d.date:new Date(d.date)),w=C(()=>e(v).toISOString()),M=C(()=>e(v).toLocaleString(d.locale,{dateStyle:"full",timeStyle:"short"})),x=P("");function h(){const S=Date.now(),f=e(v).getTime()-S,u=Math.abs(f),g=Math.round(u/1e3),J=Math.round(u/6e4),R=Math.round(u/36e5),z=Math.round(u/864e5),F=Math.round(u/6048e5),ee=Math.round(u/2592e6),Q=Math.round(u/31536e6),te=new Intl.RelativeTimeFormat(d.locale,{style:U()});let A,o;g<60?(A="second",o=g):J<60?(A="minute",o=J):R<24?(A="hour",o=R):z<7?(A="day",o=z):F<4?(A="week",o=F):ee<12?(A="month",o=ee):(A="year",o=Q);const E=f<0?-1:1;return te.format(E*o,A)}function O(){i(x,h(),!0)}$e(()=>{if(O(),L()>0){const S=setInterval(O,L());return()=>clearInterval(S)}});var X=Ve(),oe=_e(X);{var ce=S=>{Pe(S,{get text(){return e(M)},children:(m,f)=>{var u=ft(),g=n(u,!0);s(u),K(()=>{Le(u,1,`relative-time ${d.classes??""??""}`,"svelte-o98vko"),le(u,"datetime",e(w)),le(u,"data-pw",typeof d.testId=="string"?d.testId:null),D(g,e(x))}),_(m,u)},$$slots:{default:!0}})},q=S=>{var m=ht(),f=n(m,!0);s(m),K(()=>{Le(m,1,`relative-time ${d.classes??""??""}`,"svelte-o98vko"),le(m,"datetime",e(w)),le(m,"data-pw",typeof d.testId=="string"?d.testId:null),D(f,e(x))}),_(S,m)};H(oe,S=>{B()?S(ce):S(q,-1)})}_(ie,X),De()}var gt=b('<div class="section svelte-plslui"><span class="section-label svelte-plslui">Quick Launch</span> <div class="preset-grid svelte-plslui"></div></div> <div class="section svelte-plslui"><span class="section-label svelte-plslui">Working Directory</span> <!> <div class="custom-cwd-group svelte-plslui"><!></div></div> <!> <!>',1);function _t(ie,d){ke(d,!0);let U=fe(d,"open",15,!1);const L=[{args:[],command:"claude",label:"Claude Code"},{args:[],command:"codex",label:"Codex"},{args:[],command:"gemini",label:"Gemini"},{args:[],command:"qwen",label:"Qwen"},{args:[],command:"cursor-agent",label:"Cursor"},{args:[],command:"copilot",label:"Copilot"},{args:[],command:"amp",label:"Amp"},{args:[],command:"opencode",label:"OpenCode"},{args:[],command:"zsh",label:"Shell / zsh"},{args:[],command:"bash",label:"Bash"}];let B=P(0),v=P(Ke([])),w=P(""),M=P(""),x=P(!1),h=P("");$e(()=>{O()});async function O(){try{const m=await fetch("/api/sessions?limit=50&offset=0",{headers:{Authorization:`Bearer ${d.apiKey}`}});if(!m.ok)return;const u=(await m.json()).projects.map(g=>g.fullPath).filter(g=>typeof g=="string"&&g.length>0);i(v,[...new Set(u)],!0),e(v).length>0&&!e(w)&&i(w,e(v)[0],!0)}catch{}}function X(m){i(B,m,!0)}function oe(){return L[e(B)].command}function ce(){return L[e(B)].args}function q(){const m=e(M).trim();return m||(e(w)?e(w):"/tmp")}async function S(){const m=oe();if(m){i(x,!0),i(h,"");try{const f=await fetch("/api/terminals",{body:JSON.stringify({args:ce(),command:m,cwd:q()||void 0}),headers:{Authorization:`Bearer ${d.apiKey}`,"Content-Type":"application/json"},method:"POST"});if(!f.ok){const g=await f.json().catch(()=>({}));i(h,(typeof g.error=="string"?g.error:"")||`Failed to launch (${f.status})`,!0);return}const u=await f.json();d.onLaunch(u)}catch{i(h,"Network error — is the server running?")}finally{i(x,!1)}}}et(ie,{side:"bottom",title:"New Terminal",get onclose(){return d.onClose},classes:"launch-sheet",get open(){return U()},set open(f){U(f)},content:f=>{var u=gt(),g=_e(u),J=c(n(g),2);ge(J,23,()=>L,o=>o.label,(o,E,k)=>{{let de=C(()=>e(B)===e(k));tt(o,{mode:"radio",get selected(){return e(de)},onclick:()=>{X(e(k))},classes:"preset-choice",children:(ue,we)=>{he();var ve=We();K(()=>D(ve,e(E).label)),_(ue,ve)},$$slots:{default:!0}})}}),s(J),s(g);var R=c(g,2),z=c(n(R),2);{let o=C(()=>e(v).length>0?e(v).map(k=>({id:k,label:k})):[{id:"",label:"No recent projects"}]),E=C(()=>e(w)?[e(w)]:e(v).length>0?[e(v)[0]]:[""]);at(z,{get items(){return e(o)},get value(){return e(E)},placeholder:"Select a project",onchange:k=>{i(w,k[0]||"",!0)},classes:"launch-select"})}var F=c(z,2),ee=n(F);st(ee,{label:"Or enter a custom path",dataType:"text",placeholder:"/path/to/project",classes:"input-mono launch-input",get value(){return e(M)},set value(o){i(M,o,!0)}}),s(F),s(R);var Q=c(R,2);{let o=C(()=>e(x)?"Launching...":"Launch Terminal");ne(Q,{classes:"btn-launch",get disabled(){return e(x)},onclick:S,get showLoader(){return e(x)},get text(){return e(o)}})}var te=c(Q,2);{var A=o=>{Be(o,{get text(){return e(h)},classes:"banner-error launch-error-banner"})};H(te,o=>{e(h)&&o(A)})}_(f,u)},$$slots:{content:!0}}),De()}var wt=b('<meta name="description" content="Active terminal sessions on this machine"/>'),bt=b("<!> Refresh",1),xt=b('<span class="plus-icon svelte-1ewpmn2">+</span> New Terminal',1),yt=b('<div class="loading-container"></div>'),St=b('<span class="plus-icon svelte-1ewpmn2">+</span> New Terminal',1),Ct=b('<span class="terminal-cwd svelte-1ewpmn2"> </span>'),Tt=b('<div class="terminal-preview svelte-1ewpmn2"><span class="terminal-preview-text svelte-1ewpmn2"> </span></div>'),At=b('<a class="terminal-card svelte-1ewpmn2"><div class="terminal-card-header svelte-1ewpmn2"><div class="terminal-card-left svelte-1ewpmn2"><span class="status-indicator status-running svelte-1ewpmn2"><span></span></span> <span class="terminal-command svelte-1ewpmn2"> </span> <!></div> <!></div> <div class="terminal-card-meta svelte-1ewpmn2"><!> <span class="terminal-pid svelte-1ewpmn2"> </span></div> <!></a>'),It=b('<span class="terminal-cwd svelte-1ewpmn2"> </span>'),Pt=b('<div class="terminal-preview svelte-1ewpmn2"><span class="terminal-preview-text svelte-1ewpmn2"> </span></div>'),Lt=b('<a class="terminal-card terminal-card-exited svelte-1ewpmn2"><div class="terminal-card-header svelte-1ewpmn2"><div class="terminal-card-left svelte-1ewpmn2"><span class="status-indicator status-exited svelte-1ewpmn2"><span class="status-dot-static"></span></span> <span class="terminal-command svelte-1ewpmn2"> </span> <!> <!></div> <div class="terminal-card-right svelte-1ewpmn2"><!> <!></div></div> <div class="terminal-card-meta svelte-1ewpmn2"><!></div> <!></a>'),kt=b('<div class="terminals-container svelte-1ewpmn2"><!> <!></div>'),$t=b('<main class="main"><div class="page-header"><div class="page-header-content"><div><h1 class="page-title">Terminals</h1> <p class="page-description">Active terminal sessions on this machine</p></div> <div class="page-actions"><!> <!></div></div></div> <!> <!></main> <!>',1);function Jt(ie,d){ke(d,!0);const U=1e4,L="shooter_terminals",B=["zsh","bash","sh","fish"];let v=P(Ke([])),w=P(!1),M=!1,x=P(null),h=P(null),O=null;const X=C(()=>e(v).filter(t=>t.status==="running")),oe=C(()=>e(v).filter(t=>t.status==="exited"));$e(()=>{ce();const t=vt(L,1e4);t&&(i(v,t,!0),i(w,!1)),q(),O=setInterval(()=>{e(h)?.apiKey&&q()},U)}),Ye(()=>{O&&(clearInterval(O),O=null)});function ce(){try{const t=localStorage.getItem("shooter_config");if(t){const a=JSON.parse(t);mt(a)?i(h,a,!0):(localStorage.removeItem("shooter_config"),i(h,null))}}catch{}}async function q(){if(!(!e(h)?.apiKey||M)){M=!0,e(v).length===0&&i(w,!0);try{const a=await fetch("/api/terminals",{headers:{Authorization:`Bearer ${e(h).apiKey}`}});if(!a.ok){i(x,`Failed to load terminals (HTTP ${a.status})`);return}i(x,null);const r=await a.json();i(v,r.terminals.map(y=>({...y,lastOutput:y.lastOutput??null})),!0),Ee(L,e(v))}catch(t){i(x,"Failed to load terminals"),console.error("Failed to fetch terminals:",t)}finally{i(w,!1),M=!1}}}async function S(){i(w,!0),ut(L),await q()}function m(){Oe("/config")}let f=P(!1);function u(){i(f,!0)}function g(){i(f,!1)}function J(t){i(f,!1),Oe(`/terminals/${t.id}`)}function R(t){const a=t.split("/").pop()||t;return pt.includes(a)?"ai":(B.includes(a),"shell")}function z(t){return t.status==="exited"?{class:"pill-badge-ended",label:"ENDED"}:R(t.command)==="ai"?{class:"pill-badge-ai",label:"AI"}:{class:"pill-badge-shell",label:"SHELL"}}function F(t,a=40){if(t.length<=a)return t;const r=t.split("/");return r.length<=3?t:`${r[0]}/.../${r.slice(-2).join("/")}`}function ee(t){return t.replace(/\x1b\[[0-9;]*[a-zA-Z]|\x1b\][^\x07]*\x07|\x1b\[[\?]?[0-9;]*[a-zA-Z]|\x1b/g,"").replace(/[\x00-\x1f]/g,"").trim()}function Q(t,a=80){if(!t)return"";const r=t.split(`
2
2
  `).map(T=>ee(T)).filter(T=>T.trim()),y=r[r.length-1]||"";return y.length<=a?y:`${y.slice(0,a)}...`}function te(t){return t.split("/").pop()||t}async function A(t,a){if(t.preventDefault(),t.stopPropagation(),!!e(h)?.apiKey)try{(await fetch(`/api/terminals/${a}`,{headers:{Authorization:`Bearer ${e(h).apiKey}`},method:"DELETE"})).ok&&(i(v,e(v).filter(y=>y.id!==a),!0),Ee(L,e(v)))}catch(r){console.error("Failed to remove terminal:",r)}}var o=$t();lt("1ewpmn2",t=>{var a=wt();Ue(()=>{Xe.title="Terminals - Shooter"}),_(t,a)});var E=_e(o),k=n(E),de=n(k),ue=c(n(de),2),we=n(ue);ne(we,{classes:"btn-secondary",onclick:S,get disabled(){return e(w)},children:(t,a)=>{var r=bt(),y=_e(r);Ae(y,{get svg(){return it},classes:"icon-14"}),he(),_(t,r)},$$slots:{default:!0}});var ve=c(we,2);ne(ve,{classes:"btn-primary",onclick:u,children:(t,a)=>{var r=xt();he(),_(t,r)},$$slots:{default:!0}}),s(ue),s(de),s(k);var Me=c(k,2);{var Re=t=>{Be(t,{get text(){return e(x)},classes:"banner-error"})};H(Me,t=>{e(x)&&t(Re)})}var ze=c(Me,2);{var Fe=t=>{var a=yt();ge(a,20,()=>Array(4),rt,(r,y)=>{ot(r,{classes:"shimmer-card"})}),s(a),_(t,a)},He=t=>{Ne(t,{title:"Configuration Required",description:"Set up your API credentials to view terminal sessions",icon:r=>{Ae(r,{get svg(){return ct},classes:"icon-24"})},children:(r,y)=>{ne(r,{classes:"btn-primary",onclick:m,text:"Configure Settings"})}})},qe=t=>{Ne(t,{title:"No terminals",description:"Launch a new terminal session to get started. Terminal sessions will appear here once created.",icon:r=>{Ae(r,{get svg(){return dt},classes:"icon-24"})},children:(r,y)=>{ne(r,{classes:"btn-primary",onclick:u,children:(T,l)=>{var Z=St();he(),_(T,Z)},$$slots:{default:!0}})}})},Je=t=>{var a=kt(),r=n(a);ge(r,17,()=>e(X),T=>T.id,(T,l)=>{const Z=C(()=>z(e(l)));var N=At(),G=n(N),V=n(G),W=n(V),be=n(W);s(W);var ae=c(W,2),xe=n(ae,!0);s(ae);var ye=c(ae,2);Ie(ye,{get text(){return e(Z).label},get classes(){return e(Z).class}}),s(V);var me=c(V,2);je(me,{get date(){return e(l).createdAt},format:"narrow",classes:"terminal-time"}),s(G);var se=c(G,2),pe=n(se);{let p=C(()=>e(l).currentCwd||e(l).cwd);Pe(pe,{get text(){return e(p)},position:"bottom",children:(I,$)=>{var j=Ct(),Y=n(j,!0);s(j),K(Ge=>D(Y,Ge),[()=>F(e(l).currentCwd||e(l).cwd)]),_(I,j)},$$slots:{default:!0}})}var re=c(pe,2),Se=n(re);s(re),s(se);var Ce=c(se,2);{var Te=p=>{var I=Tt(),$=n(I),j=n($,!0);s($),s(I),K(Y=>D(j,Y),[()=>Q(e(l).lastOutput)]),_(p,I)};H(Ce,p=>{e(l).lastOutput&&p(Te)})}s(N),K(p=>{le(N,"href",`/terminals/${e(l).id??""}`),Le(be,1,nt(e(l).isActive?"status-dot-active":"status-dot-idle")),D(xe,p),D(Se,`PID ${e(l).pid??""}`)},[()=>te(e(l).command)]),_(T,N)});var y=c(r,2);ge(y,17,()=>e(oe),T=>T.id,(T,l)=>{const Z=C(()=>z(e(l)));var N=Lt(),G=n(N),V=n(G),W=c(n(V),2),be=n(W,!0);s(W);var ae=c(W,2);Ie(ae,{get text(){return e(Z).label},get classes(){return e(Z).class}});var xe=c(ae,2);{var ye=p=>{{let I=C(()=>e(l).exitCode!==0?"pill-exit-error":"pill-exit-ok");Ie(p,{get text(){return`exit ${e(l).exitCode??""}`},get classes(){return e(I)}})}};H(xe,p=>{e(l).exitCode!==null&&p(ye)})}s(V);var me=c(V,2),se=n(me);{let p=C(()=>e(l).exitedAt||e(l).createdAt);je(se,{get date(){return e(p)},format:"narrow",classes:"terminal-time"})}var pe=c(se,2);ne(pe,{classes:"btn-ghost btn-sm btn-remove",onclick:p=>{A(p,e(l).id)},text:"×"}),s(me),s(G);var re=c(G,2),Se=n(re);Pe(Se,{get text(){return e(l).cwd},position:"bottom",children:(p,I)=>{var $=It(),j=n($,!0);s($),K(Y=>D(j,Y),[()=>F(e(l).cwd)]),_(p,$)},$$slots:{default:!0}}),s(re);var Ce=c(re,2);{var Te=p=>{var I=Pt(),$=n(I),j=n($,!0);s($),s(I),K(Y=>D(j,Y),[()=>Q(e(l).lastOutput)]),_(p,I)};H(Ce,p=>{e(l).lastOutput&&p(Te)})}s(N),K(p=>{le(N,"href",`/terminals/${e(l).id??""}`),D(be,p)},[()=>te(e(l).command)]),_(T,N)}),s(a),_(t,a)};H(ze,t=>{e(w)&&e(v).length===0?t(Fe):e(h)?.apiKey?e(v).length===0?t(qe,2):t(Je,-1):t(He,1)})}s(E);var Qe=c(E,2);{var Ze=t=>{_t(t,{get apiKey(){return e(h).apiKey},onClose:g,onLaunch:J,get open(){return e(f)},set open(a){i(f,a,!0)}})};H(Qe,t=>{e(h)?.apiKey&&t(Ze)})}_(ie,o),De()}export{Jt as component};
@@ -1,2 +1,2 @@
1
1
  const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["../chunks/J5-Cr5oR.js","../chunks/PPVm8Dsz.js"])))=>i.map(i=>d[i]);
2
- import{_ as Wt}from"../chunks/PPVm8Dsz.js";import{p as ht,i as P,s as te,a as b,f as S,d as Bt,j as pt,b as re,e as zt,c as Jt,g as ct}from"../chunks/BPDiEZo0.js";import{p as ce,w as de,g as e,x as m,c as u,d as i,r as c,t as Y,b as t,s as f,E as Ht,A as we,q as Vt,v as Gt,y as Qt,z as Xt,$ as Yt}from"../chunks/DWmC0QM7.js";import{h as Zt}from"../chunks/2rBV5OkJ.js";import{m as ea,s as be,d as mt,B as W,e as yt,I as Le,M as ta,K as aa,P as dt,k as ut,c as na,T as vt,n as sa}from"../chunks/ZS5XYDx_.js";import{g as ge}from"../chunks/C_YNQL8b.js";import{p as ra}from"../chunks/DT4H19pV.js";import{A as oa}from"../chunks/DzuS5Nbr.js";import"../chunks/BDcFu3l7.js";import{A as ia}from"../chunks/BdtLzPpO.js";import{C as la}from"../chunks/BB2l8o4X.js";import{g as Re}from"../chunks/gQJcRhou.js";import{E as ca}from"../chunks/ClIPTXf3.js";function da(T,o){ce(o,!0);let w=ht(o,"open",15,!1);const v=m(()=>o.commands.map((n,d)=>({label:n.label,value:String(d)})));function k(n){const d=parseInt(n.value,10);o.commands[d]&&o.commands[d].action()}ea(T,{get items(){return e(v)},placeholder:"Type a command...",emptyText:"No matching commands",onselect:k,get onclose(){return o.onClose},classes:"command-palette",get open(){return w()},set open(n){w(n)}}),de()}var ua=S('<div><span></span> <span class="status-label svelte-1cg9pai"> </span> <!></div>');function va(T,o){const w=m(()=>o.status==="connected"?"Connected":o.status==="reconnecting"?"Reconnecting...":"Disconnected");var v=ua();let k;var n=u(v),d=i(n,2),_=u(d,!0);c(d);var y=i(d,2);{var I=M=>{W(M,{classes:"btn-ghost btn-sm btn-retry",get onclick(){return o.onretry},text:"Retry"})};P(y,M=>{o.status==="disconnected"&&o.onretry&&M(I)})}c(v),Y(()=>{k=be(v,1,"connection-status svelte-1cg9pai",null,k,{reconnecting:o.status==="reconnecting",disconnected:o.status==="disconnected",connected:o.status==="connected"}),mt(v,"aria-label",`Connection: ${o.status??""}`),be(n,1,`conn-dot ${o.status??""}`,"svelte-1cg9pai"),te(_,e(w))}),b(T,v)}const gt=typeof navigator<"u"&&/Mac|iPhone|iPad/.test(navigator.userAgent),ft=gt?"⌘":"Ctrl";function fa(T){function o(w){if((gt?w.metaKey:w.ctrlKey)&&!pa()&&w.key==="/"){w.preventDefault(),w.stopPropagation(),T.onHelp();return}}return window.addEventListener("keydown",o,!0),{destroy(){window.removeEventListener("keydown",o,!0)}}}function ha(){return[{description:"Command palette",keys:`${ft}+K`},{description:"Keyboard shortcuts",keys:`${ft}+/`}]}function pa(){const T=document.activeElement;if(!T)return!1;const o=T.tagName;return!!(o==="INPUT"||o==="TEXTAREA"||T.isContentEditable||T.closest(".xterm"))}var ma=S('<div class="quick-keys svelte-64qat5" role="toolbar" aria-label="Quick terminal keys"></div>');function ya(T,o){ce(o,!0);const w=[{escape:"",label:"Ctrl+C"},{escape:" ",label:"Tab"},{escape:"\x1B[A",label:"↑"},{escape:"\x1B[B",label:"↓"},{escape:"\x1B",label:"Esc"},{escape:"",label:"Ctrl+D"},{escape:"",label:"Ctrl+Z"}];var v=ma();yt(v,21,()=>w,k=>k.label,(k,n)=>{W(k,{classes:"btn-quick-key",onclick:()=>{o.onKey(e(n).escape)},get text(){return e(n).label}})}),c(v),b(T,v),de()}var ga=S('<p class="share-gate-error svelte-axsobw"> </p>'),wa=S('<div class="share-gate svelte-axsobw"><div class="share-gate-card svelte-axsobw"><h2 class="share-gate-title svelte-axsobw">Shared terminal</h2> <p class="share-gate-sub svelte-axsobw">This terminal is password protected. Enter the password to view it.</p> <!> <!> <!></div></div>');function ba(T,o){ce(o,!0);let w=f(""),v=f(null),k=f(!1);async function n(){!e(w)||e(k)||(t(k,!0),t(v,null),t(v,await o.onSubmit(e(w)),!0),t(k,!1))}function d(g){g.key==="Enter"&&(g.preventDefault(),n())}var _=wa(),y=u(_),I=i(u(y),4);Le(I,{dataType:"password",placeholder:"Password",classes:"share-gate-input",onKeyDown:d,get value(){return e(w)},set value(g){t(w,g,!0)}});var M=i(I,2);{var B=g=>{var q=ga(),F=u(q,!0);c(q),Y(()=>te(F,e(v))),b(g,q)};P(M,g=>{e(v)&&g(B)})}var x=i(M,2);{let g=m(()=>!e(w)||e(k));W(x,{classes:"btn-primary share-gate-btn",onclick:()=>{n()},get disabled(){return e(g)},get showLoader(){return e(k)},text:"Unlock"})}c(y),c(_),b(T,_),de()}var _a=S('<div class="share-active-row svelte-fj2rhy"><span class="share-active-dot svelte-fj2rhy"></span> <span class="share-active-label svelte-fj2rhy"> </span></div> <div class="share-url-row svelte-fj2rhy"><span class="share-url svelte-fj2rhy"> </span> <!></div>',1),ka=S(`<p class="share-sheet-sub svelte-fj2rhy">Anyone with this page's link and the password below can access this terminal.</p>`),Sa=S('<p class="share-error svelte-fj2rhy"> </p>'),xa=S('<div class="share-backdrop svelte-fj2rhy" role="presentation"><div class="share-sheet svelte-fj2rhy" role="dialog" aria-label="Share terminal" tabindex="-1"><div class="share-sheet-header svelte-fj2rhy"><h2 class="share-sheet-title svelte-fj2rhy">Share terminal</h2> <button class="share-sheet-close svelte-fj2rhy" aria-label="Close">&times;</button></div> <!> <div class="share-field svelte-fj2rhy"><span class="share-field-label svelte-fj2rhy">Access</span> <div class="share-mode-toggle svelte-fj2rhy"><button>View only</button> <button>Full control</button></div></div> <div class="share-field svelte-fj2rhy"><span class="share-field-label svelte-fj2rhy"> </span> <div class="share-password-row svelte-fj2rhy"><!> <!></div></div> <!> <div class="share-actions svelte-fj2rhy"><!> <!></div></div></div>');function ja(T,o){ce(o,!0);const w=ht(o,"open",3,!1);let v=f(!1),k=f(null),n=f("view"),d=f(""),_=f(!1),y=f(null),I=f(!1);const M="ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz23456789",B=m(()=>e(v)?e(d).length===0||e(d).length>=6:e(d).length>=6);Ht(()=>{w()&&x()});async function x(){t(y,null),t(I,!1);try{const K=await fetch(`/api/terminals/${o.terminalId}/share`,{headers:{Authorization:`Bearer ${Re()}`}});if(!K.ok){t(y,"Failed to load share state.");return}const A=await K.json();t(v,A.active,!0),t(k,A.mode??null,!0),t(n,A.mode??"view",!0),t(d,"")}catch{t(y,"Failed to reach the server.")}}function g(){const K=crypto.getRandomValues(new Uint8Array(16));t(d,Array.from(K,A=>M[A%M.length]).join(""),!0)}async function q(){if(!(e(_)||!e(B))){t(_,!0),t(y,null);try{const K=await fetch(`/api/terminals/${o.terminalId}/share`,{body:JSON.stringify({mode:e(n),...e(d)?{password:e(d)}:{}}),headers:{Authorization:`Bearer ${Re()}`,"Content-Type":"application/json"},method:"PUT"});if(!K.ok){const R=await K.json().catch(()=>({}));t(y,R.error??"Failed to save share.",!0);return}const A=await K.json();t(v,A.active,!0),t(k,A.mode??null,!0),t(d,"")}catch{t(y,"Failed to reach the server.")}finally{t(_,!1)}}}async function F(){if(!e(_)){t(_,!0),t(y,null);try{if(!(await fetch(`/api/terminals/${o.terminalId}/share`,{headers:{Authorization:`Bearer ${Re()}`},method:"DELETE"})).ok){t(y,"Failed to revoke share.");return}t(v,!1),t(k,null),t(d,"")}catch{t(y,"Failed to reach the server.")}finally{t(_,!1)}}}async function z(){try{await navigator.clipboard.writeText(o.shareUrl),t(I,!0),setTimeout(()=>{t(I,!1)},2e3)}catch{t(y,"Failed to copy.")}}var ue=pt(),oe=we(ue);{var _e=K=>{var A=xa(),R=u(A),ae=u(R),H=i(u(ae),2);c(ae);var ve=i(ae,2);{var Z=h=>{var L=_a(),Q=we(L),ie=i(u(Q),2),je=u(ie);c(ie),c(Q);var Ce=i(Q,2),le=u(Ce),Te=u(le,!0);c(le);var Ie=i(le,2);{let qe=m(()=>e(I)?"Copied":"Copy");W(Ie,{classes:"btn-secondary btn-sm",onclick:()=>{z()},get text(){return e(qe)}})}c(Ce),Y(()=>{te(je,`Sharing is active (${e(k)==="control"?"full control":"view only"})`),te(Te,o.shareUrl)}),b(h,L)},fe=h=>{var L=ka();b(h,L)};P(ve,h=>{e(v)?h(Z):h(fe,-1)})}var j=i(ve,2),V=i(u(j),2),C=u(V),N=i(C,2);c(V),c(j);var ee=i(j,2),G=u(ee),ke=u(G,!0);c(G);var Se=i(G,2),xe=u(Se);Le(xe,{dataType:"text",placeholder:"Password",classes:"share-password-input",get value(){return e(d)},set value(h){t(d,h,!0)}});var Ke=i(xe,2);W(Ke,{classes:"btn-secondary btn-sm",onclick:g,text:"Generate"}),c(Se),c(ee);var he=i(ee,2);{var Oe=h=>{var L=Sa(),Q=u(L,!0);c(L),Y(()=>te(Q,e(y))),b(h,L)};P(he,h=>{e(y)&&h(Oe)})}var pe=i(he,2),ne=u(pe);{var me=h=>{W(h,{classes:"btn-danger btn-sm",onclick:()=>{F()},get disabled(){return e(_)},text:"Stop sharing"})};P(ne,h=>{e(v)&&h(me)})}var De=i(ne,2);{let h=m(()=>e(_)||!e(B)),L=m(()=>e(v)?"Update":"Start sharing");W(De,{classes:"btn-primary btn-sm",onclick:()=>{q()},get disabled(){return e(h)},get showLoader(){return e(_)},get text(){return e(L)}})}c(pe),c(R),c(A),Y(()=>{be(C,1,`share-mode-btn ${e(n)==="view"?"share-mode-active":""}`,"svelte-fj2rhy"),be(N,1,`share-mode-btn ${e(n)==="control"?"share-mode-active":""}`,"svelte-fj2rhy"),te(ke,e(v)?"New password (leave empty to keep current)":"Password (min 6 chars)")}),re("click",A,function(...h){o.onClose?.apply(this,h)}),re("keydown",A,h=>{h.key==="Escape"&&o.onClose()}),re("click",R,h=>{h.stopPropagation()}),re("keydown",R,h=>{h.key==="Escape"&&o.onClose()}),re("click",H,function(...h){o.onClose?.apply(this,h)}),re("click",C,()=>{t(n,"view")}),re("click",N,()=>{t(n,"control")}),b(K,A)};P(oe,K=>{w()&&K(_e)})}b(T,ue),de()}Bt(["click","keydown"]);var Ca=S('<div class="shortcut-row svelte-1u7lstk"><span class="shortcut-desc svelte-1u7lstk"> </span> <!></div>'),Ta=S('<div class="shortcuts-list svelte-1u7lstk"></div>');function Ia(T,o){ce(o,!0);const w=ha();var v=pt(),k=we(v);{var n=d=>{ta(d,{header:{text:"Keyboard Shortcuts"},get onoverlayClick(){return o.onClose},classes:"shortcuts-modal",content:y=>{var I=Ta();yt(I,21,()=>w,M=>M.keys,(M,B)=>{var x=Ca(),g=u(x),q=u(g,!0);c(g);var F=i(g,2);aa(F,{get keys(){return e(B).keys},classes:"shortcut-kbd"}),c(x),Y(()=>te(q,e(B).description)),b(M,x)}),c(I),b(y,I)},$$slots:{content:!0}})};P(k,d=>{o.open&&d(n)})}b(T,v),de()}var Ea=S('<meta name="description" content="Interactive terminal session"/>'),Aa=S('<div class="term-page svelte-1tubujq"><div class="term-topbar svelte-1tubujq"><div class="skeleton" style="width: 120px; height: 20px;"></div></div> <div class="term-body-loading svelte-1tubujq"><div class="skeleton" style="width: 100%; height: 100%;"></div></div></div>'),Pa=S('<div class="term-page svelte-1tubujq"><!></div>'),Ma=S('<main class="main"><div class="session-back-row"><a href="/terminals" class="back-link"><span class="back-arrow">&larr;</span> Terminals</a></div> <!></main>'),Ka=S('<a href="/terminals" class="term-back svelte-1tubujq" aria-label="Back to terminals">&larr;</a>'),Oa=S("<span></span>"),Da=S('<span class="term-cwd svelte-1tubujq"> </span>'),qa=S('<a class="term-session-link svelte-1tubujq" title="View session history">Session</a>'),Na=S("<!> <!>",1),$a=S('<div class="term-input-area svelte-1tubujq"><!> <div class="term-input-bar svelte-1tubujq"><!> <!></div></div>'),Fa=S('<div class="term-exited-bar svelte-1tubujq"><span>Process exited</span> <!></div>'),Ra=S('<div class="term-page svelte-1tubujq"><div class="term-topbar svelte-1tubujq"><div class="term-topbar-left svelte-1tubujq"><!> <span class="term-command-name svelte-1tubujq"> </span> <!> <!> <!> <!> <!></div> <div class="term-topbar-right svelte-1tubujq"><!> <!> <!></div></div> <div class="term-body svelte-1tubujq"></div> <!> <div class="term-chat-body svelte-1tubujq"><!></div> <!></div>'),La=S("<!> <!> <!> <!>",1);function tn(T,o){ce(o,!0);const w=()=>Jt(ra,"$page",v),[v,k]=zt();let n=f(null),d=f(!0),_=f(null),y=f(!1),I=f(!1),M=f(!1),B=f(null),x=f("raw"),g=f("disconnected"),q=f("disconnected"),F=f(""),z=f(Vt([])),ue=f(!1),oe=f(null),_e=f(null),K=f(!1),A=f(!1),R=f(null),ae=f(null),H=null,ve=null,Z=f(!1),fe=f(!1),j=null,V=null,C=!1;const N=m(()=>w().params.id),ee=m(()=>e(n)?ia.includes((e(n).command.split("/").pop()||"").toLowerCase()):!1),G=m(()=>e(n)?.status==="running"),ke=m(()=>e(n)?.command.split("/").pop()||"terminal"),Se=m(()=>e(ee)?"AI":"SHELL"),xe=m(()=>e(ee)?"pill-badge-ai":"pill-badge-shell"),Ke=["Raw","Chat"],he=m(()=>e(x)==="raw"?e(g):e(q)),Oe=m(()=>e(x)==="raw"?0:1),pe=m(()=>L(e(B)||e(n)?.cwd||"")),ne=m(()=>e(oe)==="owner"),me=m(()=>e(oe)==="guest"&&e(_e)==="view"),De=m(()=>typeof window<"u"?`${window.location.origin}/terminals/${e(N)}`:""),h=m(()=>{const a=[{action:()=>{ge("/")},label:"Go to Home"},{action:()=>{ge("/terminals")},label:"Go to Terminals"},{action:()=>{ge("/config")},label:"Go to Settings"},{action:()=>{t(Z,!0)},label:"Show keyboard shortcuts"}];return e(G)&&e(ne)&&a.push({action:()=>{We()},label:"Kill terminal"}),a});function L(a){if(!a)return"";const s="";let r=a;if(typeof navigator<"u"){const p=a.split("/");p.length>=3&&p[1]==="Users"?r=`~/${p.slice(3).join("/")}`:p.length>=3&&p[1]==="home"&&(r=`~/${p.slice(3).join("/")}`)}if(r.length>30){const p=r.split("/");if(p.length>2)return`.../${p.slice(-2).join("/")}`}return r||s}function Q(){try{const a=localStorage.getItem("shooter_config");if(!a)return null;const s=JSON.parse(a);return typeof s?.apiKey=="string"&&s.apiKey?s:null}catch{return null}}const ie="shooter_share_tokens";function je(){const a=e(N);if(!a)return null;try{const s=localStorage.getItem(ie);if(!s)return null;const r=JSON.parse(s);return typeof r[a]=="string"?r[a]:null}catch{return null}}function Ce(a){const s=e(N);if(!s)return;let r={};try{r=JSON.parse(localStorage.getItem(ie)??"{}")}catch{}r[s]=a,localStorage.setItem(ie,JSON.stringify(r))}function le(){return Q()?.apiKey??je()}async function Te(){const a=Q(),s=a?.apiKey??je();if(!s){await Ie();return}try{const r=await fetch(`/api/terminals/${e(N)}`,{headers:{Authorization:`Bearer ${s}`}});if(r.status===401&&!a){await Ie();return}if(!r.ok){t(_,r.status===404?"Terminal not found":"Failed to load terminal",!0),t(d,!1);return}t(n,await r.json(),!0),a?t(oe,"owner"):(t(oe,"guest"),t(_e,e(n).shareMode??"view",!0))}catch{t(_,"Failed to connect to server")}t(d,!1)}async function Ie(){try{const a=await fetch(`/api/terminals/${e(N)}/share/status`);if(a.ok&&(await a.json()).shared){t(K,!0),t(d,!1);return}}catch{}t(_,"No configuration found. Please configure settings first."),t(d,!1)}async function qe(a){try{const s=await fetch(`/api/terminals/${e(N)}/share/auth`,{body:JSON.stringify({password:a}),headers:{"Content-Type":"application/json"},method:"POST"});if(s.status===429)return"Too many attempts — try again in a minute.";if(!s.ok)return"Incorrect password.";const r=await s.json();return Ce(r.token),t(K,!1),t(d,!0),await Te(),e(n)&&!e(_)&&Ve(),null}catch{return"Failed to reach the server."}}async function Ue(){const a=le();if(!a)return null;try{const s=await fetch("/api/ws-ticket",{headers:{Authorization:`Bearer ${a}`},method:"POST"});return s.ok?(await s.json()).ticket:null}catch{return null}}async function We(){if(!e(n)||e(y))return;const a=Q();if(a){t(y,!0);try{(await fetch(`/api/terminals/${e(N)}`,{headers:{Authorization:`Bearer ${a.apiKey}`},method:"DELETE"})).ok?ge("/terminals"):t(y,!1)}catch{t(y,!1)}}}async function wt(){if(!e(n)||e(I))return;const a=Q();if(a){t(I,!0);try{(await fetch(`/api/terminals/${e(N)}`,{headers:{Authorization:`Bearer ${a.apiKey}`},method:"DELETE"})).ok?ge("/terminals"):t(I,!1)}catch{t(I,!1)}}}async function Ne(){if(!e(R)||!e(n)||C)return;const s=`${window.location.protocol==="https:"?"wss:":"ws:"}//${window.location.host}${e(n).ws}`,r=async()=>{const p=await Ue();if(!p)throw new Error("Failed to obtain WebSocket ticket");return p};try{const{createTerminal:p}=await Wt(async()=>{const{createTerminal:J}=await import("../chunks/J5-Cr5oR.js");return{createTerminal:J}},__vite__mapDeps([0,1]),import.meta.url);if(C||!e(R))return;const O=await p({apiKey:le()??void 0,container:e(R),fontSize:window.innerWidth<768?12:14,getTicket:r,initialCols:e(n).cols??void 0,initialRows:e(n).rows??void 0,onActivity:J=>{C||t(M,J,!0)},onCwd:J=>{C||t(B,J,!0)},onDisconnect:()=>{C||t(g,"reconnecting")},onExit:J=>{!C&&e(n)&&(t(n,{...e(n),exitCode:J,exitedAt:new Date().toISOString(),status:"exited"},!0),t(g,"disconnected"))},onReconnect:()=>{C||t(g,"connected")},readOnly:e(me),terminalId:e(N),wsUrl:s});if(C){O.dispose();return}H=O,t(g,"connected")}catch(p){console.error("Failed to initialize terminal:",p),t(g,"disconnected")}}function Be(){H&&(H.dispose(),H=null)}async function Ee(){if(!e(n)||C||j&&(j.readyState===WebSocket.OPEN||j.readyState===WebSocket.CONNECTING))return;const a=await Ue();if(!a||C||!e(n)){t(q,"disconnected");return}const r=`${window.location.protocol==="https:"?"wss:":"ws:"}//${window.location.host}${e(n).sessionWs}?ticket=${a}`;j=new WebSocket(r),j.onopen=()=>{C||(t(q,"connected"),j?.send(JSON.stringify({sessionId:e(N),type:"subscribe"})))},j.onmessage=p=>{if(!C)try{const O=JSON.parse(p.data);bt(O)}catch{}},j.onclose=()=>{!C&&e(n)?.status==="running"&&(t(q,"reconnecting"),V&&clearTimeout(V),V=setTimeout(()=>{V=null,!C&&e(n)?.status==="running"&&Ee()},2e3))},j.onerror=()=>{C||t(q,"disconnected")}}function ye(){return e(z)}function bt(a){if(a.type==="history"){const s=a.messages||[];t(z,s.map(r=>({id:r.id,parts:r.content,role:r.role,timestamp:r.timestamp})),!0)}else if(a.type==="message"){const s=typeof a.role=="string"?a.role:"assistant",r=s==="user"?"user":s==="system"?"system":"assistant",p={id:`msg-${Date.now()}-${Math.random().toString(36).slice(2,8)}`,parts:a.content||[],role:r,timestamp:(typeof a.timestamp=="string"?a.timestamp:"")||new Date().toISOString()};t(z,ye().concat(p),!0)}else if(a.type==="tool-use"){const s={id:a.id||`tool-${Date.now()}`,input:a.input||{},toolName:a.name,type:"tool_use"},r={id:`tool-${Date.now()}-${Math.random().toString(36).slice(2,8)}`,parts:[s],role:"assistant",timestamp:new Date().toISOString()};t(z,ye().concat(r),!0)}else if(a.type==="tool-result"){const s={isError:a.isError||!1,output:a.output||"",toolUseId:a.id,type:"tool_result"},r={id:`result-${Date.now()}-${Math.random().toString(36).slice(2,8)}`,parts:[s],role:"system",timestamp:new Date().toISOString()};t(z,ye().concat(r),!0)}else if(a.type==="thinking"){const s={content:a.text||"",type:"thinking"},r=ye(),p=r.length-1;if(p>=0&&r[p].role==="assistant"){const O=r[p],J={id:O.id,parts:O.parts.concat(s),role:O.role,timestamp:O.timestamp};t(z,[...r.slice(0,p),J],!0)}else{const O={id:`think-${Date.now()}-${Math.random().toString(36).slice(2,8)}`,parts:[s],role:"assistant",timestamp:new Date().toISOString()};t(z,r.concat(O),!0)}}else if(a.type==="error"){const s={content:a.message||"Unknown error",type:"text"},r={id:`err-${Date.now()}-${Math.random().toString(36).slice(2,8)}`,parts:[s],role:"system",timestamp:new Date().toISOString()};t(z,ye().concat(r),!0)}else a.type==="session-end"&&(t(ue,!0),e(n)&&t(n,{...e(n),status:"exited"},!0))}function ze(){V&&(clearTimeout(V),V=null),j&&(j.onclose=null,j.close(),j=null)}function Je(){e(F).trim()&&(H&&e(g)==="connected"&&H.sendInput(`${e(F)}\r`),t(F,""),e(ae)?.focus())}function _t(a){!a.trim()||j?.readyState!==WebSocket.OPEN||j.send(JSON.stringify({text:a,type:"send-input"}))}function He(){j?.readyState===WebSocket.OPEN&&j.send(JSON.stringify({type:"cancel"}))}function kt(a){e(x)==="raw"?H&&e(g)==="connected"&&H.sendInput(a):e(x)==="chat"&&a===""&&He()}function St(a){a.key==="Enter"&&!a.shiftKey&&(a.preventDefault(),Je())}let Ae=!1,Pe=!1;function xt(a){a!==e(x)&&(t(x,a,!0),a==="raw"&&!Ae?(requestAnimationFrame(()=>{Ne()}),Ae=!0):a==="chat"&&!Pe&&(Ee(),Pe=!0))}function jt(){e(x)==="raw"?(Be(),t(g,"reconnecting"),Ne(),Ae=!0):(ze(),t(q,"reconnecting"),Ee(),Pe=!0)}function Ve(){e(ee)&&window.innerWidth<768?t(x,"chat"):t(x,"raw"),e(x)==="raw"?(requestAnimationFrame(()=>{Ne()}),Ae=!0):(Ee(),Pe=!0)}Gt(async()=>{await Te(),!C&&(ve=fa({onHelp:()=>{t(Z,!e(Z))}}),!(!e(n)||e(_))&&Ve())}),Qt(()=>{C=!0,Be(),ze(),ve?.destroy()});var Ge=La();Zt("1tubujq",a=>{var s=Ea();Xt(()=>{Yt.title=`${e(ke)??""} - Terminal - Shooter`}),b(a,s)});var Qe=we(Ge);{var Ct=a=>{var s=Aa();b(a,s)},Tt=a=>{var s=Pa(),r=u(s);ba(r,{onSubmit:qe}),c(s),b(a,s)},It=a=>{var s=Ma(),r=i(u(s),2);ca(r,{title:"Error",get description(){return e(_)},icon:O=>{na(O,{get svg(){return oa},classes:"icon-24"})}}),c(s),b(a,s)},Et=a=>{var s=Ra(),r=u(s),p=u(r),O=u(p);{var J=l=>{var E=Ka();b(l,E)};P(O,l=>{e(ne)&&l(J)})}var $e=i(O,2),Pt=u($e,!0);c($e);var Ze=i($e,2);dt(Ze,{get text(){return e(Se)},get classes(){return e(xe)}});var et=i(Ze,2);{var Mt=l=>{{let E=m(()=>e(M)?"Active":"Idle");vt(l,{get text(){return e(E)},position:"bottom",children:($,X)=>{var D=Oa();Y(()=>be(D,1,`activity-dot ${e(M)?"activity-active":"activity-idle"}`,"svelte-1tubujq")),b($,D)},$$slots:{default:!0}})}};P(et,l=>{e(G)&&l(Mt)})}var tt=i(et,2);{var Kt=l=>{{let E=m(()=>e(B)||e(n)?.cwd||"");vt(l,{get text(){return e(E)},position:"bottom",children:($,X)=>{var D=Da(),se=u(D,!0);c(D),Y(()=>te(se,e(pe))),b($,D)},$$slots:{default:!0}})}};P(tt,l=>{e(pe)&&l(Kt)})}var at=i(tt,2);va(at,{get status(){return e(he)},onretry:jt});var Ot=i(at,2);{var Dt=l=>{const E=m(()=>e(n).sessionFile??"");var $=qa();Y(X=>mt($,"href",`/session/${X??""}`),[()=>e(E).split(/[\\/]/).pop()?.replace(".jsonl","")||""]),b(l,$)};P(Ot,l=>{e(ne)&&e(ee)&&e(n)?.sessionFile&&l(Dt)})}c(p);var nt=i(p,2),st=u(nt);{var qt=l=>{sa(l,{get items(){return Ke},get activeIndex(){return e(Oe)},onchange:E=>{xt(E===0?"raw":"chat")},classes:"term-tabs"})};P(st,l=>{e(ee)&&l(qt)})}var rt=i(st,2);W(rt,{classes:"term-shortcuts-btn",onclick:()=>{t(Z,!e(Z))},text:"?",ariaLabel:"Keyboard shortcuts"});var Nt=i(rt,2);{var $t=l=>{var E=Na(),$=we(E);W($,{classes:"btn-secondary btn-sm",onclick:()=>{t(A,!0)},text:"Share"});var X=i($,2);{var D=U=>{W(U,{classes:"btn-danger btn-sm",onclick:We,get disabled(){return e(y)},get showLoader(){return e(y)},text:"Kill"})},se=U=>{W(U,{classes:"btn-secondary btn-sm",onclick:wt,get disabled(){return e(I)},get showLoader(){return e(I)},text:"Remove"})};P(X,U=>{e(G)?U(D):U(se,-1)})}b(l,E)};P(Nt,l=>{e(ne)&&l($t)})}c(nt),c(r);var Fe=i(r,2);let ot;ct(Fe,l=>t(R,l),()=>e(R));var it=i(Fe,2);{var Ft=l=>{var E=$a(),$=u(E);ya($,{onKey:kt});var X=i($,2),D=u(X);ct(Le(D,{dataType:"text",useTextArea:!0,placeholder:"Type command... (Shift+Enter for new line)",classes:"input-mono term-input-field",onKeyDown:St,get value(){return e(F)},set value(U){t(F,U,!0)}}),U=>t(ae,U,!0),()=>e(ae));var se=i(D,2);{let U=m(()=>!e(F).trim());W(se,{classes:"btn-primary btn-send",onclick:Je,get disabled(){return e(U)},text:"↵"})}c(X),c(E),b(l,E)};P(it,l=>{e(G)&&e(x)==="raw"&&!e(me)&&l(Ft)})}var Me=i(it,2);let lt;var Rt=u(Me);{let l=m(()=>e(G)&&!e(me));la(Rt,{get messages(){return e(z)},get connectionState(){return e(he)},get sessionEnded(){return e(ue)},get showInput(){return e(l)},onSendInput:_t,onCancel:He})}c(Me);var Lt=i(Me,2);{var Ut=l=>{var E=Fa(),$=i(u(E),2);{var X=D=>{{let se=m(()=>e(n).exitCode!==0?"pill-exit-error":"pill-exit-ok");dt(D,{get text(){return`code ${e(n).exitCode??""}`},get classes(){return e(se)}})}};P($,D=>{e(n).exitCode!==null&&D(X)})}c(E),b(l,E)};P(Lt,l=>{e(G)||l(Ut)})}c(s),Y(()=>{te(Pt,e(ke)),ot=ut(Fe,"",ot,{display:e(x)==="raw"?"flex":"none"}),lt=ut(Me,"",lt,{display:e(x)==="chat"?"flex":"none"})}),b(a,s)};P(Qe,a=>{e(d)?a(Ct):e(K)?a(Tt,1):e(_)?a(It,2):e(n)&&a(Et,3)})}var Xe=i(Qe,2);Ia(Xe,{get open(){return e(Z)},onClose:()=>{t(Z,!1)}});var Ye=i(Xe,2);{let a=m(()=>e(N)??"");ja(Ye,{get open(){return e(A)},get terminalId(){return e(a)},get shareUrl(){return e(De)},onClose:()=>{t(A,!1)}})}var At=i(Ye,2);da(At,{get commands(){return e(h)},onClose:()=>{t(fe,!1)},get open(){return e(fe)},set open(a){t(fe,a,!0)}}),b(T,Ge),de(),k()}export{tn as component};
2
+ import{_ as Wt}from"../chunks/PPVm8Dsz.js";import{p as ht,i as P,s as te,a as b,f as S,d as Bt,j as pt,b as re,e as zt,c as Jt,g as ct}from"../chunks/BPDiEZo0.js";import{p as ce,w as de,g as e,x as m,c as u,d as i,r as c,t as Y,b as t,s as f,E as Ht,A as we,q as Vt,v as Gt,y as Qt,z as Xt,$ as Yt}from"../chunks/DWmC0QM7.js";import{h as Zt}from"../chunks/2rBV5OkJ.js";import{m as ea,s as be,d as mt,B as W,e as yt,I as Le,M as ta,K as aa,P as dt,l as ut,c as na,T as vt,n as sa}from"../chunks/B1bOvemT.js";import{g as ge}from"../chunks/BfbPKMXz.js";import{p as ra}from"../chunks/CZg4kn4E.js";import{A as oa}from"../chunks/DzuS5Nbr.js";import"../chunks/BDcFu3l7.js";import{A as ia}from"../chunks/BdtLzPpO.js";import{C as la}from"../chunks/i5iZvmIH.js";import{g as Re}from"../chunks/gQJcRhou.js";import{E as ca}from"../chunks/DomZZqvG.js";function da(T,o){ce(o,!0);let w=ht(o,"open",15,!1);const v=m(()=>o.commands.map((n,d)=>({label:n.label,value:String(d)})));function k(n){const d=parseInt(n.value,10);o.commands[d]&&o.commands[d].action()}ea(T,{get items(){return e(v)},placeholder:"Type a command...",emptyText:"No matching commands",onselect:k,get onclose(){return o.onClose},classes:"command-palette",get open(){return w()},set open(n){w(n)}}),de()}var ua=S('<div><span></span> <span class="status-label svelte-1cg9pai"> </span> <!></div>');function va(T,o){const w=m(()=>o.status==="connected"?"Connected":o.status==="reconnecting"?"Reconnecting...":"Disconnected");var v=ua();let k;var n=u(v),d=i(n,2),_=u(d,!0);c(d);var y=i(d,2);{var I=M=>{W(M,{classes:"btn-ghost btn-sm btn-retry",get onclick(){return o.onretry},text:"Retry"})};P(y,M=>{o.status==="disconnected"&&o.onretry&&M(I)})}c(v),Y(()=>{k=be(v,1,"connection-status svelte-1cg9pai",null,k,{reconnecting:o.status==="reconnecting",disconnected:o.status==="disconnected",connected:o.status==="connected"}),mt(v,"aria-label",`Connection: ${o.status??""}`),be(n,1,`conn-dot ${o.status??""}`,"svelte-1cg9pai"),te(_,e(w))}),b(T,v)}const gt=typeof navigator<"u"&&/Mac|iPhone|iPad/.test(navigator.userAgent),ft=gt?"⌘":"Ctrl";function fa(T){function o(w){if((gt?w.metaKey:w.ctrlKey)&&!pa()&&w.key==="/"){w.preventDefault(),w.stopPropagation(),T.onHelp();return}}return window.addEventListener("keydown",o,!0),{destroy(){window.removeEventListener("keydown",o,!0)}}}function ha(){return[{description:"Command palette",keys:`${ft}+K`},{description:"Keyboard shortcuts",keys:`${ft}+/`}]}function pa(){const T=document.activeElement;if(!T)return!1;const o=T.tagName;return!!(o==="INPUT"||o==="TEXTAREA"||T.isContentEditable||T.closest(".xterm"))}var ma=S('<div class="quick-keys svelte-64qat5" role="toolbar" aria-label="Quick terminal keys"></div>');function ya(T,o){ce(o,!0);const w=[{escape:"",label:"Ctrl+C"},{escape:" ",label:"Tab"},{escape:"\x1B[A",label:"↑"},{escape:"\x1B[B",label:"↓"},{escape:"\x1B",label:"Esc"},{escape:"",label:"Ctrl+D"},{escape:"",label:"Ctrl+Z"}];var v=ma();yt(v,21,()=>w,k=>k.label,(k,n)=>{W(k,{classes:"btn-quick-key",onclick:()=>{o.onKey(e(n).escape)},get text(){return e(n).label}})}),c(v),b(T,v),de()}var ga=S('<p class="share-gate-error svelte-axsobw"> </p>'),wa=S('<div class="share-gate svelte-axsobw"><div class="share-gate-card svelte-axsobw"><h2 class="share-gate-title svelte-axsobw">Shared terminal</h2> <p class="share-gate-sub svelte-axsobw">This terminal is password protected. Enter the password to view it.</p> <!> <!> <!></div></div>');function ba(T,o){ce(o,!0);let w=f(""),v=f(null),k=f(!1);async function n(){!e(w)||e(k)||(t(k,!0),t(v,null),t(v,await o.onSubmit(e(w)),!0),t(k,!1))}function d(g){g.key==="Enter"&&(g.preventDefault(),n())}var _=wa(),y=u(_),I=i(u(y),4);Le(I,{dataType:"password",placeholder:"Password",classes:"share-gate-input",onKeyDown:d,get value(){return e(w)},set value(g){t(w,g,!0)}});var M=i(I,2);{var B=g=>{var q=ga(),F=u(q,!0);c(q),Y(()=>te(F,e(v))),b(g,q)};P(M,g=>{e(v)&&g(B)})}var x=i(M,2);{let g=m(()=>!e(w)||e(k));W(x,{classes:"btn-primary share-gate-btn",onclick:()=>{n()},get disabled(){return e(g)},get showLoader(){return e(k)},text:"Unlock"})}c(y),c(_),b(T,_),de()}var _a=S('<div class="share-active-row svelte-fj2rhy"><span class="share-active-dot svelte-fj2rhy"></span> <span class="share-active-label svelte-fj2rhy"> </span></div> <div class="share-url-row svelte-fj2rhy"><span class="share-url svelte-fj2rhy"> </span> <!></div>',1),ka=S(`<p class="share-sheet-sub svelte-fj2rhy">Anyone with this page's link and the password below can access this terminal.</p>`),Sa=S('<p class="share-error svelte-fj2rhy"> </p>'),xa=S('<div class="share-backdrop svelte-fj2rhy" role="presentation"><div class="share-sheet svelte-fj2rhy" role="dialog" aria-label="Share terminal" tabindex="-1"><div class="share-sheet-header svelte-fj2rhy"><h2 class="share-sheet-title svelte-fj2rhy">Share terminal</h2> <button class="share-sheet-close svelte-fj2rhy" aria-label="Close">&times;</button></div> <!> <div class="share-field svelte-fj2rhy"><span class="share-field-label svelte-fj2rhy">Access</span> <div class="share-mode-toggle svelte-fj2rhy"><button>View only</button> <button>Full control</button></div></div> <div class="share-field svelte-fj2rhy"><span class="share-field-label svelte-fj2rhy"> </span> <div class="share-password-row svelte-fj2rhy"><!> <!></div></div> <!> <div class="share-actions svelte-fj2rhy"><!> <!></div></div></div>');function ja(T,o){ce(o,!0);const w=ht(o,"open",3,!1);let v=f(!1),k=f(null),n=f("view"),d=f(""),_=f(!1),y=f(null),I=f(!1);const M="ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz23456789",B=m(()=>e(v)?e(d).length===0||e(d).length>=6:e(d).length>=6);Ht(()=>{w()&&x()});async function x(){t(y,null),t(I,!1);try{const K=await fetch(`/api/terminals/${o.terminalId}/share`,{headers:{Authorization:`Bearer ${Re()}`}});if(!K.ok){t(y,"Failed to load share state.");return}const A=await K.json();t(v,A.active,!0),t(k,A.mode??null,!0),t(n,A.mode??"view",!0),t(d,"")}catch{t(y,"Failed to reach the server.")}}function g(){const K=crypto.getRandomValues(new Uint8Array(16));t(d,Array.from(K,A=>M[A%M.length]).join(""),!0)}async function q(){if(!(e(_)||!e(B))){t(_,!0),t(y,null);try{const K=await fetch(`/api/terminals/${o.terminalId}/share`,{body:JSON.stringify({mode:e(n),...e(d)?{password:e(d)}:{}}),headers:{Authorization:`Bearer ${Re()}`,"Content-Type":"application/json"},method:"PUT"});if(!K.ok){const R=await K.json().catch(()=>({}));t(y,R.error??"Failed to save share.",!0);return}const A=await K.json();t(v,A.active,!0),t(k,A.mode??null,!0),t(d,"")}catch{t(y,"Failed to reach the server.")}finally{t(_,!1)}}}async function F(){if(!e(_)){t(_,!0),t(y,null);try{if(!(await fetch(`/api/terminals/${o.terminalId}/share`,{headers:{Authorization:`Bearer ${Re()}`},method:"DELETE"})).ok){t(y,"Failed to revoke share.");return}t(v,!1),t(k,null),t(d,"")}catch{t(y,"Failed to reach the server.")}finally{t(_,!1)}}}async function z(){try{await navigator.clipboard.writeText(o.shareUrl),t(I,!0),setTimeout(()=>{t(I,!1)},2e3)}catch{t(y,"Failed to copy.")}}var ue=pt(),oe=we(ue);{var _e=K=>{var A=xa(),R=u(A),ae=u(R),H=i(u(ae),2);c(ae);var ve=i(ae,2);{var Z=h=>{var L=_a(),Q=we(L),ie=i(u(Q),2),je=u(ie);c(ie),c(Q);var Ce=i(Q,2),le=u(Ce),Te=u(le,!0);c(le);var Ie=i(le,2);{let qe=m(()=>e(I)?"Copied":"Copy");W(Ie,{classes:"btn-secondary btn-sm",onclick:()=>{z()},get text(){return e(qe)}})}c(Ce),Y(()=>{te(je,`Sharing is active (${e(k)==="control"?"full control":"view only"})`),te(Te,o.shareUrl)}),b(h,L)},fe=h=>{var L=ka();b(h,L)};P(ve,h=>{e(v)?h(Z):h(fe,-1)})}var j=i(ve,2),V=i(u(j),2),C=u(V),N=i(C,2);c(V),c(j);var ee=i(j,2),G=u(ee),ke=u(G,!0);c(G);var Se=i(G,2),xe=u(Se);Le(xe,{dataType:"text",placeholder:"Password",classes:"share-password-input",get value(){return e(d)},set value(h){t(d,h,!0)}});var Ke=i(xe,2);W(Ke,{classes:"btn-secondary btn-sm",onclick:g,text:"Generate"}),c(Se),c(ee);var he=i(ee,2);{var Oe=h=>{var L=Sa(),Q=u(L,!0);c(L),Y(()=>te(Q,e(y))),b(h,L)};P(he,h=>{e(y)&&h(Oe)})}var pe=i(he,2),ne=u(pe);{var me=h=>{W(h,{classes:"btn-danger btn-sm",onclick:()=>{F()},get disabled(){return e(_)},text:"Stop sharing"})};P(ne,h=>{e(v)&&h(me)})}var De=i(ne,2);{let h=m(()=>e(_)||!e(B)),L=m(()=>e(v)?"Update":"Start sharing");W(De,{classes:"btn-primary btn-sm",onclick:()=>{q()},get disabled(){return e(h)},get showLoader(){return e(_)},get text(){return e(L)}})}c(pe),c(R),c(A),Y(()=>{be(C,1,`share-mode-btn ${e(n)==="view"?"share-mode-active":""}`,"svelte-fj2rhy"),be(N,1,`share-mode-btn ${e(n)==="control"?"share-mode-active":""}`,"svelte-fj2rhy"),te(ke,e(v)?"New password (leave empty to keep current)":"Password (min 6 chars)")}),re("click",A,function(...h){o.onClose?.apply(this,h)}),re("keydown",A,h=>{h.key==="Escape"&&o.onClose()}),re("click",R,h=>{h.stopPropagation()}),re("keydown",R,h=>{h.key==="Escape"&&o.onClose()}),re("click",H,function(...h){o.onClose?.apply(this,h)}),re("click",C,()=>{t(n,"view")}),re("click",N,()=>{t(n,"control")}),b(K,A)};P(oe,K=>{w()&&K(_e)})}b(T,ue),de()}Bt(["click","keydown"]);var Ca=S('<div class="shortcut-row svelte-1u7lstk"><span class="shortcut-desc svelte-1u7lstk"> </span> <!></div>'),Ta=S('<div class="shortcuts-list svelte-1u7lstk"></div>');function Ia(T,o){ce(o,!0);const w=ha();var v=pt(),k=we(v);{var n=d=>{ta(d,{header:{text:"Keyboard Shortcuts"},get onoverlayClick(){return o.onClose},classes:"shortcuts-modal",content:y=>{var I=Ta();yt(I,21,()=>w,M=>M.keys,(M,B)=>{var x=Ca(),g=u(x),q=u(g,!0);c(g);var F=i(g,2);aa(F,{get keys(){return e(B).keys},classes:"shortcut-kbd"}),c(x),Y(()=>te(q,e(B).description)),b(M,x)}),c(I),b(y,I)},$$slots:{content:!0}})};P(k,d=>{o.open&&d(n)})}b(T,v),de()}var Ea=S('<meta name="description" content="Interactive terminal session"/>'),Aa=S('<div class="term-page svelte-1tubujq"><div class="term-topbar svelte-1tubujq"><div class="skeleton" style="width: 120px; height: 20px;"></div></div> <div class="term-body-loading svelte-1tubujq"><div class="skeleton" style="width: 100%; height: 100%;"></div></div></div>'),Pa=S('<div class="term-page svelte-1tubujq"><!></div>'),Ma=S('<main class="main"><div class="session-back-row"><a href="/terminals" class="back-link"><span class="back-arrow">&larr;</span> Terminals</a></div> <!></main>'),Ka=S('<a href="/terminals" class="term-back svelte-1tubujq" aria-label="Back to terminals">&larr;</a>'),Oa=S("<span></span>"),Da=S('<span class="term-cwd svelte-1tubujq"> </span>'),qa=S('<a class="term-session-link svelte-1tubujq" title="View session history">Session</a>'),Na=S("<!> <!>",1),$a=S('<div class="term-input-area svelte-1tubujq"><!> <div class="term-input-bar svelte-1tubujq"><!> <!></div></div>'),Fa=S('<div class="term-exited-bar svelte-1tubujq"><span>Process exited</span> <!></div>'),Ra=S('<div class="term-page svelte-1tubujq"><div class="term-topbar svelte-1tubujq"><div class="term-topbar-left svelte-1tubujq"><!> <span class="term-command-name svelte-1tubujq"> </span> <!> <!> <!> <!> <!></div> <div class="term-topbar-right svelte-1tubujq"><!> <!> <!></div></div> <div class="term-body svelte-1tubujq"></div> <!> <div class="term-chat-body svelte-1tubujq"><!></div> <!></div>'),La=S("<!> <!> <!> <!>",1);function tn(T,o){ce(o,!0);const w=()=>Jt(ra,"$page",v),[v,k]=zt();let n=f(null),d=f(!0),_=f(null),y=f(!1),I=f(!1),M=f(!1),B=f(null),x=f("raw"),g=f("disconnected"),q=f("disconnected"),F=f(""),z=f(Vt([])),ue=f(!1),oe=f(null),_e=f(null),K=f(!1),A=f(!1),R=f(null),ae=f(null),H=null,ve=null,Z=f(!1),fe=f(!1),j=null,V=null,C=!1;const N=m(()=>w().params.id),ee=m(()=>e(n)?ia.includes((e(n).command.split("/").pop()||"").toLowerCase()):!1),G=m(()=>e(n)?.status==="running"),ke=m(()=>e(n)?.command.split("/").pop()||"terminal"),Se=m(()=>e(ee)?"AI":"SHELL"),xe=m(()=>e(ee)?"pill-badge-ai":"pill-badge-shell"),Ke=["Raw","Chat"],he=m(()=>e(x)==="raw"?e(g):e(q)),Oe=m(()=>e(x)==="raw"?0:1),pe=m(()=>L(e(B)||e(n)?.cwd||"")),ne=m(()=>e(oe)==="owner"),me=m(()=>e(oe)==="guest"&&e(_e)==="view"),De=m(()=>typeof window<"u"?`${window.location.origin}/terminals/${e(N)}`:""),h=m(()=>{const a=[{action:()=>{ge("/")},label:"Go to Home"},{action:()=>{ge("/terminals")},label:"Go to Terminals"},{action:()=>{ge("/config")},label:"Go to Settings"},{action:()=>{t(Z,!0)},label:"Show keyboard shortcuts"}];return e(G)&&e(ne)&&a.push({action:()=>{We()},label:"Kill terminal"}),a});function L(a){if(!a)return"";const s="";let r=a;if(typeof navigator<"u"){const p=a.split("/");p.length>=3&&p[1]==="Users"?r=`~/${p.slice(3).join("/")}`:p.length>=3&&p[1]==="home"&&(r=`~/${p.slice(3).join("/")}`)}if(r.length>30){const p=r.split("/");if(p.length>2)return`.../${p.slice(-2).join("/")}`}return r||s}function Q(){try{const a=localStorage.getItem("shooter_config");if(!a)return null;const s=JSON.parse(a);return typeof s?.apiKey=="string"&&s.apiKey?s:null}catch{return null}}const ie="shooter_share_tokens";function je(){const a=e(N);if(!a)return null;try{const s=localStorage.getItem(ie);if(!s)return null;const r=JSON.parse(s);return typeof r[a]=="string"?r[a]:null}catch{return null}}function Ce(a){const s=e(N);if(!s)return;let r={};try{r=JSON.parse(localStorage.getItem(ie)??"{}")}catch{}r[s]=a,localStorage.setItem(ie,JSON.stringify(r))}function le(){return Q()?.apiKey??je()}async function Te(){const a=Q(),s=a?.apiKey??je();if(!s){await Ie();return}try{const r=await fetch(`/api/terminals/${e(N)}`,{headers:{Authorization:`Bearer ${s}`}});if(r.status===401&&!a){await Ie();return}if(!r.ok){t(_,r.status===404?"Terminal not found":"Failed to load terminal",!0),t(d,!1);return}t(n,await r.json(),!0),a?t(oe,"owner"):(t(oe,"guest"),t(_e,e(n).shareMode??"view",!0))}catch{t(_,"Failed to connect to server")}t(d,!1)}async function Ie(){try{const a=await fetch(`/api/terminals/${e(N)}/share/status`);if(a.ok&&(await a.json()).shared){t(K,!0),t(d,!1);return}}catch{}t(_,"No configuration found. Please configure settings first."),t(d,!1)}async function qe(a){try{const s=await fetch(`/api/terminals/${e(N)}/share/auth`,{body:JSON.stringify({password:a}),headers:{"Content-Type":"application/json"},method:"POST"});if(s.status===429)return"Too many attempts — try again in a minute.";if(!s.ok)return"Incorrect password.";const r=await s.json();return Ce(r.token),t(K,!1),t(d,!0),await Te(),e(n)&&!e(_)&&Ve(),null}catch{return"Failed to reach the server."}}async function Ue(){const a=le();if(!a)return null;try{const s=await fetch("/api/ws-ticket",{headers:{Authorization:`Bearer ${a}`},method:"POST"});return s.ok?(await s.json()).ticket:null}catch{return null}}async function We(){if(!e(n)||e(y))return;const a=Q();if(a){t(y,!0);try{(await fetch(`/api/terminals/${e(N)}`,{headers:{Authorization:`Bearer ${a.apiKey}`},method:"DELETE"})).ok?ge("/terminals"):t(y,!1)}catch{t(y,!1)}}}async function wt(){if(!e(n)||e(I))return;const a=Q();if(a){t(I,!0);try{(await fetch(`/api/terminals/${e(N)}`,{headers:{Authorization:`Bearer ${a.apiKey}`},method:"DELETE"})).ok?ge("/terminals"):t(I,!1)}catch{t(I,!1)}}}async function Ne(){if(!e(R)||!e(n)||C)return;const s=`${window.location.protocol==="https:"?"wss:":"ws:"}//${window.location.host}${e(n).ws}`,r=async()=>{const p=await Ue();if(!p)throw new Error("Failed to obtain WebSocket ticket");return p};try{const{createTerminal:p}=await Wt(async()=>{const{createTerminal:J}=await import("../chunks/J5-Cr5oR.js");return{createTerminal:J}},__vite__mapDeps([0,1]),import.meta.url);if(C||!e(R))return;const O=await p({apiKey:le()??void 0,container:e(R),fontSize:window.innerWidth<768?12:14,getTicket:r,initialCols:e(n).cols??void 0,initialRows:e(n).rows??void 0,onActivity:J=>{C||t(M,J,!0)},onCwd:J=>{C||t(B,J,!0)},onDisconnect:()=>{C||t(g,"reconnecting")},onExit:J=>{!C&&e(n)&&(t(n,{...e(n),exitCode:J,exitedAt:new Date().toISOString(),status:"exited"},!0),t(g,"disconnected"))},onReconnect:()=>{C||t(g,"connected")},readOnly:e(me),terminalId:e(N),wsUrl:s});if(C){O.dispose();return}H=O,t(g,"connected")}catch(p){console.error("Failed to initialize terminal:",p),t(g,"disconnected")}}function Be(){H&&(H.dispose(),H=null)}async function Ee(){if(!e(n)||C||j&&(j.readyState===WebSocket.OPEN||j.readyState===WebSocket.CONNECTING))return;const a=await Ue();if(!a||C||!e(n)){t(q,"disconnected");return}const r=`${window.location.protocol==="https:"?"wss:":"ws:"}//${window.location.host}${e(n).sessionWs}?ticket=${a}`;j=new WebSocket(r),j.onopen=()=>{C||(t(q,"connected"),j?.send(JSON.stringify({sessionId:e(N),type:"subscribe"})))},j.onmessage=p=>{if(!C)try{const O=JSON.parse(p.data);bt(O)}catch{}},j.onclose=()=>{!C&&e(n)?.status==="running"&&(t(q,"reconnecting"),V&&clearTimeout(V),V=setTimeout(()=>{V=null,!C&&e(n)?.status==="running"&&Ee()},2e3))},j.onerror=()=>{C||t(q,"disconnected")}}function ye(){return e(z)}function bt(a){if(a.type==="history"){const s=a.messages||[];t(z,s.map(r=>({id:r.id,parts:r.content,role:r.role,timestamp:r.timestamp})),!0)}else if(a.type==="message"){const s=typeof a.role=="string"?a.role:"assistant",r=s==="user"?"user":s==="system"?"system":"assistant",p={id:`msg-${Date.now()}-${Math.random().toString(36).slice(2,8)}`,parts:a.content||[],role:r,timestamp:(typeof a.timestamp=="string"?a.timestamp:"")||new Date().toISOString()};t(z,ye().concat(p),!0)}else if(a.type==="tool-use"){const s={id:a.id||`tool-${Date.now()}`,input:a.input||{},toolName:a.name,type:"tool_use"},r={id:`tool-${Date.now()}-${Math.random().toString(36).slice(2,8)}`,parts:[s],role:"assistant",timestamp:new Date().toISOString()};t(z,ye().concat(r),!0)}else if(a.type==="tool-result"){const s={isError:a.isError||!1,output:a.output||"",toolUseId:a.id,type:"tool_result"},r={id:`result-${Date.now()}-${Math.random().toString(36).slice(2,8)}`,parts:[s],role:"system",timestamp:new Date().toISOString()};t(z,ye().concat(r),!0)}else if(a.type==="thinking"){const s={content:a.text||"",type:"thinking"},r=ye(),p=r.length-1;if(p>=0&&r[p].role==="assistant"){const O=r[p],J={id:O.id,parts:O.parts.concat(s),role:O.role,timestamp:O.timestamp};t(z,[...r.slice(0,p),J],!0)}else{const O={id:`think-${Date.now()}-${Math.random().toString(36).slice(2,8)}`,parts:[s],role:"assistant",timestamp:new Date().toISOString()};t(z,r.concat(O),!0)}}else if(a.type==="error"){const s={content:a.message||"Unknown error",type:"text"},r={id:`err-${Date.now()}-${Math.random().toString(36).slice(2,8)}`,parts:[s],role:"system",timestamp:new Date().toISOString()};t(z,ye().concat(r),!0)}else a.type==="session-end"&&(t(ue,!0),e(n)&&t(n,{...e(n),status:"exited"},!0))}function ze(){V&&(clearTimeout(V),V=null),j&&(j.onclose=null,j.close(),j=null)}function Je(){e(F).trim()&&(H&&e(g)==="connected"&&H.sendInput(`${e(F)}\r`),t(F,""),e(ae)?.focus())}function _t(a){!a.trim()||j?.readyState!==WebSocket.OPEN||j.send(JSON.stringify({text:a,type:"send-input"}))}function He(){j?.readyState===WebSocket.OPEN&&j.send(JSON.stringify({type:"cancel"}))}function kt(a){e(x)==="raw"?H&&e(g)==="connected"&&H.sendInput(a):e(x)==="chat"&&a===""&&He()}function St(a){a.key==="Enter"&&!a.shiftKey&&(a.preventDefault(),Je())}let Ae=!1,Pe=!1;function xt(a){a!==e(x)&&(t(x,a,!0),a==="raw"&&!Ae?(requestAnimationFrame(()=>{Ne()}),Ae=!0):a==="chat"&&!Pe&&(Ee(),Pe=!0))}function jt(){e(x)==="raw"?(Be(),t(g,"reconnecting"),Ne(),Ae=!0):(ze(),t(q,"reconnecting"),Ee(),Pe=!0)}function Ve(){e(ee)&&window.innerWidth<768?t(x,"chat"):t(x,"raw"),e(x)==="raw"?(requestAnimationFrame(()=>{Ne()}),Ae=!0):(Ee(),Pe=!0)}Gt(async()=>{await Te(),!C&&(ve=fa({onHelp:()=>{t(Z,!e(Z))}}),!(!e(n)||e(_))&&Ve())}),Qt(()=>{C=!0,Be(),ze(),ve?.destroy()});var Ge=La();Zt("1tubujq",a=>{var s=Ea();Xt(()=>{Yt.title=`${e(ke)??""} - Terminal - Shooter`}),b(a,s)});var Qe=we(Ge);{var Ct=a=>{var s=Aa();b(a,s)},Tt=a=>{var s=Pa(),r=u(s);ba(r,{onSubmit:qe}),c(s),b(a,s)},It=a=>{var s=Ma(),r=i(u(s),2);ca(r,{title:"Error",get description(){return e(_)},icon:O=>{na(O,{get svg(){return oa},classes:"icon-24"})}}),c(s),b(a,s)},Et=a=>{var s=Ra(),r=u(s),p=u(r),O=u(p);{var J=l=>{var E=Ka();b(l,E)};P(O,l=>{e(ne)&&l(J)})}var $e=i(O,2),Pt=u($e,!0);c($e);var Ze=i($e,2);dt(Ze,{get text(){return e(Se)},get classes(){return e(xe)}});var et=i(Ze,2);{var Mt=l=>{{let E=m(()=>e(M)?"Active":"Idle");vt(l,{get text(){return e(E)},position:"bottom",children:($,X)=>{var D=Oa();Y(()=>be(D,1,`activity-dot ${e(M)?"activity-active":"activity-idle"}`,"svelte-1tubujq")),b($,D)},$$slots:{default:!0}})}};P(et,l=>{e(G)&&l(Mt)})}var tt=i(et,2);{var Kt=l=>{{let E=m(()=>e(B)||e(n)?.cwd||"");vt(l,{get text(){return e(E)},position:"bottom",children:($,X)=>{var D=Da(),se=u(D,!0);c(D),Y(()=>te(se,e(pe))),b($,D)},$$slots:{default:!0}})}};P(tt,l=>{e(pe)&&l(Kt)})}var at=i(tt,2);va(at,{get status(){return e(he)},onretry:jt});var Ot=i(at,2);{var Dt=l=>{const E=m(()=>e(n).sessionFile??"");var $=qa();Y(X=>mt($,"href",`/session/${X??""}`),[()=>e(E).split(/[\\/]/).pop()?.replace(".jsonl","")||""]),b(l,$)};P(Ot,l=>{e(ne)&&e(ee)&&e(n)?.sessionFile&&l(Dt)})}c(p);var nt=i(p,2),st=u(nt);{var qt=l=>{sa(l,{get items(){return Ke},get activeIndex(){return e(Oe)},onchange:E=>{xt(E===0?"raw":"chat")},classes:"term-tabs"})};P(st,l=>{e(ee)&&l(qt)})}var rt=i(st,2);W(rt,{classes:"term-shortcuts-btn",onclick:()=>{t(Z,!e(Z))},text:"?",ariaLabel:"Keyboard shortcuts"});var Nt=i(rt,2);{var $t=l=>{var E=Na(),$=we(E);W($,{classes:"btn-secondary btn-sm",onclick:()=>{t(A,!0)},text:"Share"});var X=i($,2);{var D=U=>{W(U,{classes:"btn-danger btn-sm",onclick:We,get disabled(){return e(y)},get showLoader(){return e(y)},text:"Kill"})},se=U=>{W(U,{classes:"btn-secondary btn-sm",onclick:wt,get disabled(){return e(I)},get showLoader(){return e(I)},text:"Remove"})};P(X,U=>{e(G)?U(D):U(se,-1)})}b(l,E)};P(Nt,l=>{e(ne)&&l($t)})}c(nt),c(r);var Fe=i(r,2);let ot;ct(Fe,l=>t(R,l),()=>e(R));var it=i(Fe,2);{var Ft=l=>{var E=$a(),$=u(E);ya($,{onKey:kt});var X=i($,2),D=u(X);ct(Le(D,{dataType:"text",useTextArea:!0,placeholder:"Type command... (Shift+Enter for new line)",classes:"input-mono term-input-field",onKeyDown:St,get value(){return e(F)},set value(U){t(F,U,!0)}}),U=>t(ae,U,!0),()=>e(ae));var se=i(D,2);{let U=m(()=>!e(F).trim());W(se,{classes:"btn-primary btn-send",onclick:Je,get disabled(){return e(U)},text:"↵"})}c(X),c(E),b(l,E)};P(it,l=>{e(G)&&e(x)==="raw"&&!e(me)&&l(Ft)})}var Me=i(it,2);let lt;var Rt=u(Me);{let l=m(()=>e(G)&&!e(me));la(Rt,{get messages(){return e(z)},get connectionState(){return e(he)},get sessionEnded(){return e(ue)},get showInput(){return e(l)},onSendInput:_t,onCancel:He})}c(Me);var Lt=i(Me,2);{var Ut=l=>{var E=Fa(),$=i(u(E),2);{var X=D=>{{let se=m(()=>e(n).exitCode!==0?"pill-exit-error":"pill-exit-ok");dt(D,{get text(){return`code ${e(n).exitCode??""}`},get classes(){return e(se)}})}};P($,D=>{e(n).exitCode!==null&&D(X)})}c(E),b(l,E)};P(Lt,l=>{e(G)||l(Ut)})}c(s),Y(()=>{te(Pt,e(ke)),ot=ut(Fe,"",ot,{display:e(x)==="raw"?"flex":"none"}),lt=ut(Me,"",lt,{display:e(x)==="chat"?"flex":"none"})}),b(a,s)};P(Qe,a=>{e(d)?a(Ct):e(K)?a(Tt,1):e(_)?a(It,2):e(n)&&a(Et,3)})}var Xe=i(Qe,2);Ia(Xe,{get open(){return e(Z)},onClose:()=>{t(Z,!1)}});var Ye=i(Xe,2);{let a=m(()=>e(N)??"");ja(Ye,{get open(){return e(A)},get terminalId(){return e(a)},get shareUrl(){return e(De)},onClose:()=>{t(A,!1)}})}var At=i(Ye,2);da(At,{get commands(){return e(h)},onClose:()=>{t(fe,!1)},get open(){return e(fe)},set open(a){t(fe,a,!0)}}),b(T,Ge),de(),k()}export{tn as component};
@@ -0,0 +1,23 @@
1
+ import{d as he,i as N,s as _,b as Wt,a as p,f as h}from"../chunks/BPDiEZo0.js";import{s as J,q as qt,g as r,b as w,p as Yt,v as ge,c as l,d as v,r as c,t as R,w as Ft,x as H,A as Mt,y as Ee,D as Te,$ as Ne,B as se}from"../chunks/DWmC0QM7.js";import{s as Tt,g as Dt,d as nt,e as dt,P as ye,l as Oe,j as Qt,B as Jt,c as $t,b as ze,i as ne}from"../chunks/B1bOvemT.js";import{h as Ie}from"../chunks/2rBV5OkJ.js";import{g as ae}from"../chunks/BfbPKMXz.js";import{B as Pe}from"../chunks/Bn-6X1BO.js";import{R as je,S as re}from"../chunks/CJulw9ux.js";import{S as Le}from"../chunks/CG453M9q.js";import{c as Me,s as De,g as Re}from"../chunks/xs1Xl3_e.js";import{g as oe,i as Be}from"../chunks/gQJcRhou.js";import"../chunks/BDcFu3l7.js";import{f as Xt}from"../chunks/BLszSzTT.js";import{S as Ke}from"../chunks/BcpydfqI.js";import{i as We,N as qe}from"../chunks/C4Hns_Wl.js";import{d as Ye}from"../chunks/C87ZRWX0.js";import{E as ie}from"../chunks/DomZZqvG.js";const Fe=2e4;function Ge(e){if(typeof document>"u")return()=>{};const t=()=>{Ut(e,document.visibilityState==="visible"?"foreground":"background")},n=()=>{Ut(e,"background")};t();const a=setInterval(t,Fe);return document.addEventListener("visibilitychange",t),window.addEventListener("pagehide",n),()=>{clearInterval(a),document.removeEventListener("visibilitychange",t),window.removeEventListener("pagehide",n),Ut(e,"background")}}function Ut(e,t){fetch("/api/presence",{body:JSON.stringify({state:t}),headers:{Authorization:`Bearer ${e}`,"Content-Type":"application/json"},keepalive:!0,method:"POST"}).catch(()=>{})}const Je={humanGraceMs:5e3,injectConfidence:.7,maxAutoActions:8,minIntervalMs:3e4},ce=400,$e=[/\brm\s+-[a-z]*r[a-z]*f?\s+(\/|~|\/\*|\$home)/i,/\brm\s+-[a-z]*f[a-z]*r?\s+(\/|~|\/\*|\$home)/i,/:\(\)\s*\{\s*:\s*\|\s*:\s*&\s*\}\s*;\s*:/,/\bdd\b[^\n]*\bof=\/dev\//i,/>\s*\/dev\/(sd|nvme|disk|hd)/i,/\bmkfs(\.[a-z0-9]+)?\b/i,/\b(shutdown|reboot|halt|poweroff)\b/i];function Ue(e,t,n,a=Je,s={}){const o=t.steps[0];return o?o.tentative&&!s.allowTentative?{act:!1,reason:"consensus is tentative (no quorum)"}:e.isManaged?e.lastEventType!=="agent-idle"?{act:!1,reason:`agent not idle (last event: ${e.lastEventType})`}:n-e.lastActivityAt<a.humanGraceMs?{act:!1,reason:"recent activity — within human grace window"}:n-e.lastInjectedAt<a.minIntervalMs?{act:!1,reason:"rate-limited (min inject interval)"}:e.autoActionCount>=a.maxAutoActions?{act:!1,reason:"circuit breaker — max consecutive auto-actions reached"}:o.confidence<a.injectConfidence?{act:!1,reason:`confidence ${o.confidence.toFixed(2)} below floor`}:e.lastActedStep!==null&&Zt(o.text)===e.lastActedStep?{act:!1,reason:"already acted on this step"}:{act:!0,reason:"idle + high-confidence consensus",step:o}:{act:!1,reason:"terminal is external / read-only (cannot inject)"}:{act:!1,reason:"no consensus step"}}function He(e,t){const n=e.trim();if(n.length===0)return{command:n,reason:"empty command",safe:!1};if(/[\r\n]/.test(e))return{command:n,reason:"multi-line command rejected (single command only)",safe:!1};if(n.length>ce)return{command:n,reason:`command too long (> ${ce})`,safe:!1};for(const a of $e)if(a.test(n))return{command:n,reason:"matches a dangerous-command pattern",safe:!1};return t!==null&&n===t.trim()?{command:n,reason:"duplicate of last injected command",safe:!1}:{command:n,reason:"ok",safe:!0}}function Zt(e){return e.toLowerCase().trim().replace(/\s+/g," ").replace(/[.,;:!?]+$/,"")}const _e="shooter_autonomy",Ve=6e3,Xe=3e3,Ze=5e3,Qe=40,ts=12e4,es=120,ss=/^[A-Za-z0-9_-]+$/,ns=new Set(["bun","cargo","cat","deno","echo","eslint","git","go","jest","ls","make","node","npm","npx","pnpm","prettier","pwd","python","python3","tsc","vitest","yarn"]),as=new Set(["claude","opencode"]);class rs{#t=J(qt([]));get actions(){return r(this.#t)}set actions(t){w(this.#t,t,!0)}#e=J(!1);get enabled(){return r(this.#e)}set enabled(t){w(this.#e,t,!0)}apiKey="";deps;eventsWs=null;pollTimer=null;reconnectTimer=null;started=!1;terminals=new Map;constructor(t){this.deps={now:t?.now??(()=>Date.now()),produceCommand:t?.produceCommand??os},this.enabled=us()}setEnabled(t){this.enabled=t;try{localStorage.setItem(_e,JSON.stringify({enabled:t}))}catch{}}start(t){this.apiKey=t,!this.started&&(this.started=!0,typeof window<"u"&&window.addEventListener("shooter:wake",this.onWake),this.connectEvents(),this.refresh(),this.pollTimer=setInterval(()=>{this.refresh()},Ve))}stop(){this.started=!1,typeof window<"u"&&window.removeEventListener("shooter:wake",this.onWake),this.pollTimer&&(clearInterval(this.pollTimer),this.pollTimer=null),this.reconnectTimer&&(clearTimeout(this.reconnectTimer),this.reconnectTimer=null),this.eventsWs&&(this.eventsWs.onclose=null,this.eventsWs.close(),this.eventsWs=null);for(const t of this.terminals.values())t.injectSocket?.close(),t.injectSocket=null}async connectEvents(){const t=await this.getTicket();if(!t||!this.started)return;const n=window.location.origin.replace(/^http/,"ws"),a=new WebSocket(`${n}/ws/events?ticket=${t}`);this.eventsWs=a,a.onmessage=s=>{try{const o=JSON.parse(s.data);o&&typeof o=="object"&&this.handleEvent(o)}catch{}},a.onclose=()=>{this.eventsWs=null,this.started&&this.scheduleReconnect()},a.onerror=()=>{}}createRuntime(t){const n={autoActionCount:0,busy:!1,command:"",consensus:null,injectSocket:null,isManaged:!1,lastActedStep:null,lastActivityAt:0,lastCommand:null,lastEventAt:0,lastEventType:"",lastInjectedAt:0,recentOutput:""};return this.terminals.set(t,n),n}async evaluate(t){if(!this.enabled)return;const n=this.terminals.get(t);if(!n||n.busy||!n.consensus)return;const a={autoActionCount:n.autoActionCount,isManaged:n.isManaged,lastActedStep:n.lastActedStep,lastActivityAt:n.lastActivityAt,lastEventType:n.lastEventType,lastInjectedAt:n.lastInjectedAt},s=Ue(a,n.consensus,this.deps.now(),void 0,{allowTentative:Ht(n.command)});if(!(!s.act||!s.step)){n.busy=!0;try{const o=Ht(n.command);let f;try{f=await this.deps.produceCommand({apiKey:this.apiKey,isAgentTerminal:o,recentOutput:n.recentOutput,step:s.step,terminalId:t})}catch{f=null}if(!f){this.log(t,"skipped",`no command for: ${s.step.text.slice(0,60)}`);return}const g=o?f.replace(/\s*[\r\n]+\s*/g," ").trim():f,k=He(g,n.lastCommand);if(!k.safe){n.lastActedStep=Zt(s.step.text),this.log(t,"skipped",`guard: ${k.reason}`);return}await this.inject(t,k.command)?(n.lastInjectedAt=this.deps.now(),n.lastCommand=k.command,n.lastActedStep=Zt(s.step.text),n.autoActionCount+=1,this.log(t,"injected",k.command)):this.log(t,"error",`inject failed: ${k.command}`)}finally{n.busy=!1}}}async fetchSummaries(){try{const t=await fetch("/api/summaries?limit=30",{headers:{Authorization:`Bearer ${this.apiKey}`}});if(!t.ok)return;const n=await t.json(),a=new Set;for(const s of n.summaries??[]){const o=s.terminalId;if(!o||a.has(o))continue;const f=this.terminals.get(o);if(!f)continue;a.add(o),f.consensus={agentCount:5,quorum:3,steps:ls(s.nextSteps)};const g=Date.parse(s.createdAt);s.trigger==="agent-idle"&&Number.isFinite(g)&&g>=f.lastEventAt&&this.deps.now()-g<ts&&(f.lastEventType="agent-idle")}}catch{}}async fetchTerminals(){try{const t=await fetch("/api/terminals",{headers:{Authorization:`Bearer ${this.apiKey}`}});if(!t.ok)return;const n=await t.json(),a=new Set;for(const s of n.terminals??[]){if(s.exitedAt!==null||s.status==="exited")continue;a.add(s.id);const o=this.terminals.get(s.id)??this.createRuntime(s.id);o.isManaged=!0,o.command=s.command??""}for(const s of[...this.terminals.keys()])a.has(s)||(this.terminals.get(s)?.injectSocket?.close(),this.terminals.delete(s))}catch{}}async getTicket(){try{const t=await fetch("/api/ws-ticket",{headers:{Authorization:`Bearer ${this.apiKey}`},method:"POST"});if(!t.ok)return null;const{ticket:n}=await t.json();return n}catch{return null}}handleEvent(t){const n=typeof t.type=="string"?t.type:"",a=typeof t.terminalId=="string"?t.terminalId:"";if(!n||n==="welcome"||!a)return;const s=this.terminals.get(a);s&&(s.lastEventType=n,s.lastEventAt=this.deps.now(),n!=="agent-idle"&&n!=="agent-question"&&(s.lastActivityAt=this.deps.now()),n==="tool-completed"&&t.success===!0&&(s.autoActionCount=0),n==="agent-idle"&&this.enabled&&this.evaluate(a))}async inject(t,n){const a=this.terminals.get(t);if(!a||!ss.test(t))return!1;let s=a.injectSocket;if(!s||s.readyState>WebSocket.OPEN){const o=await this.getTicket();if(!o)return!1;const f=window.location.origin.replace(/^http/,"ws");if(s=new WebSocket(`${f}/ws/terminal/${encodeURIComponent(t)}?ticket=${encodeURIComponent(o)}`),a.injectSocket=s,!await vs(s))return a.injectSocket=null,!1}if(s.readyState!==WebSocket.OPEN)return!1;if(Ht(a.command)){const o=n.replace(/\s*[\r\n]+\s*/g," ").trim();return!o||(s.send(JSON.stringify({data:o,type:"input"})),await is(es),s.readyState!==WebSocket.OPEN)?!1:(s.send(JSON.stringify({data:"\r",type:"input"})),!0)}return s.send(JSON.stringify({data:`${n}\r`,type:"input"})),!0}log(t,n,a){this.actions=[{at:this.deps.now(),detail:a,kind:n,terminalId:t},...this.actions].slice(0,Qe)}onWake=()=>{this.refresh()};async refresh(){if(this.apiKey&&(await Promise.allSettled([this.fetchTerminals(),this.fetchSummaries()]),this.enabled))for(const t of this.terminals.keys())this.evaluate(t)}scheduleReconnect(){this.reconnectTimer||(this.reconnectTimer=setTimeout(()=>{this.reconnectTimer=null,this.connectEvents()},Xe))}}async function os(e){if(e.isAgentTerminal){const f=e.step.text.trim();return f.length>0?f:null}const t=await ds(e);if(t)return t;const n=await cs(e);if(n)return n;const a=e.step.text.trim(),s=/`([^`]+)`/.exec(a);if(s)return s[1].trim();const o=a.split(/\s+/)[0]?.toLowerCase();return o&&ns.has(o)&&!/[\r\n]/.test(a)&&a.length<80?a:null}function is(e){return new Promise(t=>{setTimeout(t,e)})}function Ht(e){const n=(e.trim().split(/\s+/)[0]??"").split("/").pop()??"";return as.has(n)}async function cs(e){const t=le("LITELLM_BASE_URL");if(!t||!e.apiKey)return null;const n=le("LITELLM_MODEL")||"open-large",a=`Recent terminal output:
2
+ ${e.recentOutput.slice(-2e3)}
3
+
4
+ Suggested next step: ${e.step.text}
5
+
6
+ Reply with ONLY the single shell command to run next — no prose, no backticks, no explanation.`;try{const s=await fetch("/api/neurolink-proxy",{body:JSON.stringify({body:{max_tokens:60,messages:[{content:"You are a coding-session copilot. Output ONLY the next shell command.",role:"system"},{content:a,role:"user"}],model:n,temperature:0},headers:{},provider:"litellm",url:`${t}/chat/completions`}),headers:{Authorization:`Bearer ${e.apiKey}`,"Content-Type":"application/json"},method:"POST"});if(!s.ok)return null;const f=(await s.json()).choices?.[0]?.message?.content;if(typeof f!="string")return null;const g=f.trim().replace(/^`+|`+$/g,"").trim();return g.length>0?g:null}catch{return null}}function ls(e){try{const t=JSON.parse(e);return Array.isArray(t)?t.filter(n=>typeof n=="object"&&n!==null&&typeof n.text=="string"&&typeof n.confidence=="number"):[]}catch{return[]}}function us(){if(typeof localStorage>"u")return!1;try{const e=localStorage.getItem(_e);return e?!!JSON.parse(e)?.enabled:!1}catch{return!1}}function le(e){const n=window.process?.env?.[e];return typeof n=="string"?n:""}function ds(e){const t=window.ShooterBridge;if(typeof t?.agentDecide!="function")return Promise.resolve(null);const n=`Recent terminal output:
7
+ ${e.recentOutput.slice(-2e3)}
8
+
9
+ Suggested next step: ${e.step.text}
10
+
11
+ Reply with the single shell command to run next.`;return t.agentDecide(n).then(a=>typeof a=="string"&&a.trim().length>0?a.trim():null).catch(()=>null)}function vs(e){return e.readyState===WebSocket.OPEN?Promise.resolve(!0):new Promise(t=>{const n=setTimeout(()=>{e.close(),t(!1)},Ze);e.addEventListener("open",()=>{clearTimeout(n),t(!0)}),e.addEventListener("error",()=>{clearTimeout(n),e.close(),t(!1)})})}const F=new rs;var fs=h('<span class="status-dot-active svelte-ziwu2n" aria-hidden="true"></span>'),ms=h('<div class="autonomy-warning svelte-ziwu2n" role="alert">⚠ Auto-inject is ON — proposed commands run automatically in idle managed terminals.</div>'),ps=h('<li><span class="action-kind svelte-ziwu2n"> </span> <span class="action-detail svelte-ziwu2n"> </span> <span class="action-time svelte-ziwu2n"> </span></li>'),hs=h('<div class="actions-log svelte-ziwu2n"><span class="actions-label svelte-ziwu2n">Recent actions</span> <ul class="actions-list svelte-ziwu2n"></ul></div>'),gs=h('<p class="session-summary svelte-ziwu2n"> </p>'),ys=h('<li class="step-item svelte-ziwu2n"><span> </span> <span class="step-text svelte-ziwu2n"> </span></li>'),_s=h('<div class="next-steps svelte-ziwu2n"><span class="next-steps-label svelte-ziwu2n">Next steps</span> <ul class="steps-list svelte-ziwu2n"></ul></div>'),Ss=h('<div class="session-card svelte-ziwu2n"><div class="session-header svelte-ziwu2n"><span class="session-name svelte-ziwu2n"> </span> <span class="session-status session-status--idle svelte-ziwu2n"> </span></div> <!> <!> <span class="last-updated svelte-ziwu2n"> </span></div>'),ws=h('<div class="sessions-list svelte-ziwu2n"></div>'),bs=h('<p class="panel-empty svelte-ziwu2n"> </p>'),As=h('<div class="autopilot-panel svelte-ziwu2n"><div class="panel-header svelte-ziwu2n"><div class="panel-title-row svelte-ziwu2n"><span class="panel-title svelte-ziwu2n">Auto-pilot</span> <!></div> <button> </button></div> <div class="autonomy-row svelte-ziwu2n"><div class="autonomy-label svelte-ziwu2n"><span class="autonomy-title svelte-ziwu2n">Autonomy</span> <span class="autonomy-sub svelte-ziwu2n"> </span></div> <button> </button></div> <!> <!> <!></div>');function ks(e,t){Yt(t,!0);let n=J(!1),a=J(qt([]));const s=H(()=>{const i=new Set,d=[];for(const S of r(a)){const x=S.sessionId??S.terminalId??S.id;i.has(x)||(i.add(x),d.push(S))}return d});function o(){const i=oe();return i?{Authorization:`Bearer ${i}`}:{}}async function f(){try{const i=await fetch("/api/autopilot",{headers:o()});i.ok&&w(n,!!(await i.json()).enabled,!0)}catch{}}async function g(){try{const i=await fetch("/api/summaries?limit=30",{headers:o()});i.ok&&w(a,(await i.json()).summaries??[],!0)}catch{}}async function k(){const i=!r(n);w(n,i);try{const d=await fetch("/api/autopilot",{body:JSON.stringify({enabled:i}),headers:{...o(),"Content-Type":"application/json"},method:"POST"});d.ok&&w(n,!!(await d.json()).enabled,!0)}catch{w(n,!i)}}function E(){F.setEnabled(!F.enabled)}function A(i){return Xt(new Date(i).toISOString())}function b(i){try{const d=JSON.parse(i);return Array.isArray(d)?d:[]}catch{return[]}}function O(i){if(i.tentative)return"step-badge step-badge--tentative";const d=i.votes??1;return d>=4?"step-badge step-badge--strong":d>=3?"step-badge step-badge--medium":"step-badge step-badge--weak"}function P(i){return i.tentative?"~":`${i.votes??1}`}ge(()=>{f(),g();const i=oe();i&&F.start(i);const d=i?Ge(i):null,S=setInterval(()=>{g(),f()},8e3);return()=>{clearInterval(S),F.stop(),d?.()}});var j=As(),vt=l(j),et=l(vt),St=v(l(et),2);{var wt=i=>{var d=fs();p(i,d)};N(St,i=>{r(n)&&i(wt)})}c(et);var K=v(et,2),ft=l(K,!0);c(K),c(vt);var V=v(vt,2),$=l(V),at=v(l($),2),bt=l(at,!0);c(at),c($);var W=v($,2),At=l(W,!0);c(W),c(V);var rt=v(V,2);{var kt=i=>{var d=ms();p(i,d)};N(rt,i=>{F.enabled&&i(kt)})}var ot=v(rt,2);{var xt=i=>{var d=hs(),S=v(l(d),2);dt(S,21,()=>F.actions.slice(0,6),x=>`${x.at}-${x.terminalId}`,(x,z)=>{var q=ps(),B=l(q),U=l(B,!0);c(B);var X=v(B,2),T=l(X,!0);c(X);var I=v(X,2),L=l(I,!0);c(I),c(q),R(Z=>{Tt(q,1,`action-item action-item--${r(z).kind??""}`,"svelte-ziwu2n"),_(U,r(z).kind),nt(X,"title",r(z).detail),_(T,r(z).detail),_(L,Z)},[()=>A(r(z).at)]),p(x,q)}),c(S),c(d),p(i,d)};N(ot,i=>{F.actions.length>0&&i(xt)})}var m=v(ot,2);{var y=i=>{var d=ws();dt(d,21,()=>r(s),S=>S.id,(S,x)=>{const z=H(()=>b(r(x).nextSteps));var q=Ss(),B=l(q),U=l(B),X=l(U,!0);c(U);var T=v(U,2),I=l(T,!0);c(T),c(B);var L=v(B,2);{var Z=C=>{var D=gs(),it=l(D,!0);c(D),R(()=>_(it,r(x).summary)),p(C,D)};N(L,C=>{r(x).summary&&C(Z)})}var Y=v(L,2);{var st=C=>{var D=_s(),it=v(l(D),2);dt(it,21,()=>r(z),pt=>pt.text,(pt,ct)=>{var Ct=ys(),lt=l(Ct),Gt=l(lt,!0);c(lt);var zt=v(lt,2),It=l(zt,!0);c(zt),c(Ct),R((Pt,Et)=>{Tt(lt,1,Pt,"svelte-ziwu2n"),nt(lt,"title",`${r(ct).votes??1??""} vote(s)`),_(Gt,Et),_(It,r(ct).text)},[()=>Dt(O(r(ct))),()=>P(r(ct))]),p(pt,Ct)}),c(it),c(D),p(C,D)};N(Y,C=>{r(z).length>0&&C(st)})}var mt=v(Y,2),M=l(mt);c(mt),c(q),R(C=>{_(X,r(x).projectName??r(x).terminalId),_(I,r(x).trigger),_(M,`Updated ${C??""}`)},[()=>Xt(r(x).createdAt)]),p(S,q)}),c(d),p(i,d)},u=i=>{var d=bs(),S=l(d,!0);c(d),R(()=>_(S,r(n)?"Watching all active sessions…":"Start Auto-pilot for AI summaries + next steps across all sessions — runs on the server, even with this page closed.")),p(i,d)};N(m,i=>{r(s).length>0?i(y):i(u,-1)})}c(j),R(()=>{Tt(K,1,Dt(r(n)?"toggle-btn toggle-btn--on":"toggle-btn toggle-btn--off"),"svelte-ziwu2n"),nt(K,"aria-label",r(n)?"Stop Auto-pilot":"Start Auto-pilot"),nt(K,"aria-pressed",r(n)),_(ft,r(n)?"Stop":"Start"),_(bt,F.enabled?"Auto-running commands into idle terminals":"Off — summaries + suggestions only"),Tt(W,1,Dt(F.enabled?"toggle-btn toggle-btn--danger":"toggle-btn toggle-btn--off"),"svelte-ziwu2n"),nt(W,"aria-label",F.enabled?"Disable autonomy":"Enable autonomy"),nt(W,"aria-pressed",F.enabled),_(At,F.enabled?"On":"Off")}),Wt("click",K,k),Wt("click",W,E),p(e,j),Ft()}he(["click"]);var xs=h('<p class="goal-text svelte-1qbe2oo"> </p>'),Cs=h('<span class="summarizing svelte-1qbe2oo">Analyzing…</span>'),Es=h('<span class="summary-text svelte-1qbe2oo"> </span>'),Ts=h('<span class="summary-fallback svelte-1qbe2oo"> </span>'),Ns=h('<span class="stat stat-error svelte-1qbe2oo"> </span>'),Os=h('<div class="card svelte-1qbe2oo" role="button" tabindex="0"><div class="card-header svelte-1qbe2oo"><span class="project-name svelte-1qbe2oo"> </span> <!></div> <!> <div class="summary-row svelte-1qbe2oo"><!></div> <div class="stats-row svelte-1qbe2oo"><span class="stat svelte-1qbe2oo"><span></span> </span> <span class="stat svelte-1qbe2oo"> </span> <!> <span class="stat stat-path svelte-1qbe2oo"> </span></div></div>');function ue(e,t){Yt(t,!0);function n(m){const y=Math.floor(m/1e3);if(y<60)return`${y}s`;const u=Math.floor(y/60);return u<60?`${u}m ${y%60}s`:`${Math.floor(u/60)}h ${u%60}m`}function a(m){const y=m.replace(/\/$/,"").split("/");return y.length<=2?m:y.slice(-2).join("/")}const s=H(()=>t.card.status==="running"&&t.card.isActive?"var(--ds-green-700)":t.card.status==="running"?"var(--ds-blue-700)":t.card.status==="idle"?"var(--ds-amber-700)":t.card.status==="error"?"var(--ds-red-700)":"var(--ds-gray-600)"),o=H(()=>t.card.status==="running"&&t.card.isActive||t.card.status==="running"?"● Running":t.card.status==="idle"?"◎ Idle":t.card.status==="exited"?"○ Done":t.card.status==="error"?"✕ Error":t.card.status),f=H(()=>t.card.status==="running"&&t.card.isActive?"status-pill status-pill--running-active":t.card.status==="running"?"status-pill status-pill--running":t.card.status==="idle"?"status-pill status-pill--idle":t.card.status==="exited"?"status-pill status-pill--exited":t.card.status==="error"?"status-pill status-pill--error":"status-pill"),g=H(()=>t.card.toolCallCount===0?"Waiting for activity…":t.card.toolCallCount===1?"1 tool call so far":`${t.card.toolCallCount} tool calls so far`);function k(m){(m.key==="Enter"||m.key===" ")&&(m.key===" "&&m.preventDefault(),t.onclick?.())}var E=Os(),A=l(E),b=l(A),O=l(b,!0);c(b);var P=v(b,2);ye(P,{get text(){return r(o)},get classes(){return r(f)}}),c(A);var j=v(A,2);{var vt=m=>{var y=xs(),u=l(y,!0);c(y),R(()=>_(u,t.card.goal)),p(m,y)};N(j,m=>{t.card.goal&&m(vt)})}var et=v(j,2),St=l(et);{var wt=m=>{var y=Cs();p(m,y)},K=m=>{var y=Es(),u=l(y,!0);c(y),R(()=>_(u,t.card.summary)),p(m,y)},ft=m=>{var y=Ts(),u=l(y,!0);c(y),R(()=>_(u,r(g))),p(m,y)};N(St,m=>{t.card.isSummarizing?m(wt):t.card.summary?m(K,1):t.card.status==="running"&&m(ft,2)})}c(et);var V=v(et,2),$=l(V),at=l($),bt=v(at);c($);var W=v($,2),At=l(W);c(W);var rt=v(W,2);{var kt=m=>{var y=Ns(),u=l(y);c(y),R(()=>_(u,`${t.card.errorCount??""} errors`)),p(m,y)};N(rt,m=>{t.card.errorCount>0&&m(kt)})}var ot=v(rt,2),xt=l(ot,!0);c(ot),c(V),c(E),R((m,y)=>{Oe(E,`--status-color: ${r(s)??""}`),nt(E,"aria-label",`Open ${t.card.projectName??""} session`),_(O,t.card.projectName),Tt(at,1,Dt(t.card.status==="running"&&t.card.isActive?"status-dot-active":"status-dot-static"),"svelte-1qbe2oo"),_(bt,` ${m??""}`),_(At,`${t.card.toolCallCount??""} tools`),nt(ot,"title",t.card.cwd),_(xt,y)},[()=>n(t.card.duration),()=>a(t.card.cwd)]),Wt("click",E,function(...m){t.onclick?.apply(this,m)}),Wt("keydown",E,k),p(e,E),Ft()}he(["click","keydown"]);var zs=h('<div class="section svelte-14sxgtb"><h3 class="section-label svelte-14sxgtb">Active</h3> <!></div>'),Is=h('<div class="section svelte-14sxgtb"><h3 class="section-label svelte-14sxgtb">Recent</h3> <!></div>'),Ps=h("<!> <!>",1);function js(e,t){Yt(t,!0);const n=H(()=>t.cards.filter(A=>A.status==="running")),a=H(()=>t.cards.filter(A=>A.status!=="running"));function s(A){t.onCardClick?.(A)}var o=Ps(),f=Mt(o);{var g=A=>{var b=zs(),O=v(l(b),2);dt(O,17,()=>r(n),P=>P.terminalId,(P,j)=>{ue(P,{get card(){return r(j)},onclick:()=>{s(r(j))}})}),c(b),p(A,b)};N(f,A=>{r(n).length>0&&A(g)})}var k=v(f,2);{var E=A=>{var b=Is(),O=v(l(b),2);dt(O,17,()=>r(a),P=>P.terminalId,(P,j)=>{ue(P,{get card(){return r(j)},onclick:()=>{s(r(j))}})}),c(b),p(A,b)};N(k,A=>{r(a).length>0&&A(E)})}p(e,o),Ft()}const Ls=new Set(["agent-question","terminal-exited","tool-failed"]);let jt=null,Lt=null,Rt=null;class Ms{async summarize(t){const n=this.chooseTone(t),a=n==="conversational"?this.buildConversationalPrompt(t):this.buildStatusReportPrompt(t);try{const s=await Ds();if(!s)return console.log("[SessionSummarizer] NeuroLink not available, using fallback."),{generatedAt:new Date().toISOString(),text:this.fallbackText(t),tone:n};const o=await s.generate({input:{text:a},...Rt?{model:Rt.model,provider:Rt.provider}:{}}),f=Bs(o.content??"").trim()||this.fallbackText(t);return{generatedAt:new Date().toISOString(),text:f,tone:n}}catch(s){return console.warn("[SessionSummarizer] summarize failed:",s instanceof Error?s.message:String(s)),{generatedAt:new Date().toISOString(),text:this.fallbackText(t),tone:n}}}buildConversationalPrompt(t){const n=t.goal??"unknown",a=t.recentEvents.map(s=>{const o=[s.type];return s.tool&&o.push(`tool=${s.tool}`),s.error&&o.push(`error=${s.error}`),s.command&&o.push(`command=${s.command}`),o.join(" ")}).join(", ");return`You are monitoring a coding session. Based on the context below, write ONE sentence (max 100 chars) describing what's happening in plain English. Be specific about what Claude did or is doing.
12
+
13
+ Goal: ${n}
14
+ Recent events: ${a}
15
+ Conversation excerpt: ${t.conversationExcerpt}
16
+ Status: ${t.status}
17
+
18
+ One sentence only, no quotes, no markdown.`}buildStatusReportPrompt(t){return`You are monitoring a coding session. Write a brief status update (max 60 chars) in the format "Doing X, Y done". Focus on the action.
19
+
20
+ Recent tool calls: ${t.recentEvents.flatMap(a=>a.tool?[a.tool]:[]).join(", ")||"none"}
21
+ Status: ${t.status}
22
+
23
+ Short phrase only, no quotes.`}chooseTone(t){return t.status==="error"||t.errorCount>0||t.recentEvents.some(a=>Ls.has(a.type))?"conversational":"status-report"}fallbackText(t){const n=t.recentEvents.flatMap(s=>s.tool?[s.tool]:[]),a=[...new Set(n)];return a.length>0?`Running: ${a.join(", ")} (${t.toolCallCount} tools)`:`Status: ${t.status} — ${t.toolCallCount} tool calls`}}async function Ds(){if(Lt)return Lt;We();const t=(await Rs()).NeuroLink;if(!t)return null;const n=window.__aiProviders,a=window.process?.env?.NEUROLINK_PROVIDER,s=Ye(n,a);if(!s)return console.warn("[SessionSummarizer] No AI provider configured"),null;const o=window.process;return o?.env&&n&&(n["google-ai"]&&!o.env.GOOGLE_AI_API_KEY&&(o.env.GOOGLE_AI_API_KEY="proxy-via-server"),n.anthropic&&!o.env.ANTHROPIC_API_KEY&&(o.env.ANTHROPIC_API_KEY="proxy-via-server"),n.openai&&!o.env.OPENAI_API_KEY&&(o.env.OPENAI_API_KEY="proxy-via-server"),n.mistral&&!o.env.MISTRAL_API_KEY&&(o.env.MISTRAL_API_KEY="proxy-via-server")),Lt=new t({provider:s.provider}),Rt=s,console.log(`[SessionSummarizer] Using provider: ${s.provider}/${s.model}`),Lt}function Rs(){return jt||(jt=import(qe).catch(e=>{throw console.warn("[SessionSummarizer] Failed to load NeuroLink SDK:",e),jt=null,e})),jt}function Bs(e){return typeof e=="string"?e:typeof e=="number"||typeof e=="boolean"?String(e):""}function te(){return new Date(Date.now()).toISOString()}const Ks=100,Ws=15e3,qs=3e4,Se=2e3,Ys=3e4;let tt=J(qt([])),Nt=J(!1),G=null,yt=null,_t=null,Bt=Se,Fs=0,Q="";const Ot=new Qt,ut=new Qt,Kt=new Ke;async function Gs(e){Q=e||Vs(),Q&&(await fe(Q),await be(Q),yt&&clearInterval(yt),yt=setInterval(()=>{fe(Q)},Ws))}function Js(){G&&(G.onclose=null,G.close(),G=null),yt&&(clearInterval(yt),yt=null),_t&&(clearTimeout(_t),_t=null);for(const[,e]of ut)e.onclose=null,e.close();ut.clear(),Kt.clear(),Ot.clear(),w(Nt,!1),Q=""}function $s(){const e=Date.now();return ee(r(tt)).map(t=>{const n=Date.parse(t.createdAt),a=t.events.length>0?Date.parse(t.events[t.events.length-1].timestamp):0;return{...t,duration:e-n,goal:t.goal,isActive:a>0&&e-a<qs,isSummarizing:t.isSummarizing,summary:t.summary}})}function de(e,t){const n=r(tt).find(a=>a.terminalId===e);n&&(n.goal=t)}function Us(e,t){const n=r(tt).find(a=>a.terminalId===e);n&&(n.summary=t,n.summaryUpdatedAt=te(),n.isSummarizing=!1)}function ht(e,t,n){const a={data:n,id:`evt-${++Fs}`,summarized:!1,terminalId:e.terminalId,timestamp:n.timestamp??te(),type:t},s=e.events.length>=Ks?[...e.events.slice(1),a]:[...e.events,a];e.events=s,e.eventCount+=1}function we(e){return e.split("/").filter(Boolean).pop()??e}function gt(e){const t=ut.get(e);t&&(t.onclose=null,t.close(),ut.delete(e))}async function be(e){if(!(G&&G.readyState<=1))try{const t=await fetch("/api/ws-ticket",{headers:{Authorization:`Bearer ${e}`},method:"POST"});if(!t.ok){Vt(e);return}const{ticket:n}=await t.json(),a=window.location.origin.replace(/^http/,"ws");G=new WebSocket(`${a}/ws/events?ticket=${n}`),G.onopen=()=>{w(Nt,!0),Bt=Se},G.onmessage=s=>{try{const o=JSON.parse(s.data);o&&typeof o=="object"&&Xs(o)}catch{}},G.onclose=()=>{w(Nt,!1),G=null,Vt(e)},G.onerror=()=>{w(Nt,!1)}}catch{w(Nt,!1),Vt(e)}}const Hs=["<local-command","<command-name>","<command-message>","<command-args>","<system-reminder>","<task-notification>","Caveat:"];function ve(e){let t="";typeof e=="string"?t=e:Array.isArray(e)&&(t=e.find(s=>s.type==="text")?.content??"");const n=t.slice(0,200).trim();return Zs(n)?"":n}async function fe(e){if(e)try{const t=await fetch("/api/terminals",{headers:{Authorization:`Bearer ${e}`}});if(!t.ok)return;const a=(await t.json()).terminals??[];w(tt,ee(tn(r(tt),a)),!0)}catch{}}function Vs(){try{const e=localStorage.getItem("shooter_config");if(!e)return"";const t=JSON.parse(e);if(t&&typeof t=="object"){const n=t;if(typeof n.apiKey=="string")return n.apiKey}}catch{}return""}function Xs(e){const t=e.type;if(!t||t==="welcome")return;const n=e.terminalId??null;if(!n)return;const a=r(tt).findIndex(f=>f.terminalId===n);if(a===-1)return;const s=r(tt)[a];switch(t){case"agent-idle":case"agent-question":{s.status="idle",ht(s,t,e);break}case"terminal-exited":{s.status="exited",s.exitedAt=e.exitedAt??te(),ht(s,t,e),gt(n),Ot.delete(n);break}case"tool-completed":{ht(s,t,e);break}case"tool-failed":{s.errorCount+=1,ht(s,t,e);break}case"tool-started":{s.toolCallCount+=1,s.status="running",ht(s,t,e);break}default:{ht(s,t,e);break}}(t==="tool-failed"||t==="agent-question"||s.errorCount>=3||s.eventCount>0&&s.eventCount%20===0)&&!s.isSummarizing&&en(s),w(tt,ee(r(tt)),!0)}function Zs(e){return Hs.some(t=>e.startsWith(t))}function Qs(e){return{command:e.command,createdAt:e.createdAt,cwd:e.cwd,errorCount:0,eventCount:0,events:[],exitedAt:e.exitedAt,goal:"",isSummarizing:!1,projectName:we(e.cwd),projectPath:e.cwd,status:Ae(e.status),summary:"",summaryUpdatedAt:"",terminalId:e.id,toolCallCount:0}}function Ae(e){return e==="running"?"running":e==="idle"?"idle":e==="exited"?"exited":"error"}function tn(e,t){const n=new Set(t.map(s=>s.id));for(const s of e)n.has(s.terminalId)||(gt(s.terminalId),Ot.delete(s.terminalId));const a=new Qt;for(const s of e)n.has(s.terminalId)&&a.set(s.terminalId,s);for(const s of t){const o=a.get(s.id);o?(o.command=s.command,o.cwd=s.cwd,o.projectName=we(s.cwd),o.projectPath=s.cwd,o.exitedAt=s.exitedAt,o.status!=="error"&&(o.status=Ae(s.status)),!o.goal&&s.exitedAt===null&&s.status!=="exited"&&me(s.id)):(a.set(s.id,Qs(s)),s.exitedAt===null&&s.status!=="exited"&&me(s.id))}return Array.from(a.values())}async function me(e){if(Q&&!(ut.has(e)||Kt.has(e))){Kt.add(e),console.log(`[DashboardStore] Opening session socket for ${e}`);try{const t=await fetch("/api/ws-ticket",{headers:{Authorization:`Bearer ${Q}`},method:"POST"});if(!t.ok){console.warn(`[DashboardStore] Failed to get WS ticket for ${e}:`,t.status);return}const{ticket:n}=await t.json(),s=`${window.location.origin.replace(/^http/,"ws")}/ws/session/${e}?ticket=${n}`;console.log(`[DashboardStore] Connecting session socket for ${e}`);const o=new WebSocket(s);ut.set(e,o),o.onopen=()=>{console.log(`[DashboardStore] Session socket opened for ${e}`)},o.onmessage=f=>{try{const g=JSON.parse(f.data);if(!g||typeof g!="object")return;const k=g;if(k.type==="session-end"){gt(e);return}const E=r(tt).find(b=>b.terminalId===e),A=E?.goal&&E.goal.length>0;if(k.type==="history"){console.log(`[DashboardStore] Received history for ${e}, extracting goal...`);const b=k.messages;if(!Array.isArray(b)){console.warn(`[DashboardStore] No messages array in history for ${e}`);return}console.log(`[DashboardStore] Found ${b.length} messages, looking for first user message...`);for(const O of b){if(O.role!=="user")continue;const P=ve(O.content);if(P){de(e,P),pe(e,P),gt(e);return}}return}if(k.type==="message"&&k.role==="user"&&!A){const b=ve(k.content);b&&(de(e,b),pe(e,b),gt(e));return}if(!A)return;gt(e)}catch(g){console.warn("[DashboardStore] Error processing session message:",g)}},o.onclose=()=>{console.log(`[DashboardStore] Session socket closed for ${e}`),ut.delete(e)},o.onerror=f=>{console.warn(`[DashboardStore] Session socket error for ${e}:`,f),ut.delete(e)}}catch(t){console.warn("[DashboardStore] Failed to open session socket:",t)}finally{Kt.delete(e)}}}function Vt(e){_t||(_t=setTimeout(()=>{_t=null,be(e)},Bt),Bt=Math.min(Bt*2,Ys))}function ee(e){return[...e].sort((t,n)=>{const a={error:2,exited:3,idle:1,running:0},s=a[t.status],o=a[n.status];if(s!==o)return s-o;if(t.status!=="exited"&&n.status!=="exited")return n.createdAt.localeCompare(t.createdAt);const f=t.exitedAt??t.createdAt;return(n.exitedAt??n.createdAt).localeCompare(f)})}function pe(e,t){Q&&fetch("/api/autopilot/goal",{body:JSON.stringify({goal:t,terminalId:e}),headers:{Authorization:`Bearer ${Q}`,"Content-Type":"application/json"},method:"POST"}).catch(()=>{})}function en(e){e.isSummarizing=!0;let t=Ot.get(e.terminalId);t||(t=new Ms,Ot.set(e.terminalId,t));const n=e.events.slice(-10).map(s=>({command:typeof s.data.command=="string"?s.data.command:null,error:typeof s.data.error=="string"?s.data.error:null,tool:typeof s.data.tool=="string"?s.data.tool:null,type:s.type})),a={conversationExcerpt:e.goal??"",errorCount:e.errorCount,goal:e.goal,recentEvents:n,status:e.status,toolCallCount:e.toolCallCount};(async()=>{try{const s=await t.summarize(a);Us(e.terminalId,s.text)}catch(s){console.error(`[dashboard] Summarization failed for ${e.terminalId}:`,s)}finally{e.isSummarizing=!1}})()}var sn=h('<meta name="description" content="Active terminals and Claude Code sessions"/>'),nn=h("<!> Refresh",1),an=h('<div class="stat-chip stat-chip-active svelte-1uha8ag"><span class="stat-value svelte-1uha8ag"> </span> <span class="stat-label svelte-1uha8ag">active</span></div>'),rn=h('<div class="stats-bar svelte-1uha8ag"><div class="stat-chip svelte-1uha8ag"><span class="stat-value svelte-1uha8ag"> </span> <span class="stat-label svelte-1uha8ag"> </span></div> <div class="stat-chip svelte-1uha8ag"><span class="stat-value svelte-1uha8ag"> </span> <span class="stat-label svelte-1uha8ag"> </span></div> <!></div>'),on=h('<div class="loading-container"></div>'),cn=h('<div class="dashboard-section svelte-1uha8ag"><!></div>'),ln=h('<div class="loading-container"></div>'),un=h('<h3 class="section-label svelte-1uha8ag">Sessions</h3>'),dn=h('<a class="session-card"><div class="session-card-header"><div><h3 class="session-card-title"> </h3> <div class="session-card-subtitle"> </div></div> <!></div> <div class="session-stats"><span><strong> </strong> </span></div></a>'),vn=h('<div style="text-align: center; padding: 1rem;"><!></div>'),fn=h('<!> <div class="projects-container svelte-1uha8ag"></div> <!>',1),mn=h("<!> <!> <!>",1),pn=h('<main class="main"><div class="page-header"><div class="page-header-content"><div><h1 class="page-title">Dashboard</h1> <p class="page-description">Active terminals and Claude Code sessions</p></div> <div class="page-actions"><!></div></div> <!></div> <!> <!></main>');function In(e,t){Yt(t,!0);const n=1e4,a=20;let s=J(qt([])),o=J(!1),f=!1,g=J(null),k=null,E=J(null),A=J(!1),b=J(0);const O=H($s);ge(()=>{P();const u=Re("shooter_projects");u&&(w(s,u,!0),w(o,!1)),j(),k=setInterval(()=>{r(g)?.apiKey&&r(b)<=a&&j()},n)}),Ee(()=>{k&&(clearInterval(k),k=null),Js()});function P(){try{const u=localStorage.getItem("shooter_config");if(u){const i=JSON.parse(u);Be(i)?(w(g,i,!0),Gs(r(g).apiKey)):(localStorage.removeItem("shooter_config"),w(g,null))}}catch{}}async function j(u=!1,i=!1){if(!r(g)?.apiKey||f)return;f=!0,r(s).length===0&&w(o,!0);const d=u?r(b):0;try{const x=await fetch(`${i?"/api/sessions?refresh=true&":"/api/sessions?"}limit=${a}&offset=${d}`,{headers:{Authorization:`Bearer ${r(g).apiKey}`}});if(!x.ok){w(E,`Failed to load projects (HTTP ${x.status})`);return}w(E,null);const z=await x.json();u?w(s,[...r(s),...z.projects],!0):w(s,z.projects,!0),w(b,r(s).length,!0),w(A,z.total!==void 0?r(s).length<z.total:!1,!0),De("shooter_projects",r(s))}catch(S){w(E,"Failed to load projects"),console.error("Failed to fetch sessions:",S)}finally{w(o,!1),f=!1}}async function vt(){await j(!0)}async function et(){w(o,!0),Me("shooter_projects"),await j(!1,!0)}function St(){ae("/config")}function wt(u){ae(`/terminals/${u}`)}function K(){return r(s).reduce((u,i)=>u+i.sessionCount,0)}var ft=pn();Ie("1uha8ag",u=>{var i=sn();Te(()=>{Ne.title="Dashboard - Shooter"}),p(u,i)});var V=l(ft),$=l(V),at=v(l($),2),bt=l(at);Jt(bt,{classes:"btn-secondary",onclick:et,get disabled(){return r(o)},children:(u,i)=>{var d=nn(),S=Mt(d);$t(S,{get svg(){return je},classes:"icon-14"}),se(),p(u,d)},$$slots:{default:!0}}),c(at),c($);var W=v($,2);{var At=u=>{var i=rn(),d=l(i),S=l(d),x=l(S,!0);c(S);var z=v(S,2),q=l(z,!0);c(z),c(d);var B=v(d,2),U=l(B),X=l(U,!0);c(U);var T=v(U,2),I=l(T,!0);c(T),c(B);var L=v(B,2);{var Z=Y=>{var st=an(),mt=l(st),M=l(mt,!0);c(mt),se(2),c(st),R(()=>_(M,r(O).length)),p(Y,st)};N(L,Y=>{r(O).length>0&&Y(Z)})}c(i),R((Y,st)=>{_(x,r(s).length),_(q,r(s).length===1?"project":"projects"),_(X,Y),_(I,st)},[()=>K(),()=>K()===1?"session":"sessions"]),p(u,i)};N(W,u=>{r(s).length>0&&u(At)})}c(V);var rt=v(V,2);{var kt=u=>{ze(u,{get text(){return r(E)},classes:"banner-error"})};N(rt,u=>{r(E)&&u(kt)})}var ot=v(rt,2);{var xt=u=>{var i=on();dt(i,20,()=>Array(3),ne,(d,S)=>{re(d,{classes:"shimmer-card"})}),c(i),p(u,i)},m=u=>{ie(u,{title:"Configuration Required",description:"Set up your API credentials to start tracking sessions",icon:d=>{$t(d,{get svg(){return Le},classes:"icon-24"})},children:(d,S)=>{Jt(d,{classes:"btn-primary",onclick:St,text:"Configure Settings"})}})},y=u=>{var i=mn(),d=Mt(i);ks(d,{});var S=v(d,2);{var x=T=>{var I=cn(),L=l(I);js(L,{get cards(){return r(O)},onCardClick:Z=>{wt(Z.terminalId)}}),c(I),p(T,I)};N(S,T=>{r(O).length>0&&T(x)})}var z=v(S,2);{var q=T=>{var I=ln();dt(I,20,()=>Array(3),ne,(L,Z)=>{re(L,{classes:"shimmer-card"})}),c(I),p(T,I)},B=T=>{ie(T,{title:"No sessions yet",description:"Claude Code sessions will appear here once JSONL files are found",icon:L=>{$t(L,{get svg(){return Pe},classes:"icon-24"})}})},U=H(()=>K()===0&&r(O).length===0),X=T=>{var I=fn(),L=Mt(I);{var Z=M=>{var C=un();p(M,C)};N(L,M=>{r(O).length>0&&M(Z)})}var Y=v(L,2);dt(Y,21,()=>r(s),M=>M.id,(M,C)=>{var D=dn(),it=l(D),pt=l(it),ct=l(pt),Ct=l(ct,!0);c(ct);var lt=v(ct,2),Gt=l(lt,!0);c(lt),c(pt);var zt=v(pt,2);{let Ce=H(()=>Xt(r(C).lastModified));ye(zt,{get text(){return`Last updated ${r(Ce)??""}`},classes:"pill-session-time"})}c(it);var It=v(it,2),Pt=l(It),Et=l(Pt),ke=l(Et,!0);c(Et);var xe=v(Et);c(Pt),c(It),c(D),R(()=>{nt(D,"href",`/project?id=${r(C).id??""}`),_(Ct,r(C).name),_(Gt,r(C).fullPath),_(ke,r(C).sessionCount),_(xe,` ${r(C).sessionCount===1?"session":"sessions"}`)}),p(M,D)}),c(Y);var st=v(Y,2);{var mt=M=>{var C=vn(),D=l(C);Jt(D,{classes:"btn-secondary",onclick:vt,text:"Load More"}),c(C),p(M,C)};N(st,M=>{r(A)&&M(mt)})}p(T,I)};N(z,T=>{r(o)&&r(s).length===0?T(q):r(U)?T(B,1):r(s).length>0&&T(X,2)})}p(u,i)};N(ot,u=>{r(o)&&r(s).length===0&&r(O).length===0?u(xt):r(g)?.apiKey?u(y,-1):u(m,1)})}c(ft),p(e,ft),Ft()}export{In as component};
@@ -1,4 +1,4 @@
1
- import{i as P,s as h,a as g,t as Be,f as A}from"../chunks/BPDiEZo0.js";import{s as b,q as ke,b as _,g as n,p as Ee,v as Pe,y as Ge,c as u,d as p,r as d,t as E,B as He,w as Ne,x as N,D as Ve,$ as We}from"../chunks/DWmC0QM7.js";import{h as Je}from"../chunks/2rBV5OkJ.js";import{g as ce}from"../chunks/C_YNQL8b.js";import{j as ue,e as le,B as qe,s as Ae,b as Xe}from"../chunks/ZS5XYDx_.js";import{g as je,i as Ze}from"../chunks/gQJcRhou.js";import"../chunks/BDcFu3l7.js";import{f as we}from"../chunks/BLszSzTT.js";import{S as Qe}from"../chunks/BcpydfqI.js";import{i as et,N as tt}from"../chunks/CRkG7oE4.js";import{d as ot}from"../chunks/pRcLbE0d.js";const rt=6e4,Se=3;let Q=null,Y=null,L=0,$e=0;async function st(e,t){if(e.length===0)return{error:null,text:""};let i;try{i=await it()}catch{const o=e.map(x=>w(x.data.tool)||x.type),l=Array.from(new Set(o));return{error:"AI SDK failed to load",text:`${e.length} events: ${l.join(", ")}`}}if(!i){const o=e.map(x=>w(x.data.tool)||x.type),l=Array.from(new Set(o));return{error:"No AI provider configured",text:`${e.length} events: ${l.join(", ")}`}}const s=at(e),a=`You are a coding activity summarizer. Given these events from active Claude Code sessions, write a 1-2 sentence summary (max 150 chars) of what's happening. Be specific — mention tool names, file names, and what's being accomplished.
1
+ import{i as P,s as h,a as g,t as Be,f as A}from"../chunks/BPDiEZo0.js";import{s as b,q as ke,b as _,g as n,p as Ee,v as Pe,y as Ge,c as u,d as p,r as d,t as E,B as He,w as Ne,x as N,D as Ve,$ as We}from"../chunks/DWmC0QM7.js";import{h as Je}from"../chunks/2rBV5OkJ.js";import{g as ce}from"../chunks/BfbPKMXz.js";import{j as ue,e as le,B as qe,s as Ae,b as Xe}from"../chunks/B1bOvemT.js";import{g as je,i as Ze}from"../chunks/gQJcRhou.js";import"../chunks/BDcFu3l7.js";import{f as we}from"../chunks/BLszSzTT.js";import{S as Qe}from"../chunks/BcpydfqI.js";import{i as et,N as tt}from"../chunks/C4Hns_Wl.js";import{d as ot}from"../chunks/C87ZRWX0.js";const rt=6e4,Se=3;let Q=null,Y=null,L=0,$e=0;async function st(e,t){if(e.length===0)return{error:null,text:""};let i;try{i=await it()}catch{const o=e.map(x=>w(x.data.tool)||x.type),l=Array.from(new Set(o));return{error:"AI SDK failed to load",text:`${e.length} events: ${l.join(", ")}`}}if(!i){const o=e.map(x=>w(x.data.tool)||x.type),l=Array.from(new Set(o));return{error:"No AI provider configured",text:`${e.length} events: ${l.join(", ")}`}}const s=at(e),a=`You are a coding activity summarizer. Given these events from active Claude Code sessions, write a 1-2 sentence summary (max 150 chars) of what's happening. Be specific — mention tool names, file names, and what's being accomplished.
2
2
 
3
3
  ${t?`Project: ${t}
4
4
  `:""}Events:
@@ -1,11 +1,11 @@
1
- import{a as d,f as u,i as K,s as O}from"../chunks/BPDiEZo0.js";import{c as v,g as e,r as c,t as U,p as ke,w as Ce,d as g,v as De,D as Oe,A as J,b as t,x,s as k,$ as Le,B as we}from"../chunks/DWmC0QM7.js";import{e as xe,l as je,s as W,i as $e,a as Je,B as F,I as ie,c as se,b as Me,d as Ee}from"../chunks/ZS5XYDx_.js";import{h as Fe}from"../chunks/2rBV5OkJ.js";import{A as Ge}from"../chunks/DzuS5Nbr.js";import{i as ze}from"../chunks/gQJcRhou.js";import"../chunks/BDcFu3l7.js";import{P as Ve}from"../chunks/pRcLbE0d.js";var He=u("<div><!></div>"),We=u("<div></div>");function Xe(h,o){var f=We();xe(f,21,()=>o.steps,$e,(s,w,l)=>{var S=He();let i;var I=v(S);je(I,{get onclick(){return o.onhandleStepClick},get label(){return e(w).label},get icon(){return e(w).icon},stepIndex:l+1}),c(S),U(()=>i=W(S,1,"step-container svelte-dvxh34",null,i,{"active-step":o.currentStepIndex===l,"completed-step":o.currentStepIndex>l})),d(s,S)}),c(f),U(()=>W(f,1,`container ${o.classes??""??""}`,"svelte-dvxh34")),d(h,f)}var Ye=u('<div class="card-description svelte-15b0v7e"> </div>'),Ze=u('<div class="card-header svelte-15b0v7e"><div class="card-title svelte-15b0v7e"> </div> <!></div>'),et=u('<div><!> <div class="card-content svelte-15b0v7e"><!></div></div>');function G(h,o){ke(o,!0);var f=et(),s=v(f);{var w=i=>{var I=Ze(),T=v(I),L=v(T,!0);c(T);var j=g(T,2);{var q=A=>{var M=Ye(),z=v(M,!0);c(M),U(()=>O(z,o.description)),d(A,M)};K(j,A=>{typeof o.description=="string"&&o.description.length>0&&A(q)})}c(I),U(()=>O(L,o.title)),d(i,I)};K(s,i=>{typeof o.title=="string"&&o.title.length>0&&i(w)})}var l=g(s,2),S=v(l);Je(S,()=>o.children),c(l),c(f),U(()=>W(f,1,`card ${o.classes??""??""}`,"svelte-15b0v7e")),d(h,f),Ce()}function H(h){return h instanceof Error?h.message:typeof h=="string"?h:String(h)}function tt(){return Pe()!==null}async function rt(){const h=Pe();if(!h)throw new Error("Scanner not available");return h()}function Pe(){if(typeof window>"u")return null;const h=window.ShooterBridge?.scanner;if(h&&typeof h.scan=="function")return()=>h.scan();const o=window.ShooterNativeBridge?.scanner;return o&&typeof o.scan=="function"?()=>o.scan():null}const Se=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
1
+ import{a as d,f as u,i as K,s as O}from"../chunks/BPDiEZo0.js";import{c as v,g as e,r as c,t as U,p as be,w as Ce,d as g,v as De,D as Oe,A as J,b as t,x,s as b,$ as Le,B as we}from"../chunks/DWmC0QM7.js";import{e as xe,k as je,s as W,i as $e,a as Je,B as F,I as ie,c as se,b as Me,d as Ee}from"../chunks/B1bOvemT.js";import{h as Fe}from"../chunks/2rBV5OkJ.js";import{A as Ge}from"../chunks/DzuS5Nbr.js";import{i as ze}from"../chunks/gQJcRhou.js";import"../chunks/BDcFu3l7.js";import{P as Ve}from"../chunks/C87ZRWX0.js";var He=u("<div><!></div>"),We=u("<div></div>");function Xe(h,o){var f=We();xe(f,21,()=>o.steps,$e,(s,w,l)=>{var S=He();let i;var I=v(S);je(I,{get onclick(){return o.onhandleStepClick},get label(){return e(w).label},get icon(){return e(w).icon},stepIndex:l+1}),c(S),U(()=>i=W(S,1,"step-container svelte-dvxh34",null,i,{"active-step":o.currentStepIndex===l,"completed-step":o.currentStepIndex>l})),d(s,S)}),c(f),U(()=>W(f,1,`container ${o.classes??""??""}`,"svelte-dvxh34")),d(h,f)}var Ye=u('<div class="card-description svelte-15b0v7e"> </div>'),Ze=u('<div class="card-header svelte-15b0v7e"><div class="card-title svelte-15b0v7e"> </div> <!></div>'),et=u('<div><!> <div class="card-content svelte-15b0v7e"><!></div></div>');function G(h,o){be(o,!0);var f=et(),s=v(f);{var w=i=>{var I=Ze(),T=v(I),L=v(T,!0);c(T);var j=g(T,2);{var q=A=>{var M=Ye(),z=v(M,!0);c(M),U(()=>O(z,o.description)),d(A,M)};K(j,A=>{typeof o.description=="string"&&o.description.length>0&&A(q)})}c(I),U(()=>O(L,o.title)),d(i,I)};K(s,i=>{typeof o.title=="string"&&o.title.length>0&&i(w)})}var l=g(s,2),S=v(l);Je(S,()=>o.children),c(l),c(f),U(()=>W(f,1,`card ${o.classes??""??""}`,"svelte-15b0v7e")),d(h,f),Ce()}function H(h){return h instanceof Error?h.message:typeof h=="string"?h:String(h)}function tt(){return Pe()!==null}async function rt(){const h=Pe();if(!h)throw new Error("Scanner not available");return h()}function Pe(){if(typeof window>"u")return null;const h=window.ShooterBridge?.scanner;if(h&&typeof h.scan=="function")return()=>h.scan();const o=window.ShooterNativeBridge?.scanner;return o&&typeof o.scan=="function"?()=>o.scan():null}const Se=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
2
2
  <path d="M22 11.08V12a10 10 0 1 1-5.93-9.14"/>
3
3
  <polyline points="22 4 12 14.01 9 11.01"/>
4
4
  </svg>
5
5
  `,nt=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
6
6
  <polygon points="5 3 19 12 5 21 5 3"/>
7
7
  </svg>
8
- `,be=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
8
+ `,ke=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
9
9
  <circle cx="12" cy="12" r="10"/>
10
10
  <line x1="15" y1="9" x2="9" y2="15"/>
11
11
  <line x1="9" y1="9" x2="15" y2="15"/>
@@ -13,4 +13,4 @@ import{a as d,f as u,i as K,s as O}from"../chunks/BPDiEZo0.js";import{c as v,g a
13
13
  `;var at=u('<meta name="description" content="Configure notification system settings"/>'),ot=u(`<!> <!> <p class="input-help svelte-1gp6n77">Find this in your <code class="svelte-1gp6n77">~/.shooter/.env</code> file. Run <code class="svelte-1gp6n77">shooter setup</code> to generate
14
14
  one.</p> <!> <p class="input-help svelte-1gp6n77">Optional — only needed for iOS/Android push notifications.</p>`,1),it=u("<!> Test Connection",1),st=u(`<p class="qr-description svelte-1gp6n77">Scan the QR code shown on your server's settings page to auto-configure the
15
15
  connection.</p> <!>`,1),ct=u('<p class="qr-server-url svelte-1gp6n77">Server: <code class="svelte-1gp6n77"> </code></p>'),lt=u('<div class="qr-container svelte-1gp6n77"><img alt="QR code for mobile app pairing" class="qr-image svelte-1gp6n77"/></div> <p class="qr-hint svelte-1gp6n77">Scan this QR code with the Shooter iOS or Android app to connect.</p> <!>',1),dt=u('<div class="qr-placeholder svelte-1gp6n77"><p class="qr-loading-text svelte-1gp6n77">Generating QR code...</p></div>'),vt=u('<p class="qr-error svelte-1gp6n77"> </p>'),ut=u(`<p class="qr-description svelte-1gp6n77">Generate a QR code containing your server URL and API key. Your mobile app can
16
- scan it to auto-configure the connection.</p>`),gt=u("<!> <!>",1),ft=u('<div class="qr-section svelte-1gp6n77"><!></div>'),pt=u('<div class="provider-row svelte-1gp6n77"><!> <span class="provider-label svelte-1gp6n77"> </span> <span> </span></div>'),ht=u('<div class="active-provider svelte-1gp6n77">Active: <strong> </strong></div>'),mt=u('<div class="active-provider svelte-1gp6n77">Auto-detected from configured keys</div>'),yt=u('<p class="ai-help svelte-1gp6n77">Run <code class="svelte-1gp6n77">shooter setup</code> to configure AI providers for summaries.</p>'),_t=u('<div class="ai-providers svelte-1gp6n77"><!> <!></div>'),wt=u('<p class="danger-description svelte-1gp6n77">Clear all saved configuration data from this device.</p> <!>',1),St=u('<main class="main"><div class="settings-container svelte-1gp6n77"><div style="margin-bottom: var(--space-4);"><a href="/" class="back-link">← Back to Projects</a></div> <div class="page-header"><h1 class="page-title">Settings</h1> <p class="page-description">Configure your API credentials and notification preferences</p></div> <div class="settings-grid svelte-1gp6n77"><section class="settings-section svelte-1gp6n77"><!> <!> <div class="button-group svelte-1gp6n77"><!> <!></div></section> <aside class="settings-sidebar svelte-1gp6n77"><!> <!> <!> <!></aside></div></div></main>');function Tt(h,o){ke(o,!0);let f=k(""),s=k(""),w=k(""),l=k(""),S=k(!1),i=k(""),I=k(!1),T=k(""),L=k(""),j=k(!1),q=k(""),A=k(!1),M=k(!1),z=!1,V=k(!1);async function Re(){if(!e(s).trim()){t(q,"Save an API key first to generate a QR code");return}t(j,!0),t(q,""),t(T,""),t(L,"");try{const r=await fetch("/api/qr-config",{headers:{Authorization:`Bearer ${e(s).trim()}`}});if(!r.ok){const a=await r.json();t(q,a.error||"Failed to generate QR code",!0);return}const n=await r.json();t(T,n.dataUrl,!0),t(L,n.serverUrl,!0)}catch(r){t(q,`Network error: ${H(r)}`)}finally{t(j,!1)}}async function Ue(){t(V,!0),t(l,""),t(i,"");try{const r=await rt();try{const n=JSON.parse(r);typeof n.serverUrl=="string"&&n.serverUrl&&t(f,n.serverUrl,!0),typeof n.apiKey=="string"&&n.apiKey&&t(s,n.apiKey,!0),await Z();const a=e(i);a!=="error"&&a!=="warning"&&(t(l,"Configuration updated from QR code"),t(i,"success"))}catch{t(l,"Invalid QR code data"),t(i,"error")}}catch(r){const n=H(r);n!=="cancelled"&&(t(l,`Scanner error: ${n}`),t(i,"error"))}finally{t(V,!1)}}function X(){return typeof window>"u"?null:window.ShooterBridge?window.ShooterBridge:window.ShooterNativeBridge?window.ShooterNativeBridge:null}function Y(){return window.location.origin}function ce(){const r=X();if(r&&!z){t(I,!0);try{const n=JSON.parse(r.getConfig?.()??"{}");n.serverUrl&&t(f,n.serverUrl,!0),n.apiKey&&t(s,n.apiKey,!0);const a=r.getFcmToken?.();a&&t(w,a,!0),z=!0}catch{}}t(A,tt(),!0)}De(()=>{{const r=window.location.hash.slice(1);if(r){const n=new URLSearchParams(r),a=n.get("key"),p=n.get("url");a&&(t(s,a,!0),p&&t(f,p,!0),Z(),window.history.replaceState({},"",window.location.pathname))}if(!e(s))try{const n=localStorage.getItem("shooter_config");if(n){const a=JSON.parse(n);ze(a)?(a.apiKey&&t(s,a.apiKey,!0),a.deviceToken&&t(w,a.deviceToken,!0),a.serverUrl&&t(f,a.serverUrl,!0)):localStorage.removeItem("shooter_config")}}catch{}if(ce(),e(f)||t(f,Y(),!0),t(M,!0),!e(A)){const n=setInterval(()=>{ce(),e(A)&&clearInterval(n)},200);setTimeout(()=>{clearInterval(n)},3e3)}}});async function Z(){t(S,!0),t(l,""),t(i,"");try{const r=e(f).trim().replace(/\/+$/,"");localStorage.setItem("shooter_config",JSON.stringify({apiKey:e(s).trim(),deviceToken:e(w).trim(),lastUpdated:Date.now(),serverUrl:r||Y()}));const n=X();n&&n.saveConfig?.(JSON.stringify({apiKey:e(s).trim(),serverUrl:r||Y()})),(await fetch("/api/health")).ok?(t(l,"Configuration saved successfully"),t(i,"success")):(t(l,"Configuration saved but system health check failed"),t(i,"warning"))}catch(r){t(l,`Configuration failed: ${H(r)}`),t(i,"error")}t(S,!1)}async function Ie(){if(!e(s).trim()){t(l,"API key is required for testing"),t(i,"error");return}t(S,!0),t(l,""),t(i,"");try{const r={data:{source:"config-test",timestamp:Date.now()},message:`Configuration test at ${new Date().toLocaleTimeString()}`,title:"Configuration Test"};e(w).trim()&&(r.deviceToken=e(w).trim());const n=await fetch("/api/notify",{body:JSON.stringify(r),headers:{Authorization:`Bearer ${e(s)}`,"Content-Type":"application/json"},method:"POST"}),a=await n.json();n.ok?(t(l,"Test notification sent successfully"),t(i,"success")):(t(l,`Test failed: ${typeof a.error=="string"?a.error:"Unknown error"}`),t(i,"error"))}catch(r){t(l,`Network error: ${H(r)}`),t(i,"error")}t(S,!1)}function Te(){{localStorage.removeItem("shooter_config"),t(f,typeof window<"u"?window.location.origin:"",!0),t(s,""),t(w,""),t(l,"Configuration cleared"),t(i,"success");const r=X();r&&r.saveConfig?.(JSON.stringify({apiKey:"",serverUrl:""}))}}var ee=St();Fe("1gp6n77",r=>{var n=at();Oe(()=>{Le.title="Settings - Shooter"}),d(r,n)});var le=v(ee),de=g(v(le),4),te=v(de),ve=v(te);G(ve,{title:"Server Configuration",description:"Configure server connection and credentials",children:(r,n)=>{var a=ot(),p=J(a);ie(p,{name:"serverUrl",label:"Server URL",dataType:"text",placeholder:"https://shooter.breezehq.dev",infoMessage:"Base URL of your Shooter server. Apps will reload with this URL on next launch.",get value(){return e(f)},set value(C){t(f,C,!0)}});var P=g(p,2);ie(P,{name:"apiKey",label:"API Key",dataType:"password",placeholder:"Enter your API key",infoMessage:"Required for sending notifications",get value(){return e(s)},set value(C){t(s,C,!0)}});var N=g(P,4);{let C=x(()=>e(I)?"Waiting for token...":"64-character hex string"),R=x(()=>e(I)&&e(w)?"Auto-detected from app":"Device token from app registration");ie(N,{name:"deviceToken",label:"Device Token",dataType:"text",get placeholder(){return e(C)},get infoMessage(){return e(R)},classes:"input-mono",get value(){return e(w)},set value(B){t(w,B,!0)}})}we(2),d(r,a)},$$slots:{default:!0}});var ue=g(ve,2);{var Ae=r=>{const n=x(()=>e(i)==="success"?Se:e(i)==="error"?be:Ge);{const a=P=>{se(P,{get svg(){return e(n)},classes:"icon-16"})};let p=x(()=>e(i)||"info");Me(r,{get text(){return e(l)},get classes(){return`banner-${e(p)??""}`},icon:a,$$slots:{icon:!0}})}};K(ue,r=>{e(l)&&r(Ae)})}var ge=g(ue,2),fe=v(ge);{let r=x(()=>e(S)||!e(s).trim());F(fe,{classes:"btn-secondary",onclick:Ie,get disabled(){return e(r)},children:(n,a)=>{var p=it(),P=J(p);{var N=C=>{se(C,{get svg(){return nt},classes:"icon-14"})};K(P,C=>{e(S)||C(N)})}we(),d(n,p)},$$slots:{default:!0}})}var Be=g(fe,2);{let r=x(()=>e(S)||!e(s).trim());F(Be,{classes:"btn-primary",onclick:Z,get disabled(){return e(r)},get showLoader(){return e(S)},text:"Save Changes"})}c(ge),c(te);var pe=g(te,2),he=v(pe);G(he,{title:"Setup Guide",children:(r,n)=>{{let a=x(()=>e(s).trim()&&e(w).trim()?2:e(s).trim()?1:0);Xe(r,{steps:[{label:"Get API Key"},{label:"Find Device Token"},{label:"Test Connection"}],get currentStepIndex(){return e(a)},classes:"setup-stepper"})}},$$slots:{default:!0}});var me=g(he,2);{let r=x(()=>e(A)?"Scan a QR code to connect":"Scan to connect your mobile app");G(me,{title:"Mobile App Setup",get description(){return e(r)},children:(n,a)=>{var p=ft(),P=v(p);{var N=R=>{var B=st(),m=g(J(B),2);{let _=x(()=>e(V)?"Scanning...":"Scan QR Code");F(m,{classes:"btn-secondary btn-sm",onclick:Ue,get disabled(){return e(V)},get text(){return e(_)}})}d(R,B)},C=R=>{var B=gt(),m=J(B);{var _=y=>{var b=lt(),D=J(b),ne=v(D);c(D);var Qe=g(D,4);{var Ke=ae=>{var oe=ct(),_e=g(v(oe)),Ne=v(_e,!0);c(_e),c(oe),U(()=>O(Ne,e(L))),d(ae,oe)};K(Qe,ae=>{e(L)&&ae(Ke)})}U(()=>Ee(ne,"src",e(T))),d(y,b)},Q=y=>{var b=dt();d(y,b)},$=y=>{var b=vt(),D=v(b,!0);c(b),U(()=>O(D,e(q))),d(y,b)},E=y=>{var b=ut();d(y,b)};K(m,y=>{e(T)?y(_):e(j)?y(Q,1):e(q)?y($,2):y(E,-1)})}var re=g(m,2);{let y=x(()=>e(j)||!e(s).trim()),b=x(()=>e(T)?"Regenerate QR Code":"Generate QR Code");F(re,{classes:"btn-secondary btn-sm",onclick:Re,get disabled(){return e(y)},get text(){return e(b)}})}d(R,B)};K(P,R=>{e(A)?R(N):R(C,-1)})}c(p),d(n,p)},$$slots:{default:!0}})}var ye=g(me,2);G(ye,{title:"AI Providers",description:"NeuroLink-powered summaries and AI features",children:(r,n)=>{var a=_t(),p=v(a);xe(p,17,()=>Ve,m=>m.id,(m,_)=>{var Q=pt(),$=v(Q);{let ne=x(()=>o.data.aiProviders[e(_).id]?Se:be);se($,{get svg(){return e(ne)},classes:"icon-14"})}var E=g($,2),re=v(E,!0);c(E);var y=g(E,2);let b;var D=v(y,!0);c(y),c(Q),U(()=>{O(re,e(_).label),b=W(y,1,"provider-status svelte-1gp6n77",null,b,{configured:o.data.aiProviders[e(_).id]}),O(D,o.data.aiProviders[e(_).id]?"configured":"not configured")}),d(m,Q)});var P=g(p,2);{var N=m=>{var _=ht(),Q=g(v(_)),$=v(Q,!0);c(Q),c(_),U(()=>O($,o.data.activeProvider)),d(m,_)},C=m=>{var _=mt();d(m,_)},R=x(()=>Object.values(o.data.aiProviders).some(Boolean)),B=m=>{var _=yt();d(m,_)};K(P,m=>{o.data.activeProvider?m(N):e(R)?m(C,1):m(B,-1)})}c(a),d(r,a)},$$slots:{default:!0}});var qe=g(ye,2);G(qe,{title:"Danger Zone",children:(r,n)=>{var a=wt(),p=g(J(a),2);F(p,{classes:"btn-danger btn-sm",onclick:Te,text:"Clear Configuration"}),d(r,a)},$$slots:{default:!0}}),c(pe),c(de),c(le),c(ee),d(h,ee),Ce()}export{Tt as component};
16
+ scan it to auto-configure the connection.</p>`),gt=u("<!> <!>",1),ft=u('<div class="qr-section svelte-1gp6n77"><!></div>'),pt=u('<div class="provider-row svelte-1gp6n77"><!> <span class="provider-label svelte-1gp6n77"> </span> <span> </span></div>'),ht=u('<div class="active-provider svelte-1gp6n77">Active: <strong> </strong></div>'),mt=u('<div class="active-provider svelte-1gp6n77">Auto-detected from configured keys</div>'),yt=u('<p class="ai-help svelte-1gp6n77">Run <code class="svelte-1gp6n77">shooter setup</code> to configure AI providers for summaries.</p>'),_t=u('<div class="ai-providers svelte-1gp6n77"><!> <!></div>'),wt=u('<p class="danger-description svelte-1gp6n77">Clear all saved configuration data from this device.</p> <!>',1),St=u('<main class="main"><div class="settings-container svelte-1gp6n77"><div style="margin-bottom: var(--space-4);"><a href="/" class="back-link">← Back to Projects</a></div> <div class="page-header"><h1 class="page-title">Settings</h1> <p class="page-description">Configure your API credentials and notification preferences</p></div> <div class="settings-grid svelte-1gp6n77"><section class="settings-section svelte-1gp6n77"><!> <!> <div class="button-group svelte-1gp6n77"><!> <!></div></section> <aside class="settings-sidebar svelte-1gp6n77"><!> <!> <!> <!></aside></div></div></main>');function Tt(h,o){be(o,!0);let f=b(""),s=b(""),w=b(""),l=b(""),S=b(!1),i=b(""),I=b(!1),T=b(""),L=b(""),j=b(!1),q=b(""),A=b(!1),M=b(!1),z=!1,V=b(!1);async function Re(){if(!e(s).trim()){t(q,"Save an API key first to generate a QR code");return}t(j,!0),t(q,""),t(T,""),t(L,"");try{const r=await fetch("/api/qr-config",{headers:{Authorization:`Bearer ${e(s).trim()}`}});if(!r.ok){const a=await r.json();t(q,a.error||"Failed to generate QR code",!0);return}const n=await r.json();t(T,n.dataUrl,!0),t(L,n.serverUrl,!0)}catch(r){t(q,`Network error: ${H(r)}`)}finally{t(j,!1)}}async function Ue(){t(V,!0),t(l,""),t(i,"");try{const r=await rt();try{const n=JSON.parse(r);typeof n.serverUrl=="string"&&n.serverUrl&&t(f,n.serverUrl,!0),typeof n.apiKey=="string"&&n.apiKey&&t(s,n.apiKey,!0),await Z();const a=e(i);a!=="error"&&a!=="warning"&&(t(l,"Configuration updated from QR code"),t(i,"success"))}catch{t(l,"Invalid QR code data"),t(i,"error")}}catch(r){const n=H(r);n!=="cancelled"&&(t(l,`Scanner error: ${n}`),t(i,"error"))}finally{t(V,!1)}}function X(){return typeof window>"u"?null:window.ShooterBridge?window.ShooterBridge:window.ShooterNativeBridge?window.ShooterNativeBridge:null}function Y(){return window.location.origin}function ce(){const r=X();if(r&&!z){t(I,!0);try{const n=JSON.parse(r.getConfig?.()??"{}");n.serverUrl&&t(f,n.serverUrl,!0),n.apiKey&&t(s,n.apiKey,!0);const a=r.getFcmToken?.();a&&t(w,a,!0),z=!0}catch{}}t(A,tt(),!0)}De(()=>{{const r=window.location.hash.slice(1);if(r){const n=new URLSearchParams(r),a=n.get("key"),p=n.get("url");a&&(t(s,a,!0),p&&t(f,p,!0),Z(),window.history.replaceState({},"",window.location.pathname))}if(!e(s))try{const n=localStorage.getItem("shooter_config");if(n){const a=JSON.parse(n);ze(a)?(a.apiKey&&t(s,a.apiKey,!0),a.deviceToken&&t(w,a.deviceToken,!0),a.serverUrl&&t(f,a.serverUrl,!0)):localStorage.removeItem("shooter_config")}}catch{}if(ce(),e(f)||t(f,Y(),!0),t(M,!0),!e(A)){const n=setInterval(()=>{ce(),e(A)&&clearInterval(n)},200);setTimeout(()=>{clearInterval(n)},3e3)}}});async function Z(){t(S,!0),t(l,""),t(i,"");try{const r=e(f).trim().replace(/\/+$/,"");localStorage.setItem("shooter_config",JSON.stringify({apiKey:e(s).trim(),deviceToken:e(w).trim(),lastUpdated:Date.now(),serverUrl:r||Y()}));const n=X();n&&n.saveConfig?.(JSON.stringify({apiKey:e(s).trim(),serverUrl:r||Y()})),(await fetch("/api/health")).ok?(t(l,"Configuration saved successfully"),t(i,"success")):(t(l,"Configuration saved but system health check failed"),t(i,"warning"))}catch(r){t(l,`Configuration failed: ${H(r)}`),t(i,"error")}t(S,!1)}async function Ie(){if(!e(s).trim()){t(l,"API key is required for testing"),t(i,"error");return}t(S,!0),t(l,""),t(i,"");try{const r={data:{source:"config-test",timestamp:Date.now()},message:`Configuration test at ${new Date().toLocaleTimeString()}`,title:"Configuration Test"};e(w).trim()&&(r.deviceToken=e(w).trim());const n=await fetch("/api/notify",{body:JSON.stringify(r),headers:{Authorization:`Bearer ${e(s)}`,"Content-Type":"application/json"},method:"POST"}),a=await n.json();n.ok?(t(l,"Test notification sent successfully"),t(i,"success")):(t(l,`Test failed: ${typeof a.error=="string"?a.error:"Unknown error"}`),t(i,"error"))}catch(r){t(l,`Network error: ${H(r)}`),t(i,"error")}t(S,!1)}function Te(){{localStorage.removeItem("shooter_config"),t(f,typeof window<"u"?window.location.origin:"",!0),t(s,""),t(w,""),t(l,"Configuration cleared"),t(i,"success");const r=X();r&&r.saveConfig?.(JSON.stringify({apiKey:"",serverUrl:""}))}}var ee=St();Fe("1gp6n77",r=>{var n=at();Oe(()=>{Le.title="Settings - Shooter"}),d(r,n)});var le=v(ee),de=g(v(le),4),te=v(de),ve=v(te);G(ve,{title:"Server Configuration",description:"Configure server connection and credentials",children:(r,n)=>{var a=ot(),p=J(a);ie(p,{name:"serverUrl",label:"Server URL",dataType:"text",placeholder:"https://shooter.breezehq.dev",infoMessage:"Base URL of your Shooter server. Apps will reload with this URL on next launch.",get value(){return e(f)},set value(C){t(f,C,!0)}});var P=g(p,2);ie(P,{name:"apiKey",label:"API Key",dataType:"password",placeholder:"Enter your API key",infoMessage:"Required for sending notifications",get value(){return e(s)},set value(C){t(s,C,!0)}});var N=g(P,4);{let C=x(()=>e(I)?"Waiting for token...":"64-character hex string"),R=x(()=>e(I)&&e(w)?"Auto-detected from app":"Device token from app registration");ie(N,{name:"deviceToken",label:"Device Token",dataType:"text",get placeholder(){return e(C)},get infoMessage(){return e(R)},classes:"input-mono",get value(){return e(w)},set value(B){t(w,B,!0)}})}we(2),d(r,a)},$$slots:{default:!0}});var ue=g(ve,2);{var Ae=r=>{const n=x(()=>e(i)==="success"?Se:e(i)==="error"?ke:Ge);{const a=P=>{se(P,{get svg(){return e(n)},classes:"icon-16"})};let p=x(()=>e(i)||"info");Me(r,{get text(){return e(l)},get classes(){return`banner-${e(p)??""}`},icon:a,$$slots:{icon:!0}})}};K(ue,r=>{e(l)&&r(Ae)})}var ge=g(ue,2),fe=v(ge);{let r=x(()=>e(S)||!e(s).trim());F(fe,{classes:"btn-secondary",onclick:Ie,get disabled(){return e(r)},children:(n,a)=>{var p=it(),P=J(p);{var N=C=>{se(C,{get svg(){return nt},classes:"icon-14"})};K(P,C=>{e(S)||C(N)})}we(),d(n,p)},$$slots:{default:!0}})}var Be=g(fe,2);{let r=x(()=>e(S)||!e(s).trim());F(Be,{classes:"btn-primary",onclick:Z,get disabled(){return e(r)},get showLoader(){return e(S)},text:"Save Changes"})}c(ge),c(te);var pe=g(te,2),he=v(pe);G(he,{title:"Setup Guide",children:(r,n)=>{{let a=x(()=>e(s).trim()&&e(w).trim()?2:e(s).trim()?1:0);Xe(r,{steps:[{label:"Get API Key"},{label:"Find Device Token"},{label:"Test Connection"}],get currentStepIndex(){return e(a)},classes:"setup-stepper"})}},$$slots:{default:!0}});var me=g(he,2);{let r=x(()=>e(A)?"Scan a QR code to connect":"Scan to connect your mobile app");G(me,{title:"Mobile App Setup",get description(){return e(r)},children:(n,a)=>{var p=ft(),P=v(p);{var N=R=>{var B=st(),m=g(J(B),2);{let _=x(()=>e(V)?"Scanning...":"Scan QR Code");F(m,{classes:"btn-secondary btn-sm",onclick:Ue,get disabled(){return e(V)},get text(){return e(_)}})}d(R,B)},C=R=>{var B=gt(),m=J(B);{var _=y=>{var k=lt(),D=J(k),ne=v(D);c(D);var Qe=g(D,4);{var Ke=ae=>{var oe=ct(),_e=g(v(oe)),Ne=v(_e,!0);c(_e),c(oe),U(()=>O(Ne,e(L))),d(ae,oe)};K(Qe,ae=>{e(L)&&ae(Ke)})}U(()=>Ee(ne,"src",e(T))),d(y,k)},Q=y=>{var k=dt();d(y,k)},$=y=>{var k=vt(),D=v(k,!0);c(k),U(()=>O(D,e(q))),d(y,k)},E=y=>{var k=ut();d(y,k)};K(m,y=>{e(T)?y(_):e(j)?y(Q,1):e(q)?y($,2):y(E,-1)})}var re=g(m,2);{let y=x(()=>e(j)||!e(s).trim()),k=x(()=>e(T)?"Regenerate QR Code":"Generate QR Code");F(re,{classes:"btn-secondary btn-sm",onclick:Re,get disabled(){return e(y)},get text(){return e(k)}})}d(R,B)};K(P,R=>{e(A)?R(N):R(C,-1)})}c(p),d(n,p)},$$slots:{default:!0}})}var ye=g(me,2);G(ye,{title:"AI Providers",description:"NeuroLink-powered summaries and AI features",children:(r,n)=>{var a=_t(),p=v(a);xe(p,17,()=>Ve,m=>m.id,(m,_)=>{var Q=pt(),$=v(Q);{let ne=x(()=>o.data.aiProviders[e(_).id]?Se:ke);se($,{get svg(){return e(ne)},classes:"icon-14"})}var E=g($,2),re=v(E,!0);c(E);var y=g(E,2);let k;var D=v(y,!0);c(y),c(Q),U(()=>{O(re,e(_).label),k=W(y,1,"provider-status svelte-1gp6n77",null,k,{configured:o.data.aiProviders[e(_).id]}),O(D,o.data.aiProviders[e(_).id]?"configured":"not configured")}),d(m,Q)});var P=g(p,2);{var N=m=>{var _=ht(),Q=g(v(_)),$=v(Q,!0);c(Q),c(_),U(()=>O($,o.data.activeProvider)),d(m,_)},C=m=>{var _=mt();d(m,_)},R=x(()=>Object.values(o.data.aiProviders).some(Boolean)),B=m=>{var _=yt();d(m,_)};K(P,m=>{o.data.activeProvider?m(N):e(R)?m(C,1):m(B,-1)})}c(a),d(r,a)},$$slots:{default:!0}});var qe=g(ye,2);G(qe,{title:"Danger Zone",children:(r,n)=>{var a=wt(),p=g(J(a),2);F(p,{classes:"btn-danger btn-sm",onclick:Te,text:"Clear Configuration"}),d(r,a)},$$slots:{default:!0}}),c(pe),c(de),c(le),c(ee),d(h,ee),Ce()}export{Tt as component};
@@ -1 +1 @@
1
- import{d as q,i as T,b as H,a as k,f as N,s as V}from"../chunks/BPDiEZo0.js";import{p as z,s as n,q as J,v as Q,w as W,g as t,b as r,x as _,d as g,c as b,r as c,t as X}from"../chunks/DWmC0QM7.js";import{e as K,I as Z,B as ee,s as te,i as ae,P as I}from"../chunks/ZS5XYDx_.js";import{i as se,N as S}from"../chunks/CRkG7oE4.js";import{P as O}from"../chunks/pRcLbE0d.js";var re=N('<div class="provider-bar svelte-sjabew"></div>'),ie=N("<div> </div>"),oe=N('<div class="page svelte-sjabew"><header class="svelte-sjabew"><h1 class="svelte-sjabew">NeuroLink</h1> <span class="version svelte-sjabew">new NeuroLink()</span> <!></header> <!> <div class="log svelte-sjabew" id="log"></div> <div class="input-bar svelte-sjabew"><!> <!></div></div>');function pe(M,p){z(p,!0);let u=n(null),m=n(null),h=n(J([])),d=n(""),v=n(!1),f=n(!1),o=n("litellm");function i(e,a="info"){r(h,[...t(h),{text:e,type:a}],!0)}function R(){const e=globalThis.process;if(!e?.env)return;const a=e.env;p.data.litellmBaseUrl&&(a.LITELLM_BASE_URL=p.data.litellmBaseUrl),p.data.litellmModel&&(a.LITELLM_MODEL=p.data.litellmModel);const s=window.__aiProviders;s?.["google-ai"]&&(a.GOOGLE_AI_API_KEY="proxy-via-server"),s?.anthropic&&(a.ANTHROPIC_API_KEY="proxy-via-server"),s?.openai&&(a.OPENAI_API_KEY="proxy-via-server"),s?.mistral&&(a.MISTRAL_API_KEY="proxy-via-server")}Q(async()=>{$(),se(),R(),i("Loading NeuroLink from CDN..."),i(S,"dim");try{r(u,await import(S),!0),i(`Loaded! ${Object.keys(t(u)??{}).length} exports`,"pass"),r(m,new(t(u)).NeuroLink({provider:t(o)}),!0),i(`NeuroLink ready · provider: ${t(o)}`,"pass"),r(f,!0)}catch(e){i(`Failed to load: ${e instanceof Error?e.message:String(e)}`,"fail")}});function D(e){!t(u)||e===t(o)||(r(o,e,!0),r(m,new(t(u)).NeuroLink({provider:e}),!0),i(`Switched to provider: ${e}`,"dim"))}function $(){typeof globalThis.process>"u"&&(globalThis.process={cwd:()=>"/",env:{},platform:"browser",version:"v24.0.0"}),typeof globalThis.global>"u"&&(globalThis.global=globalThis)}async function P(){if(!t(d).trim()||!t(m)||t(v))return;const e=t(d).trim();r(d,""),r(v,!0),i(`> ${e}`,"user");const a=O.find(s=>s.id===t(o));if(!a){r(v,!1);return}try{const s=await t(m).generate({input:{text:e},model:a.model,provider:a.id}),l=typeof s.content=="string"?s.content:"(empty response)",E=s.usage;i(l,"ai"),i(`${a.id}/${a.model} | ${E?.total??"?"} tokens`,"dim")}catch(s){i(`Error: ${s instanceof Error?s.message:String(s)}`,"fail")}r(v,!1)}function B(e){e.key==="Enter"&&!e.shiftKey&&(e.preventDefault(),P())}var y=oe(),w=b(y),U=g(b(w),4);{var C=e=>{I(e,{text:"Connected",classes:"pill-connected"})},Y=e=>{I(e,{text:"Loading...",classes:"pill-loading"})};T(U,e=>{t(f)?e(C):e(Y,-1)})}c(w);var j=g(w,2);{var F=e=>{var a=re();K(a,21,()=>O,s=>s.id,(s,l)=>{{let E=_(()=>t(o)===t(l).id?"prov-pill--active":"");I(s,{get text(){return t(l).label},get classes(){return`prov-pill ${t(E)??""}`},onclick:()=>{D(t(l).id)}})}}),c(a),k(e,a)};T(j,e=>{t(f)&&e(F)})}var L=g(j,2);K(L,21,()=>t(h),ae,(e,a)=>{var s=ie(),l=b(s,!0);c(s),X(()=>{te(s,1,`log-entry ${t(a).type??""}`,"svelte-sjabew"),V(l,t(a).text)}),k(e,s)}),c(L);var x=g(L,2),A=b(x);{let e=_(()=>t(f)?`Ask anything... [${t(o)}]`:"Loading SDK...");Z(A,{name:"prompt",get placeholder(){return t(e)},classes:"input-prompt",get value(){return t(d)},set value(a){r(d,a,!0)}})}var G=g(A,2);{let e=_(()=>!t(f)||t(v)||!t(d).trim()),a=_(()=>t(v)?"...":"Send");ee(G,{classes:"btn-primary",onclick:P,get disabled(){return t(e)},get text(){return t(a)}})}c(x),c(y),H("keydown",x,B),k(M,y),W()}q(["keydown"]);export{pe as component};
1
+ import{d as q,i as T,b as H,a as k,f as N,s as V}from"../chunks/BPDiEZo0.js";import{p as z,s as n,q as J,v as Q,w as W,g as t,b as r,x as _,d as g,c as b,r as c,t as X}from"../chunks/DWmC0QM7.js";import{e as K,I as Z,B as ee,s as te,i as ae,P as I}from"../chunks/B1bOvemT.js";import{i as se,N as S}from"../chunks/C4Hns_Wl.js";import{P as O}from"../chunks/C87ZRWX0.js";var re=N('<div class="provider-bar svelte-sjabew"></div>'),ie=N("<div> </div>"),oe=N('<div class="page svelte-sjabew"><header class="svelte-sjabew"><h1 class="svelte-sjabew">NeuroLink</h1> <span class="version svelte-sjabew">new NeuroLink()</span> <!></header> <!> <div class="log svelte-sjabew" id="log"></div> <div class="input-bar svelte-sjabew"><!> <!></div></div>');function pe(M,p){z(p,!0);let u=n(null),m=n(null),h=n(J([])),d=n(""),v=n(!1),f=n(!1),o=n("litellm");function i(e,a="info"){r(h,[...t(h),{text:e,type:a}],!0)}function R(){const e=globalThis.process;if(!e?.env)return;const a=e.env;p.data.litellmBaseUrl&&(a.LITELLM_BASE_URL=p.data.litellmBaseUrl),p.data.litellmModel&&(a.LITELLM_MODEL=p.data.litellmModel);const s=window.__aiProviders;s?.["google-ai"]&&(a.GOOGLE_AI_API_KEY="proxy-via-server"),s?.anthropic&&(a.ANTHROPIC_API_KEY="proxy-via-server"),s?.openai&&(a.OPENAI_API_KEY="proxy-via-server"),s?.mistral&&(a.MISTRAL_API_KEY="proxy-via-server")}Q(async()=>{$(),se(),R(),i("Loading NeuroLink from CDN..."),i(S,"dim");try{r(u,await import(S),!0),i(`Loaded! ${Object.keys(t(u)??{}).length} exports`,"pass"),r(m,new(t(u)).NeuroLink({provider:t(o)}),!0),i(`NeuroLink ready · provider: ${t(o)}`,"pass"),r(f,!0)}catch(e){i(`Failed to load: ${e instanceof Error?e.message:String(e)}`,"fail")}});function D(e){!t(u)||e===t(o)||(r(o,e,!0),r(m,new(t(u)).NeuroLink({provider:e}),!0),i(`Switched to provider: ${e}`,"dim"))}function $(){typeof globalThis.process>"u"&&(globalThis.process={cwd:()=>"/",env:{},platform:"browser",version:"v24.0.0"}),typeof globalThis.global>"u"&&(globalThis.global=globalThis)}async function P(){if(!t(d).trim()||!t(m)||t(v))return;const e=t(d).trim();r(d,""),r(v,!0),i(`> ${e}`,"user");const a=O.find(s=>s.id===t(o));if(!a){r(v,!1);return}try{const s=await t(m).generate({input:{text:e},model:a.model,provider:a.id}),l=typeof s.content=="string"?s.content:"(empty response)",E=s.usage;i(l,"ai"),i(`${a.id}/${a.model} | ${E?.total??"?"} tokens`,"dim")}catch(s){i(`Error: ${s instanceof Error?s.message:String(s)}`,"fail")}r(v,!1)}function B(e){e.key==="Enter"&&!e.shiftKey&&(e.preventDefault(),P())}var y=oe(),w=b(y),U=g(b(w),4);{var C=e=>{I(e,{text:"Connected",classes:"pill-connected"})},Y=e=>{I(e,{text:"Loading...",classes:"pill-loading"})};T(U,e=>{t(f)?e(C):e(Y,-1)})}c(w);var j=g(w,2);{var F=e=>{var a=re();K(a,21,()=>O,s=>s.id,(s,l)=>{{let E=_(()=>t(o)===t(l).id?"prov-pill--active":"");I(s,{get text(){return t(l).label},get classes(){return`prov-pill ${t(E)??""}`},onclick:()=>{D(t(l).id)}})}}),c(a),k(e,a)};T(j,e=>{t(f)&&e(F)})}var L=g(j,2);K(L,21,()=>t(h),ae,(e,a)=>{var s=ie(),l=b(s,!0);c(s),X(()=>{te(s,1,`log-entry ${t(a).type??""}`,"svelte-sjabew"),V(l,t(a).text)}),k(e,s)}),c(L);var x=g(L,2),A=b(x);{let e=_(()=>t(f)?`Ask anything... [${t(o)}]`:"Loading SDK...");Z(A,{name:"prompt",get placeholder(){return t(e)},classes:"input-prompt",get value(){return t(d)},set value(a){r(d,a,!0)}})}var G=g(A,2);{let e=_(()=>!t(f)||t(v)||!t(d).trim()),a=_(()=>t(v)?"...":"Send");ee(G,{classes:"btn-primary",onclick:P,get disabled(){return t(e)},get text(){return t(a)}})}c(x),c(y),H("keydown",x,B),k(M,y),W()}q(["keydown"]);export{pe as component};
@@ -1 +1 @@
1
- import{i as w,a as p,f as m,s as $}from"../chunks/BPDiEZo0.js";import{p as Qe,s as k,q as We,v as Xe,y as Ye,w as et,z as tt,g as e,b as c,$ as rt,c as o,d as l,r as a,x as u,A as K,B as Z,t as Q}from"../chunks/DWmC0QM7.js";import{b as st,e as ve,i as at,B as N,c as W,P as X,d as ot}from"../chunks/ZS5XYDx_.js";import{h as nt}from"../chunks/2rBV5OkJ.js";import{g as it}from"../chunks/C_YNQL8b.js";import{p as ct}from"../chunks/DIZ3Qst5.js";import{A as lt}from"../chunks/DzuS5Nbr.js";import{B as dt}from"../chunks/Bn-6X1BO.js";import{S as ue,R as vt}from"../chunks/BvmdJful.js";import{g as ut,s as ft,c as pt}from"../chunks/xs1Xl3_e.js";import{i as mt}from"../chunks/gQJcRhou.js";import"../chunks/BDcFu3l7.js";import{s as fe,a as ht}from"../chunks/BdtLzPpO.js";import{f as _t}from"../chunks/BLszSzTT.js";import{E as pe}from"../chunks/ClIPTXf3.js";var gt=m('<meta name="description" content="Project sessions sorted by latest update"/>'),yt=m('<div class="loading-container"><!> <!></div>'),bt=m('<div class="project-back-row svelte-urn6fi"><a href="/" class="back-link"><span class="back-arrow">&larr;</span> Back to Projects</a></div> <!>',1),$t=m("<!> Refresh",1),jt=m('<div class="session-card-subtitle"> </div>'),St=m('<span class="connect-dot svelte-urn6fi"></span> Connect',1),Pt=m('<a class="session-card"><div class="session-card-header"><div><h3 class="session-card-title"> </h3> <!></div> <div class="session-card-actions svelte-urn6fi"><!> <!></div></div> <div class="session-stats"><span><strong> </strong> messages</span> <!> <!></div> <div class="session-meta-row svelte-urn6fi"><span class="session-modified svelte-urn6fi"> </span> <span class="session-duration svelte-urn6fi"> </span></div></a>'),xt=m('<div style="text-align: center; padding: 1rem;"><!></div>'),wt=m('<div class="sessions-container svelte-urn6fi"></div> <!>',1),kt=m('<div class="chat-session-header"><div class="chat-session-header-top svelte-urn6fi"><a href="/" class="back-link">&#8592; Back to Projects</a> <!></div> <h1 class="chat-session-title"> </h1> <div class="chat-session-meta"><span class="session-card-subtitle"> </span> <span> </span></div></div> <!>',1),Bt=m('<main class="main"><!> <!></main>');function Gt(me,he){Qe(he,!0);const _e=15e3,D=20;let i=k(null),g=k(!0),h=k(null),L=k(null),R=null,B=k(D),Y=k(We([])),j=k(null);const S=u(()=>ct.url.searchParams.get("id")||""),ge=u(()=>e(i)?e(i).sessions.slice(0,e(B)):[]),ye=u(()=>e(i)?e(B)<e(i).sessions.length:!1),be=u(()=>new Set(e(Y).map(t=>t.sessionId).filter(t=>typeof t=="string")));Xe(()=>{$e();const t=ut(`shooter_project_${e(S)}`);t&&(c(i,t,!0),c(g,!1)),setTimeout(()=>{M(),z()},50),R=setInterval(()=>{e(h)?.apiKey&&e(S)&&(M(),z())},_e)}),Ye(()=>{R&&(clearInterval(R),R=null)});function $e(){try{const t=localStorage.getItem("shooter_config");if(t){const r=JSON.parse(t);mt(r)?c(h,r,!0):(localStorage.removeItem("shooter_config"),c(h,null))}}catch{}}async function M(t=!1){if(!e(h)?.apiKey||!e(S)){c(g,!1);return}e(i)||c(g,!0);try{const d=await fetch(t?"/api/sessions?refresh=true":"/api/sessions",{headers:{Authorization:`Bearer ${e(h).apiKey}`}});if(!d.ok){c(L,`Failed to load project (HTTP ${d.status})`),c(g,!1);return}c(L,null);const f=(await d.json()).projects.find(T=>T.id===e(S))||null;c(i,f,!0),f&&ft(`shooter_project_${e(S)}`,f)}catch(r){console.error("Failed to fetch project:",r)}finally{c(g,!1)}}async function z(){if(e(h)?.apiKey)try{const t=await fetch("/api/sessions/detect",{headers:{Authorization:`Bearer ${e(h).apiKey}`}});if(t.ok){const r=await t.json();c(Y,r.processes,!0)}}catch{}}async function ee(t,r,d){if(t.preventDefault(),t.stopPropagation(),!(!e(h)?.apiKey||!e(i)||e(j))){c(j,r,!0);try{const v=await fetch("/api/sessions/connect",{body:JSON.stringify({command:d,cwd:e(i).fullPath,sessionId:r}),headers:{Authorization:`Bearer ${e(h).apiKey}`,"Content-Type":"application/json"},method:"POST"});if(v.ok){const f=await v.json();it(`/terminals/${f.terminalId}`)}}catch(v){console.error("Failed to connect to session:",v)}finally{c(j,null)}}}async function je(){c(g,!0),c(i,null),c(B,D),pt(`shooter_project_${e(S)}`),await M(!0),await z()}function Se(){c(B,e(B)+D)}function te(t){if(!t)return"";const r=new Date(t);return isNaN(r.getTime())?"":r.toLocaleDateString("en-US",{day:"numeric",hour:"2-digit",minute:"2-digit",month:"short"})}function Pe(t,r){return t.length<=r?t:`${t.slice(0,r).trimEnd()}...`}var F=Bt();nt("urn6fi",t=>{var r=gt();tt(()=>{rt.title=`${(e(i)?.name||"Project")??""} - Shooter`}),p(t,r)});var re=o(F);{var xe=t=>{st(t,{get text(){return e(L)},classes:"banner-error"})};w(re,t=>{e(L)&&t(xe)})}var we=l(re,2);{var ke=t=>{var r=yt(),d=o(r);ue(d,{classes:"shimmer-header"});var v=l(d,2);ve(v,16,()=>Array(4),at,(f,T)=>{ue(f,{classes:"shimmer-card"})}),a(r),p(t,r)},Be=t=>{var r=bt(),d=l(K(r),2);pe(d,{title:"Project Not Found",description:"The requested project could not be found.",icon:f=>{W(f,{get svg(){return lt},classes:"icon-24"})}}),p(t,r)},Te=t=>{var r=kt(),d=K(r),v=o(d),f=l(o(v),2);N(f,{classes:"btn-secondary",onclick:je,get disabled(){return e(g)},children:(y,E)=>{var b=$t(),q=K(b);W(q,{get svg(){return vt},classes:"icon-14"}),Z(),p(y,b)},$$slots:{default:!0}}),a(v);var T=l(v,2),Ce=o(T,!0);a(T);var se=l(T,2),O=o(se),Ie=o(O,!0);a(O);var ae=l(O,2),Ae=o(ae);a(ae),a(se),a(d);var Le=l(d,2);{var Re=y=>{pe(y,{title:"No sessions yet",description:"Sessions for this project will appear here",icon:b=>{W(b,{get svg(){return dt},classes:"icon-24"})}})},Ee=y=>{var E=wt(),b=K(E);ve(b,21,()=>e(ge),P=>P.id,(P,s)=>{var C=Pt(),I=o(C),J=o(I),G=o(J),Ne=o(G,!0);a(G);var De=l(G,2);{var Me=n=>{var _=jt(),A=o(_,!0);a(_),Q(x=>$(A,x),[()=>Pe(e(s).summary,80)]),p(n,_)};w(De,n=>{e(s).summary&&n(Me)})}a(J);var oe=l(J,2),ne=o(oe);{let n=u(()=>_t(e(s).modified));X(ne,{get text(){return e(n)},classes:"pill-session-time"})}var ze=l(ne,2);{var Fe=n=>{{let _=u(()=>e(j)===e(s).id),A=u(()=>e(j)===e(s).id);N(n,{classes:"btn-connect btn-xs",onclick:x=>{ee(x,e(s).id,fe(e(s).source))},get disabled(){return e(_)},get showLoader(){return e(A)},children:(x,Tt)=>{var Ze=St();Z(),p(x,Ze)},$$slots:{default:!0}})}},Oe=u(()=>e(be).has(e(s).id)),qe=n=>{{let _=u(()=>e(j)===e(s).id),A=u(()=>e(j)===e(s).id);N(n,{classes:"btn-resume btn-xs",onclick:x=>{ee(x,e(s).id,fe(e(s).source))},get disabled(){return e(_)},get showLoader(){return e(A)},text:"Resume"})}};w(ze,n=>{e(Oe)?n(Fe):n(qe,-1)})}a(oe),a(I);var H=l(I,2),U=o(H),ie=o(U),Je=o(ie,!0);a(ie),Z(),a(U);var ce=l(U,2);{var Ge=n=>{X(n,{get text(){return`🌿 ${e(s).gitBranch??""}`},classes:"pill-git-branch"})};w(ce,n=>{e(s).gitBranch&&n(Ge)})}var He=l(ce,2);{let n=u(()=>ht(e(s).source));X(He,{get text(){return e(n)},get classes(){return`pill-source-${e(s).source??""}`}})}a(H);var le=l(H,2),V=o(le),Ue=o(V);a(V);var de=l(V,2),Ve=o(de);a(de),a(le),a(C),Q((n,_)=>{ot(C,"href",`/session/${e(s).id??""}?project=${e(S)??""}`),$(Ne,e(s).title),$(Je,e(s).messageCount),$(Ue,`Last updated ${n??""}`),$(Ve,`Created ${_??""}`)},[()=>te(e(s).modified),()=>te(e(s).created)]),p(P,C)}),a(b);var q=l(b,2);{var Ke=P=>{var s=xt(),C=o(s);{let I=u(()=>`Load More (${e(i).sessions.length-e(B)} remaining)`);N(C,{classes:"btn-secondary",onclick:Se,get text(){return e(I)}})}a(s),p(P,s)};w(q,P=>{e(ye)&&P(Ke)})}p(y,E)};w(Le,y=>{e(i).sessions.length===0?y(Re):y(Ee,-1)})}Q(()=>{$(Ce,e(i).name),$(Ie,e(i).fullPath),$(Ae,`${e(i).sessionCount??""} sessions`)}),p(t,r)};w(we,t=>{e(g)&&!e(i)?t(ke):e(i)?t(Te,-1):t(Be,1)})}a(F),p(me,F),et()}export{Gt as component};
1
+ import{i as w,a as p,f as m,s as $}from"../chunks/BPDiEZo0.js";import{p as Qe,s as k,q as We,v as Xe,y as Ye,w as et,z as tt,g as e,b as c,$ as rt,c as o,d as l,r as a,x as u,A as K,B as Z,t as Q}from"../chunks/DWmC0QM7.js";import{b as st,e as ve,i as at,B as N,c as W,P as X,d as ot}from"../chunks/B1bOvemT.js";import{h as nt}from"../chunks/2rBV5OkJ.js";import{g as it}from"../chunks/BfbPKMXz.js";import{p as ct}from"../chunks/DhK7PwI_.js";import{A as lt}from"../chunks/DzuS5Nbr.js";import{B as dt}from"../chunks/Bn-6X1BO.js";import{S as ue,R as vt}from"../chunks/CJulw9ux.js";import{g as ut,s as ft,c as pt}from"../chunks/xs1Xl3_e.js";import{i as mt}from"../chunks/gQJcRhou.js";import"../chunks/BDcFu3l7.js";import{s as fe,a as ht}from"../chunks/BdtLzPpO.js";import{f as _t}from"../chunks/BLszSzTT.js";import{E as pe}from"../chunks/DomZZqvG.js";var gt=m('<meta name="description" content="Project sessions sorted by latest update"/>'),yt=m('<div class="loading-container"><!> <!></div>'),bt=m('<div class="project-back-row svelte-urn6fi"><a href="/" class="back-link"><span class="back-arrow">&larr;</span> Back to Projects</a></div> <!>',1),$t=m("<!> Refresh",1),jt=m('<div class="session-card-subtitle"> </div>'),St=m('<span class="connect-dot svelte-urn6fi"></span> Connect',1),Pt=m('<a class="session-card"><div class="session-card-header"><div><h3 class="session-card-title"> </h3> <!></div> <div class="session-card-actions svelte-urn6fi"><!> <!></div></div> <div class="session-stats"><span><strong> </strong> messages</span> <!> <!></div> <div class="session-meta-row svelte-urn6fi"><span class="session-modified svelte-urn6fi"> </span> <span class="session-duration svelte-urn6fi"> </span></div></a>'),xt=m('<div style="text-align: center; padding: 1rem;"><!></div>'),wt=m('<div class="sessions-container svelte-urn6fi"></div> <!>',1),kt=m('<div class="chat-session-header"><div class="chat-session-header-top svelte-urn6fi"><a href="/" class="back-link">&#8592; Back to Projects</a> <!></div> <h1 class="chat-session-title"> </h1> <div class="chat-session-meta"><span class="session-card-subtitle"> </span> <span> </span></div></div> <!>',1),Bt=m('<main class="main"><!> <!></main>');function Gt(me,he){Qe(he,!0);const _e=15e3,D=20;let i=k(null),g=k(!0),h=k(null),L=k(null),R=null,B=k(D),Y=k(We([])),j=k(null);const S=u(()=>ct.url.searchParams.get("id")||""),ge=u(()=>e(i)?e(i).sessions.slice(0,e(B)):[]),ye=u(()=>e(i)?e(B)<e(i).sessions.length:!1),be=u(()=>new Set(e(Y).map(t=>t.sessionId).filter(t=>typeof t=="string")));Xe(()=>{$e();const t=ut(`shooter_project_${e(S)}`);t&&(c(i,t,!0),c(g,!1)),setTimeout(()=>{M(),z()},50),R=setInterval(()=>{e(h)?.apiKey&&e(S)&&(M(),z())},_e)}),Ye(()=>{R&&(clearInterval(R),R=null)});function $e(){try{const t=localStorage.getItem("shooter_config");if(t){const r=JSON.parse(t);mt(r)?c(h,r,!0):(localStorage.removeItem("shooter_config"),c(h,null))}}catch{}}async function M(t=!1){if(!e(h)?.apiKey||!e(S)){c(g,!1);return}e(i)||c(g,!0);try{const d=await fetch(t?"/api/sessions?refresh=true":"/api/sessions",{headers:{Authorization:`Bearer ${e(h).apiKey}`}});if(!d.ok){c(L,`Failed to load project (HTTP ${d.status})`),c(g,!1);return}c(L,null);const f=(await d.json()).projects.find(T=>T.id===e(S))||null;c(i,f,!0),f&&ft(`shooter_project_${e(S)}`,f)}catch(r){console.error("Failed to fetch project:",r)}finally{c(g,!1)}}async function z(){if(e(h)?.apiKey)try{const t=await fetch("/api/sessions/detect",{headers:{Authorization:`Bearer ${e(h).apiKey}`}});if(t.ok){const r=await t.json();c(Y,r.processes,!0)}}catch{}}async function ee(t,r,d){if(t.preventDefault(),t.stopPropagation(),!(!e(h)?.apiKey||!e(i)||e(j))){c(j,r,!0);try{const v=await fetch("/api/sessions/connect",{body:JSON.stringify({command:d,cwd:e(i).fullPath,sessionId:r}),headers:{Authorization:`Bearer ${e(h).apiKey}`,"Content-Type":"application/json"},method:"POST"});if(v.ok){const f=await v.json();it(`/terminals/${f.terminalId}`)}}catch(v){console.error("Failed to connect to session:",v)}finally{c(j,null)}}}async function je(){c(g,!0),c(i,null),c(B,D),pt(`shooter_project_${e(S)}`),await M(!0),await z()}function Se(){c(B,e(B)+D)}function te(t){if(!t)return"";const r=new Date(t);return isNaN(r.getTime())?"":r.toLocaleDateString("en-US",{day:"numeric",hour:"2-digit",minute:"2-digit",month:"short"})}function Pe(t,r){return t.length<=r?t:`${t.slice(0,r).trimEnd()}...`}var F=Bt();nt("urn6fi",t=>{var r=gt();tt(()=>{rt.title=`${(e(i)?.name||"Project")??""} - Shooter`}),p(t,r)});var re=o(F);{var xe=t=>{st(t,{get text(){return e(L)},classes:"banner-error"})};w(re,t=>{e(L)&&t(xe)})}var we=l(re,2);{var ke=t=>{var r=yt(),d=o(r);ue(d,{classes:"shimmer-header"});var v=l(d,2);ve(v,16,()=>Array(4),at,(f,T)=>{ue(f,{classes:"shimmer-card"})}),a(r),p(t,r)},Be=t=>{var r=bt(),d=l(K(r),2);pe(d,{title:"Project Not Found",description:"The requested project could not be found.",icon:f=>{W(f,{get svg(){return lt},classes:"icon-24"})}}),p(t,r)},Te=t=>{var r=kt(),d=K(r),v=o(d),f=l(o(v),2);N(f,{classes:"btn-secondary",onclick:je,get disabled(){return e(g)},children:(y,E)=>{var b=$t(),q=K(b);W(q,{get svg(){return vt},classes:"icon-14"}),Z(),p(y,b)},$$slots:{default:!0}}),a(v);var T=l(v,2),Ce=o(T,!0);a(T);var se=l(T,2),O=o(se),Ie=o(O,!0);a(O);var ae=l(O,2),Ae=o(ae);a(ae),a(se),a(d);var Le=l(d,2);{var Re=y=>{pe(y,{title:"No sessions yet",description:"Sessions for this project will appear here",icon:b=>{W(b,{get svg(){return dt},classes:"icon-24"})}})},Ee=y=>{var E=wt(),b=K(E);ve(b,21,()=>e(ge),P=>P.id,(P,s)=>{var C=Pt(),I=o(C),J=o(I),G=o(J),Ne=o(G,!0);a(G);var De=l(G,2);{var Me=n=>{var _=jt(),A=o(_,!0);a(_),Q(x=>$(A,x),[()=>Pe(e(s).summary,80)]),p(n,_)};w(De,n=>{e(s).summary&&n(Me)})}a(J);var oe=l(J,2),ne=o(oe);{let n=u(()=>_t(e(s).modified));X(ne,{get text(){return e(n)},classes:"pill-session-time"})}var ze=l(ne,2);{var Fe=n=>{{let _=u(()=>e(j)===e(s).id),A=u(()=>e(j)===e(s).id);N(n,{classes:"btn-connect btn-xs",onclick:x=>{ee(x,e(s).id,fe(e(s).source))},get disabled(){return e(_)},get showLoader(){return e(A)},children:(x,Tt)=>{var Ze=St();Z(),p(x,Ze)},$$slots:{default:!0}})}},Oe=u(()=>e(be).has(e(s).id)),qe=n=>{{let _=u(()=>e(j)===e(s).id),A=u(()=>e(j)===e(s).id);N(n,{classes:"btn-resume btn-xs",onclick:x=>{ee(x,e(s).id,fe(e(s).source))},get disabled(){return e(_)},get showLoader(){return e(A)},text:"Resume"})}};w(ze,n=>{e(Oe)?n(Fe):n(qe,-1)})}a(oe),a(I);var H=l(I,2),U=o(H),ie=o(U),Je=o(ie,!0);a(ie),Z(),a(U);var ce=l(U,2);{var Ge=n=>{X(n,{get text(){return`🌿 ${e(s).gitBranch??""}`},classes:"pill-git-branch"})};w(ce,n=>{e(s).gitBranch&&n(Ge)})}var He=l(ce,2);{let n=u(()=>ht(e(s).source));X(He,{get text(){return e(n)},get classes(){return`pill-source-${e(s).source??""}`}})}a(H);var le=l(H,2),V=o(le),Ue=o(V);a(V);var de=l(V,2),Ve=o(de);a(de),a(le),a(C),Q((n,_)=>{ot(C,"href",`/session/${e(s).id??""}?project=${e(S)??""}`),$(Ne,e(s).title),$(Je,e(s).messageCount),$(Ue,`Last updated ${n??""}`),$(Ve,`Created ${_??""}`)},[()=>te(e(s).modified),()=>te(e(s).created)]),p(P,C)}),a(b);var q=l(b,2);{var Ke=P=>{var s=xt(),C=o(s);{let I=u(()=>`Load More (${e(i).sessions.length-e(B)} remaining)`);N(C,{classes:"btn-secondary",onclick:Se,get text(){return e(I)}})}a(s),p(P,s)};w(q,P=>{e(ye)&&P(Ke)})}p(y,E)};w(Le,y=>{e(i).sessions.length===0?y(Re):y(Ee,-1)})}Q(()=>{$(Ce,e(i).name),$(Ie,e(i).fullPath),$(Ae,`${e(i).sessionCount??""} sessions`)}),p(t,r)};w(we,t=>{e(g)&&!e(i)?t(ke):e(i)?t(Te,-1):t(Be,1)})}a(F),p(me,F),et()}export{Gt as component};