@juspay/shooter 1.18.0 → 1.20.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 (367) hide show
  1. package/build/client/_app/immutable/assets/{0.NV8k8wxG.css → 0.BwNtE8TX.css} +1 -1
  2. package/build/client/_app/immutable/assets/0.BwNtE8TX.css.br +0 -0
  3. package/build/client/_app/immutable/assets/{0.NV8k8wxG.css.gz → 0.BwNtE8TX.css.gz} +0 -0
  4. package/build/client/_app/immutable/assets/11.F10lvwyh.css +1 -0
  5. package/build/client/_app/immutable/assets/11.F10lvwyh.css.br +0 -0
  6. package/build/client/_app/immutable/assets/11.F10lvwyh.css.gz +0 -0
  7. package/build/client/_app/immutable/assets/8.BYgAX7hR.css +1 -0
  8. package/build/client/_app/immutable/assets/8.BYgAX7hR.css.br +0 -0
  9. package/build/client/_app/immutable/assets/8.BYgAX7hR.css.gz +0 -0
  10. package/build/client/_app/immutable/assets/9.DV6pZunn.css +1 -0
  11. package/build/client/_app/immutable/assets/9.DV6pZunn.css.br +0 -0
  12. package/build/client/_app/immutable/assets/9.DV6pZunn.css.gz +0 -0
  13. package/build/client/_app/immutable/chunks/{DZQMsHM5.js → 2rBV5OkJ.js} +1 -1
  14. package/build/client/_app/immutable/chunks/2rBV5OkJ.js.br +0 -0
  15. package/build/client/_app/immutable/chunks/2rBV5OkJ.js.gz +0 -0
  16. package/build/client/_app/immutable/chunks/{B9WQy_3X.js → BB2l8o4X.js} +1 -1
  17. package/build/client/_app/immutable/chunks/BB2l8o4X.js.br +0 -0
  18. package/build/client/_app/immutable/chunks/BB2l8o4X.js.gz +0 -0
  19. package/build/client/_app/immutable/chunks/{Cg3dlX05.js → BPDiEZo0.js} +2 -2
  20. package/build/client/_app/immutable/chunks/BPDiEZo0.js.br +0 -0
  21. package/build/client/_app/immutable/chunks/BPDiEZo0.js.gz +0 -0
  22. package/build/client/_app/immutable/chunks/{C_9BZILB.js → BcpydfqI.js} +1 -1
  23. package/build/client/_app/immutable/chunks/BcpydfqI.js.br +0 -0
  24. package/build/client/_app/immutable/chunks/BcpydfqI.js.gz +0 -0
  25. package/build/client/_app/immutable/chunks/{BRqaaL5D.js → BvmdJful.js} +1 -1
  26. package/build/client/_app/immutable/chunks/BvmdJful.js.br +0 -0
  27. package/build/client/_app/immutable/chunks/BvmdJful.js.gz +0 -0
  28. package/build/client/_app/immutable/chunks/C_YNQL8b.js +3 -0
  29. package/build/client/_app/immutable/chunks/C_YNQL8b.js.br +0 -0
  30. package/build/client/_app/immutable/chunks/C_YNQL8b.js.gz +0 -0
  31. package/build/client/_app/immutable/chunks/{C5VOyQCG.js → ClIPTXf3.js} +1 -1
  32. package/build/client/_app/immutable/chunks/ClIPTXf3.js.br +0 -0
  33. package/build/client/_app/immutable/chunks/ClIPTXf3.js.gz +0 -0
  34. package/build/client/_app/immutable/chunks/{8lO1IL7u.js → DIZ3Qst5.js} +1 -1
  35. package/build/client/_app/immutable/chunks/DIZ3Qst5.js.br +0 -0
  36. package/build/client/_app/immutable/chunks/{8lO1IL7u.js.gz → DIZ3Qst5.js.gz} +0 -0
  37. package/build/client/_app/immutable/chunks/{DJvX78LW.js → DT4H19pV.js} +1 -1
  38. package/build/client/_app/immutable/chunks/DT4H19pV.js.br +0 -0
  39. package/build/client/_app/immutable/chunks/DT4H19pV.js.gz +0 -0
  40. package/build/client/_app/immutable/chunks/{DYuMZGL5.js → DWmC0QM7.js} +1 -1
  41. package/build/client/_app/immutable/chunks/DWmC0QM7.js.br +0 -0
  42. package/build/client/_app/immutable/chunks/DWmC0QM7.js.gz +0 -0
  43. package/build/client/_app/immutable/chunks/J5-Cr5oR.js +6 -0
  44. package/build/client/_app/immutable/chunks/J5-Cr5oR.js.br +0 -0
  45. package/build/client/_app/immutable/chunks/J5-Cr5oR.js.gz +0 -0
  46. package/build/client/_app/immutable/chunks/{DZvnhU_8.js → ZS5XYDx_.js} +2 -2
  47. package/build/client/_app/immutable/chunks/ZS5XYDx_.js.br +0 -0
  48. package/build/client/_app/immutable/chunks/ZS5XYDx_.js.gz +0 -0
  49. package/build/client/_app/immutable/entry/app.Bd-DfeJi.js +2 -0
  50. package/build/client/_app/immutable/entry/app.Bd-DfeJi.js.br +0 -0
  51. package/build/client/_app/immutable/entry/app.Bd-DfeJi.js.gz +0 -0
  52. package/build/client/_app/immutable/entry/start.evvp4tX7.js +1 -0
  53. package/build/client/_app/immutable/entry/start.evvp4tX7.js.br +2 -0
  54. package/build/client/_app/immutable/entry/start.evvp4tX7.js.gz +0 -0
  55. package/build/client/_app/immutable/nodes/0.Bl-1LQWM.js +10 -0
  56. package/build/client/_app/immutable/nodes/0.Bl-1LQWM.js.br +0 -0
  57. package/build/client/_app/immutable/nodes/0.Bl-1LQWM.js.gz +0 -0
  58. package/build/client/_app/immutable/nodes/{1.C4eFlqSB.js → 1.DT4dq6Ay.js} +1 -1
  59. package/build/client/_app/immutable/nodes/1.DT4dq6Ay.js.br +0 -0
  60. package/build/client/_app/immutable/nodes/1.DT4dq6Ay.js.gz +0 -0
  61. package/build/client/_app/immutable/nodes/{8.Bs362gyb.js → 10.CF7RGXpe.js} +2 -2
  62. package/build/client/_app/immutable/nodes/10.CF7RGXpe.js.br +0 -0
  63. package/build/client/_app/immutable/nodes/10.CF7RGXpe.js.gz +0 -0
  64. package/build/client/_app/immutable/nodes/11.BV_G7yLI.js +2 -0
  65. package/build/client/_app/immutable/nodes/11.BV_G7yLI.js.br +0 -0
  66. package/build/client/_app/immutable/nodes/11.BV_G7yLI.js.gz +0 -0
  67. package/build/client/_app/immutable/nodes/{2.CdC092Za.js → 2.DcRhsjYp.js} +2 -2
  68. package/build/client/_app/immutable/nodes/2.DcRhsjYp.js.br +0 -0
  69. package/build/client/_app/immutable/nodes/2.DcRhsjYp.js.gz +0 -0
  70. package/build/client/_app/immutable/nodes/{3.Dhf4ZWW0.js → 3.0MMe3oxR.js} +3 -3
  71. package/build/client/_app/immutable/nodes/3.0MMe3oxR.js.br +0 -0
  72. package/build/client/_app/immutable/nodes/3.0MMe3oxR.js.gz +0 -0
  73. package/build/client/_app/immutable/nodes/{4.BSVqdrrD.js → 4.CBX9A3ka.js} +2 -2
  74. package/build/client/_app/immutable/nodes/4.CBX9A3ka.js.br +0 -0
  75. package/build/client/_app/immutable/nodes/4.CBX9A3ka.js.gz +0 -0
  76. package/build/client/_app/immutable/nodes/{5.Cfj35gpY.js → 5.DIVKuZc9.js} +1 -1
  77. package/build/client/_app/immutable/nodes/5.DIVKuZc9.js.br +0 -0
  78. package/build/client/_app/immutable/nodes/5.DIVKuZc9.js.gz +0 -0
  79. package/build/client/_app/immutable/nodes/{6.B3SEB_li.js → 6.ComiWlV6.js} +1 -1
  80. package/build/client/_app/immutable/nodes/6.ComiWlV6.js.br +0 -0
  81. package/build/client/_app/immutable/nodes/6.ComiWlV6.js.gz +0 -0
  82. package/build/client/_app/immutable/nodes/{7.DV8cJ1lX.js → 7.vkPx1kVP.js} +1 -1
  83. package/build/client/_app/immutable/nodes/7.vkPx1kVP.js.br +0 -0
  84. package/build/client/_app/immutable/nodes/7.vkPx1kVP.js.gz +0 -0
  85. package/build/client/_app/immutable/nodes/8.Bmr3sWbS.js +1 -0
  86. package/build/client/_app/immutable/nodes/8.Bmr3sWbS.js.br +0 -0
  87. package/build/client/_app/immutable/nodes/8.Bmr3sWbS.js.gz +0 -0
  88. package/build/client/_app/immutable/nodes/9.CAJucyeI.js +2 -0
  89. package/build/client/_app/immutable/nodes/9.CAJucyeI.js.br +0 -0
  90. package/build/client/_app/immutable/nodes/9.CAJucyeI.js.gz +0 -0
  91. package/build/client/_app/version.json +1 -1
  92. package/build/client/_app/version.json.br +0 -0
  93. package/build/client/_app/version.json.gz +0 -0
  94. package/build/server/chunks/{0-Cd7jY0a7.js → 0-DDGB6CRT.js} +4 -4
  95. package/build/server/chunks/{0-Cd7jY0a7.js.map → 0-DDGB6CRT.js.map} +1 -1
  96. package/build/server/chunks/1-DEjonQXD.js +9 -0
  97. package/build/server/chunks/{1-C4BOGoJY.js.map → 1-DEjonQXD.js.map} +1 -1
  98. package/build/server/chunks/10-BK1kiiiw.js +9 -0
  99. package/build/server/chunks/10-BK1kiiiw.js.map +1 -0
  100. package/build/server/chunks/11-CJPjkEF3.js +9 -0
  101. package/build/server/chunks/11-CJPjkEF3.js.map +1 -0
  102. package/build/server/chunks/{2-Ba0mNwJ6.js → 2-RLnhlWh5.js} +3 -3
  103. package/build/server/chunks/{2-Ba0mNwJ6.js.map → 2-RLnhlWh5.js.map} +1 -1
  104. package/build/server/chunks/{3-Pg8t1uJU.js → 3-Dd4pJBqZ.js} +3 -3
  105. package/build/server/chunks/{3-Pg8t1uJU.js.map → 3-Dd4pJBqZ.js.map} +1 -1
  106. package/build/server/chunks/{4-BtYdKCVW.js → 4-Bb5VFhsO.js} +3 -3
  107. package/build/server/chunks/{4-BtYdKCVW.js.map → 4-Bb5VFhsO.js.map} +1 -1
  108. package/build/server/chunks/{5-CvJK3PiH.js → 5-oNoWuIsn.js} +3 -3
  109. package/build/server/chunks/{5-CvJK3PiH.js.map → 5-oNoWuIsn.js.map} +1 -1
  110. package/build/server/chunks/6-DdRMnKNa.js +9 -0
  111. package/build/server/chunks/{6-D8xbnTSo.js.map → 6-DdRMnKNa.js.map} +1 -1
  112. package/build/server/chunks/7-vLOMMetm.js +9 -0
  113. package/build/server/chunks/{7-CkVK06S0.js.map → 7-vLOMMetm.js.map} +1 -1
  114. package/build/server/chunks/8-rJyiQLFs.js +9 -0
  115. package/build/server/chunks/8-rJyiQLFs.js.map +1 -0
  116. package/build/server/chunks/9-CVSNNYED.js +9 -0
  117. package/build/server/chunks/9-CVSNNYED.js.map +1 -0
  118. package/build/server/chunks/Banner-BgaAs1rs.js +90 -0
  119. package/build/server/chunks/Banner-BgaAs1rs.js.map +1 -0
  120. package/build/server/chunks/{Button-B5dU-ntz.js → Button-D0hZ7JYt.js} +2 -2
  121. package/build/server/chunks/Button-D0hZ7JYt.js.map +1 -0
  122. package/build/server/chunks/{Icon-C7Ml3GX6.js → Icon-D0GBnDcs.js} +3 -3
  123. package/build/server/chunks/Icon-D0GBnDcs.js.map +1 -0
  124. package/build/server/chunks/{Input-CPGO0sbS.js → Input-OmIiydSx.js} +2 -2
  125. package/build/server/chunks/Input-OmIiydSx.js.map +1 -0
  126. package/build/server/chunks/{Pill-CcrtCejm.js → Pill-4xJ-VhAA.js} +3 -3
  127. package/build/server/chunks/Pill-4xJ-VhAA.js.map +1 -0
  128. package/build/server/chunks/{Shimmer-C5jkvGr1.js → Shimmer-Dw2uvTC1.js} +2 -2
  129. package/build/server/chunks/Shimmer-Dw2uvTC1.js.map +1 -0
  130. package/build/server/chunks/{_error.svelte-CSIxs-ab.js → _error.svelte-CZnkxeLr.js} +8 -8
  131. package/build/server/chunks/_error.svelte-CZnkxeLr.js.map +1 -0
  132. package/build/server/chunks/{_layout.svelte-noB4j-v2.js → _layout.svelte-DfgNGGiM.js} +16 -11
  133. package/build/server/chunks/_layout.svelte-DfgNGGiM.js.map +1 -0
  134. package/build/server/chunks/{_page.svelte-DnTpPnPR.js → _page.svelte-BLo2v_8E.js} +7 -88
  135. package/build/server/chunks/_page.svelte-BLo2v_8E.js.map +1 -0
  136. package/build/server/chunks/_page.svelte-BTlfUsBp.js +43 -0
  137. package/build/server/chunks/_page.svelte-BTlfUsBp.js.map +1 -0
  138. package/build/server/chunks/{_page.svelte-BV0XyYJZ.js → _page.svelte-BX2FMgSg.js} +4 -4
  139. package/build/server/chunks/_page.svelte-BX2FMgSg.js.map +1 -0
  140. package/build/server/chunks/{_page.svelte-BUkm2304.js → _page.svelte-C7B0qdrC.js} +5 -5
  141. package/build/server/chunks/_page.svelte-C7B0qdrC.js.map +1 -0
  142. package/build/server/chunks/{_page.svelte-Dmg-RFCg.js → _page.svelte-CE7COWnF.js} +7 -7
  143. package/build/server/chunks/_page.svelte-CE7COWnF.js.map +1 -0
  144. package/build/server/chunks/{_page.svelte-BfB8maoc.js → _page.svelte-CWsjjd4l.js} +9 -9
  145. package/build/server/chunks/_page.svelte-CWsjjd4l.js.map +1 -0
  146. package/build/server/chunks/_page.svelte-D5S2hkBk.js +104 -0
  147. package/build/server/chunks/_page.svelte-D5S2hkBk.js.map +1 -0
  148. package/build/server/chunks/{_page.svelte-B6qyh-K-.js → _page.svelte-D_Ey8QRG.js} +11 -11
  149. package/build/server/chunks/_page.svelte-D_Ey8QRG.js.map +1 -0
  150. package/build/server/chunks/{_page.svelte-C60lAagP.js → _page.svelte-dabsQl9c.js} +210 -9
  151. package/build/server/chunks/_page.svelte-dabsQl9c.js.map +1 -0
  152. package/build/server/chunks/{_page.svelte-DuzZr5dA.js → _page.svelte-tBuIq8Pg.js} +11 -11
  153. package/build/server/chunks/_page.svelte-tBuIq8Pg.js.map +1 -0
  154. package/build/server/chunks/{_server.ts-CyjDrcZN.js → _server.ts-AnBXfZXh.js} +10 -2
  155. package/build/server/chunks/_server.ts-AnBXfZXh.js.map +1 -0
  156. package/build/server/chunks/_server.ts-B-evHL2q.js +13 -0
  157. package/build/server/chunks/_server.ts-B-evHL2q.js.map +1 -0
  158. package/build/server/chunks/_server.ts-B2wIgsW4.js +95 -0
  159. package/build/server/chunks/_server.ts-B2wIgsW4.js.map +1 -0
  160. package/build/server/chunks/_server.ts-BaaY7Z9D.js +77 -0
  161. package/build/server/chunks/_server.ts-BaaY7Z9D.js.map +1 -0
  162. package/build/server/chunks/_server.ts-C0317RBD.js +57 -0
  163. package/build/server/chunks/_server.ts-C0317RBD.js.map +1 -0
  164. package/build/server/chunks/{_server.ts-Bu3s5hfv.js → _server.ts-CJGyN8mw.js} +18 -10
  165. package/build/server/chunks/_server.ts-CJGyN8mw.js.map +1 -0
  166. package/build/server/chunks/_server.ts-CVPZOpiv.js +23 -0
  167. package/build/server/chunks/_server.ts-CVPZOpiv.js.map +1 -0
  168. package/build/server/chunks/{_server.ts-DZgfQKiH.js → _server.ts-D9ir7u24.js} +2 -2
  169. package/build/server/chunks/{_server.ts-DZgfQKiH.js.map → _server.ts-D9ir7u24.js.map} +1 -1
  170. package/build/server/chunks/{_server.ts-DZP2lhaY.js → _server.ts-DEx9-epI.js} +20 -8
  171. package/build/server/chunks/_server.ts-DEx9-epI.js.map +1 -0
  172. package/build/server/chunks/{_server.ts-BA_uWcPw.js → _server.ts-DKNIsQeH.js} +6 -4
  173. package/build/server/chunks/_server.ts-DKNIsQeH.js.map +1 -0
  174. package/build/server/chunks/_server.ts-DkZX_O9a.js +39 -0
  175. package/build/server/chunks/_server.ts-DkZX_O9a.js.map +1 -0
  176. package/build/server/chunks/_server.ts-DpRr0Tfh.js +68 -0
  177. package/build/server/chunks/_server.ts-DpRr0Tfh.js.map +1 -0
  178. package/build/server/chunks/{_server.ts-CwAjt91u.js → _server.ts-Dz9Jd9Jh.js} +6 -4
  179. package/build/server/chunks/{_server.ts-CwAjt91u.js.map → _server.ts-Dz9Jd9Jh.js.map} +1 -1
  180. package/build/server/chunks/_server.ts-Mttr0-Sl.js +48 -0
  181. package/build/server/chunks/_server.ts-Mttr0-Sl.js.map +1 -0
  182. package/build/server/chunks/{_server.ts-Bjbr7glm.js → _server.ts-QN-Bo5ql.js} +12 -5
  183. package/build/server/chunks/_server.ts-QN-Bo5ql.js.map +1 -0
  184. package/build/server/chunks/{_server.ts-BrqaMMAa.js → _server.ts-W6i3EnGX.js} +29 -6
  185. package/build/server/chunks/_server.ts-W6i3EnGX.js.map +1 -0
  186. package/build/server/chunks/{_server.ts-DZ5naqSL.js → _server.ts-bk_EeAdY.js} +6 -2
  187. package/build/server/chunks/_server.ts-bk_EeAdY.js.map +1 -0
  188. package/build/server/chunks/_server.ts-jtqWDWcf.js +45 -0
  189. package/build/server/chunks/_server.ts-jtqWDWcf.js.map +1 -0
  190. package/build/server/chunks/{cache-Me3zUAaD.js → cache-BlMaDsHi.js} +2 -2
  191. package/build/server/chunks/cache-BlMaDsHi.js.map +1 -0
  192. package/build/server/chunks/{client-CfNnl32g.js → client-Ds1brw-8.js} +4 -4
  193. package/build/server/chunks/{client-CfNnl32g.js.map → client-Ds1brw-8.js.map} +1 -1
  194. package/build/server/chunks/client2-DngLdcUc.js +7 -0
  195. package/build/server/chunks/{client2-DDP30_vY.js.map → client2-DngLdcUc.js.map} +1 -1
  196. package/build/server/chunks/coordinator-DMU_ADXf.js +530 -0
  197. package/build/server/chunks/coordinator-DMU_ADXf.js.map +1 -0
  198. package/build/server/chunks/guest-registry-t0-7Zv5q.js +39 -0
  199. package/build/server/chunks/guest-registry-t0-7Zv5q.js.map +1 -0
  200. package/build/server/chunks/{index-CJrGuxuM.js → index-CoYB03g7.js} +2 -2
  201. package/build/server/chunks/{index-CJrGuxuM.js.map → index-CoYB03g7.js.map} +1 -1
  202. package/build/server/chunks/{index-server--49oHtA0.js → index-server-Bq3cnK69.js} +2 -2
  203. package/build/server/chunks/{index-server--49oHtA0.js.map → index-server-Bq3cnK69.js.map} +1 -1
  204. package/build/server/chunks/{index2-MY7PXeAc.js → index2-dSGQ9Eaa.js} +2 -2
  205. package/build/server/chunks/{index2-MY7PXeAc.js.map → index2-dSGQ9Eaa.js.map} +1 -1
  206. package/build/server/chunks/{pty-manager-DmNSCKAr.js → pty-manager-CkZNoW1t.js} +7 -2
  207. package/build/server/chunks/pty-manager-CkZNoW1t.js.map +1 -0
  208. package/build/server/chunks/qwen-reader-DGfUbKaJ.js.map +1 -1
  209. package/build/server/chunks/{registry-Kcw2UCMv.js → registry-D4J_CuzW.js} +2 -2
  210. package/build/server/chunks/registry-D4J_CuzW.js.map +1 -0
  211. package/build/server/chunks/{root-xvQIR1Bt.js → root-D4IoFC8F.js} +2 -2
  212. package/build/server/chunks/root-D4IoFC8F.js.map +1 -0
  213. package/build/server/chunks/share-auth-BS7JuiHf.js +27 -0
  214. package/build/server/chunks/share-auth-BS7JuiHf.js.map +1 -0
  215. package/build/server/chunks/share-store-B9jMpVg0.js +127 -0
  216. package/build/server/chunks/share-store-B9jMpVg0.js.map +1 -0
  217. package/build/server/chunks/{state.svelte-RCtlkrNH.js → state.svelte-CmHqngc_.js} +3 -3
  218. package/build/server/chunks/{state.svelte-RCtlkrNH.js.map → state.svelte-CmHqngc_.js.map} +1 -1
  219. package/build/server/chunks/{stores-C-LqoonT.js → stores-CRYxfF0o.js} +4 -4
  220. package/build/server/chunks/stores-CRYxfF0o.js.map +1 -0
  221. package/build/server/chunks/super-session-handler-DPyxFgmz.js +22 -0
  222. package/build/server/chunks/super-session-handler-DPyxFgmz.js.map +1 -0
  223. package/build/server/index.js +4 -4
  224. package/build/server/index.js.map +1 -1
  225. package/build/server/manifest.js +101 -22
  226. package/build/server/manifest.js.map +1 -1
  227. package/package.json +2 -2
  228. package/scripts/e2e-all-features.sh +41 -2
  229. package/server.ts +33 -3
  230. package/src/lib/modules/client/terminal/ShareGate.svelte +96 -0
  231. package/src/lib/modules/client/terminal/ShareSheet.svelte +395 -0
  232. package/src/lib/modules/client/terminal/xterm-wrapper.ts +19 -2
  233. package/src/lib/modules/server/sos/coordinator.ts +492 -0
  234. package/src/lib/modules/server/sos/policy-gate.ts +56 -0
  235. package/src/lib/modules/server/sos/relay-store.ts +159 -0
  236. package/src/lib/modules/server/terminal/pty-input.ts +37 -0
  237. package/src/lib/modules/server/terminal/pty-manager.ts +6 -0
  238. package/src/lib/modules/server/terminal/share-auth.ts +37 -0
  239. package/src/lib/modules/server/terminal/share-store.ts +172 -0
  240. package/src/lib/modules/server/ws/guest-registry.ts +49 -0
  241. package/src/lib/modules/server/ws/server.ts +28 -4
  242. package/src/lib/modules/server/ws/session-handler.ts +24 -5
  243. package/src/lib/modules/server/ws/super-session-handler.ts +200 -0
  244. package/src/lib/modules/server/ws/terminal-handler.ts +21 -2
  245. package/src/lib/modules/server/ws/ticket-store.ts +18 -10
  246. package/src/lib/types/generated/Client.ts +25 -1
  247. package/src/lib/types/generated/Share.ts +404 -0
  248. package/src/lib/types/generated/WsProtocol.ts +73 -2
  249. package/src/lib/types/generated/index.ts +1 -0
  250. package/src/lib/types/index.ts +2 -1
  251. package/src/lib/types/sos.ts +134 -0
  252. package/src/lib/types/terminal-client.ts +19 -2
  253. package/src/lib/types/ws.ts +1 -0
  254. package/src/routes/+layout.svelte +9 -2
  255. package/src/routes/api/sos/+server.ts +36 -0
  256. package/src/routes/api/sos/[id]/+server.ts +55 -0
  257. package/src/routes/api/sos/[id]/inject/+server.ts +44 -0
  258. package/src/routes/api/sos/[id]/members/+server.ts +47 -0
  259. package/src/routes/api/sos/[id]/members/[mid]/+server.ts +17 -0
  260. package/src/routes/api/sos/[id]/rules/+server.ts +85 -0
  261. package/src/routes/api/terminals/[id]/+server.ts +14 -3
  262. package/src/routes/api/terminals/[id]/paste-image/+server.ts +8 -4
  263. package/src/routes/api/terminals/[id]/resize/+server.ts +8 -4
  264. package/src/routes/api/terminals/[id]/share/+server.ts +98 -0
  265. package/src/routes/api/terminals/[id]/share/auth/+server.ts +81 -0
  266. package/src/routes/api/terminals/[id]/share/status/+server.ts +11 -0
  267. package/src/routes/api/ws-ticket/+server.ts +26 -5
  268. package/src/routes/sos/+page.svelte +195 -0
  269. package/src/routes/sos/[id]/+page.svelte +677 -0
  270. package/src/routes/terminals/[id]/+page.svelte +184 -43
  271. package/build/client/_app/immutable/assets/0.NV8k8wxG.css.br +0 -0
  272. package/build/client/_app/immutable/assets/9.v5KA95xm.css +0 -1
  273. package/build/client/_app/immutable/assets/9.v5KA95xm.css.br +0 -0
  274. package/build/client/_app/immutable/assets/9.v5KA95xm.css.gz +0 -0
  275. package/build/client/_app/immutable/chunks/8lO1IL7u.js.br +0 -0
  276. package/build/client/_app/immutable/chunks/B9WQy_3X.js.br +0 -0
  277. package/build/client/_app/immutable/chunks/B9WQy_3X.js.gz +0 -0
  278. package/build/client/_app/immutable/chunks/BRqaaL5D.js.br +0 -0
  279. package/build/client/_app/immutable/chunks/BRqaaL5D.js.gz +0 -0
  280. package/build/client/_app/immutable/chunks/C5VOyQCG.js.br +0 -0
  281. package/build/client/_app/immutable/chunks/C5VOyQCG.js.gz +0 -0
  282. package/build/client/_app/immutable/chunks/CR6bkGJW.js +0 -6
  283. package/build/client/_app/immutable/chunks/CR6bkGJW.js.br +0 -0
  284. package/build/client/_app/immutable/chunks/CR6bkGJW.js.gz +0 -0
  285. package/build/client/_app/immutable/chunks/C_9BZILB.js.br +0 -0
  286. package/build/client/_app/immutable/chunks/C_9BZILB.js.gz +0 -0
  287. package/build/client/_app/immutable/chunks/Cg3dlX05.js.br +0 -0
  288. package/build/client/_app/immutable/chunks/Cg3dlX05.js.gz +0 -0
  289. package/build/client/_app/immutable/chunks/DJvX78LW.js.br +0 -0
  290. package/build/client/_app/immutable/chunks/DJvX78LW.js.gz +0 -0
  291. package/build/client/_app/immutable/chunks/DYuMZGL5.js.br +0 -0
  292. package/build/client/_app/immutable/chunks/DYuMZGL5.js.gz +0 -0
  293. package/build/client/_app/immutable/chunks/DZQMsHM5.js.br +0 -0
  294. package/build/client/_app/immutable/chunks/DZQMsHM5.js.gz +0 -0
  295. package/build/client/_app/immutable/chunks/DZvnhU_8.js.br +0 -0
  296. package/build/client/_app/immutable/chunks/DZvnhU_8.js.gz +0 -0
  297. package/build/client/_app/immutable/chunks/nWG9RHyB.js +0 -3
  298. package/build/client/_app/immutable/chunks/nWG9RHyB.js.br +0 -0
  299. package/build/client/_app/immutable/chunks/nWG9RHyB.js.gz +0 -0
  300. package/build/client/_app/immutable/entry/app.f46Ko1hu.js +0 -2
  301. package/build/client/_app/immutable/entry/app.f46Ko1hu.js.br +0 -0
  302. package/build/client/_app/immutable/entry/app.f46Ko1hu.js.gz +0 -0
  303. package/build/client/_app/immutable/entry/start.BVDjNnXt.js +0 -1
  304. package/build/client/_app/immutable/entry/start.BVDjNnXt.js.br +0 -2
  305. package/build/client/_app/immutable/entry/start.BVDjNnXt.js.gz +0 -0
  306. package/build/client/_app/immutable/nodes/0.D_9EwVmq.js +0 -7
  307. package/build/client/_app/immutable/nodes/0.D_9EwVmq.js.br +0 -0
  308. package/build/client/_app/immutable/nodes/0.D_9EwVmq.js.gz +0 -0
  309. package/build/client/_app/immutable/nodes/1.C4eFlqSB.js.br +0 -0
  310. package/build/client/_app/immutable/nodes/1.C4eFlqSB.js.gz +0 -0
  311. package/build/client/_app/immutable/nodes/2.CdC092Za.js.br +0 -0
  312. package/build/client/_app/immutable/nodes/2.CdC092Za.js.gz +0 -0
  313. package/build/client/_app/immutable/nodes/3.Dhf4ZWW0.js.br +0 -0
  314. package/build/client/_app/immutable/nodes/3.Dhf4ZWW0.js.gz +0 -0
  315. package/build/client/_app/immutable/nodes/4.BSVqdrrD.js.br +0 -0
  316. package/build/client/_app/immutable/nodes/4.BSVqdrrD.js.gz +0 -0
  317. package/build/client/_app/immutable/nodes/5.Cfj35gpY.js.br +0 -0
  318. package/build/client/_app/immutable/nodes/5.Cfj35gpY.js.gz +0 -0
  319. package/build/client/_app/immutable/nodes/6.B3SEB_li.js.br +0 -0
  320. package/build/client/_app/immutable/nodes/6.B3SEB_li.js.gz +0 -0
  321. package/build/client/_app/immutable/nodes/7.DV8cJ1lX.js.br +0 -0
  322. package/build/client/_app/immutable/nodes/7.DV8cJ1lX.js.gz +0 -0
  323. package/build/client/_app/immutable/nodes/8.Bs362gyb.js.br +0 -0
  324. package/build/client/_app/immutable/nodes/8.Bs362gyb.js.gz +0 -0
  325. package/build/client/_app/immutable/nodes/9.Cf7_3uqT.js +0 -2
  326. package/build/client/_app/immutable/nodes/9.Cf7_3uqT.js.br +0 -0
  327. package/build/client/_app/immutable/nodes/9.Cf7_3uqT.js.gz +0 -0
  328. package/build/server/chunks/1-C4BOGoJY.js +0 -9
  329. package/build/server/chunks/6-D8xbnTSo.js +0 -9
  330. package/build/server/chunks/7-CkVK06S0.js +0 -9
  331. package/build/server/chunks/8-C8qVhrds.js +0 -9
  332. package/build/server/chunks/8-C8qVhrds.js.map +0 -1
  333. package/build/server/chunks/9-fL5zqN0T.js +0 -9
  334. package/build/server/chunks/9-fL5zqN0T.js.map +0 -1
  335. package/build/server/chunks/Button-B5dU-ntz.js.map +0 -1
  336. package/build/server/chunks/Icon-C7Ml3GX6.js.map +0 -1
  337. package/build/server/chunks/Input-CPGO0sbS.js.map +0 -1
  338. package/build/server/chunks/Pill-CcrtCejm.js.map +0 -1
  339. package/build/server/chunks/Shimmer-C5jkvGr1.js.map +0 -1
  340. package/build/server/chunks/_error.svelte-CSIxs-ab.js.map +0 -1
  341. package/build/server/chunks/_layout.svelte-noB4j-v2.js.map +0 -1
  342. package/build/server/chunks/_page.svelte-B6qyh-K-.js.map +0 -1
  343. package/build/server/chunks/_page.svelte-BUkm2304.js.map +0 -1
  344. package/build/server/chunks/_page.svelte-BV0XyYJZ.js.map +0 -1
  345. package/build/server/chunks/_page.svelte-BfB8maoc.js.map +0 -1
  346. package/build/server/chunks/_page.svelte-C60lAagP.js.map +0 -1
  347. package/build/server/chunks/_page.svelte-Dmg-RFCg.js.map +0 -1
  348. package/build/server/chunks/_page.svelte-DnTpPnPR.js.map +0 -1
  349. package/build/server/chunks/_page.svelte-DuzZr5dA.js.map +0 -1
  350. package/build/server/chunks/_server.ts-BA_uWcPw.js.map +0 -1
  351. package/build/server/chunks/_server.ts-Bjbr7glm.js.map +0 -1
  352. package/build/server/chunks/_server.ts-BrqaMMAa.js.map +0 -1
  353. package/build/server/chunks/_server.ts-Bu3s5hfv.js.map +0 -1
  354. package/build/server/chunks/_server.ts-CyjDrcZN.js.map +0 -1
  355. package/build/server/chunks/_server.ts-DZ5naqSL.js.map +0 -1
  356. package/build/server/chunks/_server.ts-DZP2lhaY.js.map +0 -1
  357. package/build/server/chunks/cache-Me3zUAaD.js.map +0 -1
  358. package/build/server/chunks/client2-DDP30_vY.js +0 -7
  359. package/build/server/chunks/events-handler-Dm1mNPQP.js +0 -20
  360. package/build/server/chunks/events-handler-Dm1mNPQP.js.map +0 -1
  361. package/build/server/chunks/pty-manager-DmNSCKAr.js.map +0 -1
  362. package/build/server/chunks/registry-Kcw2UCMv.js.map +0 -1
  363. package/build/server/chunks/root-xvQIR1Bt.js.map +0 -1
  364. package/build/server/chunks/stores-C-LqoonT.js.map +0 -1
  365. /package/build/client/_app/immutable/assets/{8.BhoBXADL.css → 10.BhoBXADL.css} +0 -0
  366. /package/build/client/_app/immutable/assets/{8.BhoBXADL.css.br → 10.BhoBXADL.css.br} +0 -0
  367. /package/build/client/_app/immutable/assets/{8.BhoBXADL.css.gz → 10.BhoBXADL.css.gz} +0 -0
@@ -0,0 +1,2 @@
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};
@@ -1,4 +1,4 @@
1
- import{d as vt,i as D,s as C,b as Fe,a as h,f as p}from"../chunks/Cg3dlX05.js";import{p as ze,c,r as l,d as v,g as r,t as B,w as je,x as M,A as me,s as q,q as et,b as _,v as ft,y as gt,N as mt,$ as ht,B as Ge}from"../chunks/DYuMZGL5.js";import{P as tt,k as pt,d as Re,s as _t,g as St,e as de,j as Le,B as Te,c as De,b as yt,i as Ue}from"../chunks/DZvnhU_8.js";import{h as bt}from"../chunks/DZQMsHM5.js";import{g as Ve}from"../chunks/nWG9RHyB.js";import{B as wt}from"../chunks/Bn-6X1BO.js";import{R as Ct,S as We}from"../chunks/BRqaaL5D.js";import{S as xt}from"../chunks/CG453M9q.js";import{c as kt,s as At,g as Et}from"../chunks/xs1Xl3_e.js";import{i as Nt}from"../chunks/gQJcRhou.js";import"../chunks/BDcFu3l7.js";import{f as It}from"../chunks/BLszSzTT.js";import{S as Pt}from"../chunks/C_9BZILB.js";import{i as Tt,N as Dt}from"../chunks/CRkG7oE4.js";import{d as Ot}from"../chunks/pRcLbE0d.js";import{E as He}from"../chunks/C5VOyQCG.js";var Rt=p('<p class="goal-text svelte-1qbe2oo"> </p>'),zt=p('<span class="summarizing svelte-1qbe2oo">Analyzing…</span>'),jt=p('<span class="summary-text svelte-1qbe2oo"> </span>'),Lt=p('<span class="summary-fallback svelte-1qbe2oo"> </span>'),Mt=p('<span class="stat stat-error svelte-1qbe2oo"> </span>'),qt=p('<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 Je(t,e){ze(e,!0);function s(d){const u=Math.floor(d/1e3);if(u<60)return`${u}s`;const i=Math.floor(u/60);return i<60?`${i}m ${u%60}s`:`${Math.floor(i/60)}h ${i%60}m`}function n(d){const u=d.replace(/\/$/,"").split("/");return u.length<=2?d:u.slice(-2).join("/")}const a=M(()=>e.card.status==="running"&&e.card.isActive?"var(--ds-green-700)":e.card.status==="running"?"var(--ds-blue-700)":e.card.status==="idle"?"var(--ds-amber-700)":e.card.status==="error"?"var(--ds-red-700)":"var(--ds-gray-600)"),o=M(()=>e.card.status==="running"&&e.card.isActive||e.card.status==="running"?"● Running":e.card.status==="idle"?"◎ Idle":e.card.status==="exited"?"○ Done":e.card.status==="error"?"✕ Error":e.card.status),S=M(()=>e.card.status==="running"&&e.card.isActive?"status-pill status-pill--running-active":e.card.status==="running"?"status-pill status-pill--running":e.card.status==="idle"?"status-pill status-pill--idle":e.card.status==="exited"?"status-pill status-pill--exited":e.card.status==="error"?"status-pill status-pill--error":"status-pill"),y=M(()=>e.card.toolCallCount===0?"Waiting for activity…":e.card.toolCallCount===1?"1 tool call so far":`${e.card.toolCallCount} tool calls so far`);function E(d){(d.key==="Enter"||d.key===" ")&&(d.key===" "&&d.preventDefault(),e.onclick?.())}var b=qt(),g=c(b),f=c(g),x=c(f,!0);l(f);var k=v(f,2);tt(k,{get text(){return r(o)},get classes(){return r(S)}}),l(g);var T=v(g,2);{var Se=d=>{var u=Rt(),i=c(u,!0);l(u),B(()=>C(i,e.card.goal)),h(d,u)};D(T,d=>{e.card.goal&&d(Se)})}var $=v(T,2),ye=c($);{var be=d=>{var u=zt();h(d,u)},ee=d=>{var u=jt(),i=c(u,!0);l(u),B(()=>C(i,e.card.summary)),h(d,u)},te=d=>{var u=Lt(),i=c(u,!0);l(u),B(()=>C(i,r(y))),h(d,u)};D(ye,d=>{e.card.isSummarizing?d(be):e.card.summary?d(ee,1):e.card.status==="running"&&d(te,2)})}l($);var W=v($,2),F=c(W),ae=c(F),we=v(ae);l(F);var se=v(F,2),Ce=c(se);l(se);var re=v(se,2);{var xe=d=>{var u=Mt(),i=c(u);l(u),B(()=>C(i,`${e.card.errorCount??""} errors`)),h(d,u)};D(re,d=>{e.card.errorCount>0&&d(xe)})}var oe=v(re,2),ke=c(oe,!0);l(oe),l(W),l(b),B((d,u)=>{pt(b,`--status-color: ${r(a)??""}`),Re(b,"aria-label",`Open ${e.card.projectName??""} session`),C(x,e.card.projectName),_t(ae,1,St(e.card.status==="running"&&e.card.isActive?"status-dot-active":"status-dot-static"),"svelte-1qbe2oo"),C(we,` ${d??""}`),C(Ce,`${e.card.toolCallCount??""} tools`),Re(oe,"title",e.card.cwd),C(ke,u)},[()=>s(e.card.duration),()=>n(e.card.cwd)]),Fe("click",b,function(...d){e.onclick?.apply(this,d)}),Fe("keydown",b,E),h(t,b),je()}vt(["click","keydown"]);var Bt=p('<div class="section svelte-14sxgtb"><h3 class="section-label svelte-14sxgtb">Active</h3> <!></div>'),Kt=p('<div class="section svelte-14sxgtb"><h3 class="section-label svelte-14sxgtb">Recent</h3> <!></div>'),Yt=p("<!> <!>",1);function Ft(t,e){ze(e,!0);const s=M(()=>e.cards.filter(g=>g.status==="running")),n=M(()=>e.cards.filter(g=>g.status!=="running"));function a(g){e.onCardClick?.(g)}var o=Yt(),S=me(o);{var y=g=>{var f=Bt(),x=v(c(f),2);de(x,17,()=>r(s),k=>k.terminalId,(k,T)=>{Je(k,{get card(){return r(T)},onclick:()=>{a(r(T))}})}),l(f),h(g,f)};D(S,g=>{r(s).length>0&&g(y)})}var E=v(S,2);{var b=g=>{var f=Kt(),x=v(c(f),2);de(x,17,()=>r(n),k=>k.terminalId,(k,T)=>{Je(k,{get card(){return r(T)},onclick:()=>{a(r(T))}})}),l(f),h(g,f)};D(E,g=>{r(n).length>0&&g(b)})}h(t,o),je()}const Gt=new Set(["agent-question","terminal-exited","tool-failed"]);let fe=null,ge=null,he=null;class Ut{async summarize(e){const s=this.chooseTone(e),n=s==="conversational"?this.buildConversationalPrompt(e):this.buildStatusReportPrompt(e);try{const a=await Vt();if(!a)return console.log("[SessionSummarizer] NeuroLink not available, using fallback."),{generatedAt:new Date().toISOString(),text:this.fallbackText(e),tone:s};const o=await a.generate({input:{text:n},...he?{model:he.model,provider:he.provider}:{}}),S=Ht(o.content??"").trim()||this.fallbackText(e);return{generatedAt:new Date().toISOString(),text:S,tone:s}}catch(a){return console.warn("[SessionSummarizer] summarize failed:",a instanceof Error?a.message:String(a)),{generatedAt:new Date().toISOString(),text:this.fallbackText(e),tone:s}}}buildConversationalPrompt(e){const s=e.goal??"unknown",n=e.recentEvents.map(a=>{const o=[a.type];return a.tool&&o.push(`tool=${a.tool}`),a.error&&o.push(`error=${a.error}`),a.command&&o.push(`command=${a.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.
1
+ import{d as vt,i as T,s as C,b as Fe,a as h,f as p}from"../chunks/BPDiEZo0.js";import{p as ze,c,r as l,d as v,g as r,t as B,w as je,x as M,A as me,s as q,q as et,b as _,v as ft,y as gt,D as mt,$ as ht,B as Ge}from"../chunks/DWmC0QM7.js";import{P as tt,k as pt,d as Re,s as _t,g as St,e as de,j as Le,B as De,c as Te,b as yt,i as Ue}from"../chunks/ZS5XYDx_.js";import{h as bt}from"../chunks/2rBV5OkJ.js";import{g as Ve}from"../chunks/C_YNQL8b.js";import{B as wt}from"../chunks/Bn-6X1BO.js";import{R as Ct,S as We}from"../chunks/BvmdJful.js";import{S as xt}from"../chunks/CG453M9q.js";import{c as kt,s as At,g as Et}from"../chunks/xs1Xl3_e.js";import{i as Nt}from"../chunks/gQJcRhou.js";import"../chunks/BDcFu3l7.js";import{f as It}from"../chunks/BLszSzTT.js";import{S as Pt}from"../chunks/BcpydfqI.js";import{i as Dt,N as Tt}from"../chunks/CRkG7oE4.js";import{d as Ot}from"../chunks/pRcLbE0d.js";import{E as He}from"../chunks/ClIPTXf3.js";var Rt=p('<p class="goal-text svelte-1qbe2oo"> </p>'),zt=p('<span class="summarizing svelte-1qbe2oo">Analyzing…</span>'),jt=p('<span class="summary-text svelte-1qbe2oo"> </span>'),Lt=p('<span class="summary-fallback svelte-1qbe2oo"> </span>'),Mt=p('<span class="stat stat-error svelte-1qbe2oo"> </span>'),qt=p('<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 Je(t,e){ze(e,!0);function s(d){const u=Math.floor(d/1e3);if(u<60)return`${u}s`;const i=Math.floor(u/60);return i<60?`${i}m ${u%60}s`:`${Math.floor(i/60)}h ${i%60}m`}function n(d){const u=d.replace(/\/$/,"").split("/");return u.length<=2?d:u.slice(-2).join("/")}const a=M(()=>e.card.status==="running"&&e.card.isActive?"var(--ds-green-700)":e.card.status==="running"?"var(--ds-blue-700)":e.card.status==="idle"?"var(--ds-amber-700)":e.card.status==="error"?"var(--ds-red-700)":"var(--ds-gray-600)"),o=M(()=>e.card.status==="running"&&e.card.isActive||e.card.status==="running"?"● Running":e.card.status==="idle"?"◎ Idle":e.card.status==="exited"?"○ Done":e.card.status==="error"?"✕ Error":e.card.status),S=M(()=>e.card.status==="running"&&e.card.isActive?"status-pill status-pill--running-active":e.card.status==="running"?"status-pill status-pill--running":e.card.status==="idle"?"status-pill status-pill--idle":e.card.status==="exited"?"status-pill status-pill--exited":e.card.status==="error"?"status-pill status-pill--error":"status-pill"),y=M(()=>e.card.toolCallCount===0?"Waiting for activity…":e.card.toolCallCount===1?"1 tool call so far":`${e.card.toolCallCount} tool calls so far`);function E(d){(d.key==="Enter"||d.key===" ")&&(d.key===" "&&d.preventDefault(),e.onclick?.())}var b=qt(),g=c(b),f=c(g),x=c(f,!0);l(f);var k=v(f,2);tt(k,{get text(){return r(o)},get classes(){return r(S)}}),l(g);var D=v(g,2);{var Se=d=>{var u=Rt(),i=c(u,!0);l(u),B(()=>C(i,e.card.goal)),h(d,u)};T(D,d=>{e.card.goal&&d(Se)})}var $=v(D,2),ye=c($);{var be=d=>{var u=zt();h(d,u)},ee=d=>{var u=jt(),i=c(u,!0);l(u),B(()=>C(i,e.card.summary)),h(d,u)},te=d=>{var u=Lt(),i=c(u,!0);l(u),B(()=>C(i,r(y))),h(d,u)};T(ye,d=>{e.card.isSummarizing?d(be):e.card.summary?d(ee,1):e.card.status==="running"&&d(te,2)})}l($);var W=v($,2),F=c(W),ae=c(F),we=v(ae);l(F);var se=v(F,2),Ce=c(se);l(se);var re=v(se,2);{var xe=d=>{var u=Mt(),i=c(u);l(u),B(()=>C(i,`${e.card.errorCount??""} errors`)),h(d,u)};T(re,d=>{e.card.errorCount>0&&d(xe)})}var oe=v(re,2),ke=c(oe,!0);l(oe),l(W),l(b),B((d,u)=>{pt(b,`--status-color: ${r(a)??""}`),Re(b,"aria-label",`Open ${e.card.projectName??""} session`),C(x,e.card.projectName),_t(ae,1,St(e.card.status==="running"&&e.card.isActive?"status-dot-active":"status-dot-static"),"svelte-1qbe2oo"),C(we,` ${d??""}`),C(Ce,`${e.card.toolCallCount??""} tools`),Re(oe,"title",e.card.cwd),C(ke,u)},[()=>s(e.card.duration),()=>n(e.card.cwd)]),Fe("click",b,function(...d){e.onclick?.apply(this,d)}),Fe("keydown",b,E),h(t,b),je()}vt(["click","keydown"]);var Bt=p('<div class="section svelte-14sxgtb"><h3 class="section-label svelte-14sxgtb">Active</h3> <!></div>'),Kt=p('<div class="section svelte-14sxgtb"><h3 class="section-label svelte-14sxgtb">Recent</h3> <!></div>'),Yt=p("<!> <!>",1);function Ft(t,e){ze(e,!0);const s=M(()=>e.cards.filter(g=>g.status==="running")),n=M(()=>e.cards.filter(g=>g.status!=="running"));function a(g){e.onCardClick?.(g)}var o=Yt(),S=me(o);{var y=g=>{var f=Bt(),x=v(c(f),2);de(x,17,()=>r(s),k=>k.terminalId,(k,D)=>{Je(k,{get card(){return r(D)},onclick:()=>{a(r(D))}})}),l(f),h(g,f)};T(S,g=>{r(s).length>0&&g(y)})}var E=v(S,2);{var b=g=>{var f=Kt(),x=v(c(f),2);de(x,17,()=>r(n),k=>k.terminalId,(k,D)=>{Je(k,{get card(){return r(D)},onclick:()=>{a(r(D))}})}),l(f),h(g,f)};T(E,g=>{r(n).length>0&&g(b)})}h(t,o),je()}const Gt=new Set(["agent-question","terminal-exited","tool-failed"]);let fe=null,ge=null,he=null;class Ut{async summarize(e){const s=this.chooseTone(e),n=s==="conversational"?this.buildConversationalPrompt(e):this.buildStatusReportPrompt(e);try{const a=await Vt();if(!a)return console.log("[SessionSummarizer] NeuroLink not available, using fallback."),{generatedAt:new Date().toISOString(),text:this.fallbackText(e),tone:s};const o=await a.generate({input:{text:n},...he?{model:he.model,provider:he.provider}:{}}),S=Ht(o.content??"").trim()||this.fallbackText(e);return{generatedAt:new Date().toISOString(),text:S,tone:s}}catch(a){return console.warn("[SessionSummarizer] summarize failed:",a instanceof Error?a.message:String(a)),{generatedAt:new Date().toISOString(),text:this.fallbackText(e),tone:s}}}buildConversationalPrompt(e){const s=e.goal??"unknown",n=e.recentEvents.map(a=>{const o=[a.type];return a.tool&&o.push(`tool=${a.tool}`),a.error&&o.push(`error=${a.error}`),a.command&&o.push(`command=${a.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.
2
2
 
3
3
  Goal: ${s}
4
4
  Recent events: ${n}
@@ -10,4 +10,4 @@ One sentence only, no quotes, no markdown.`}buildStatusReportPrompt(e){return`Yo
10
10
  Recent tool calls: ${e.recentEvents.flatMap(n=>n.tool?[n.tool]:[]).join(", ")||"none"}
11
11
  Status: ${e.status}
12
12
 
13
- Short phrase only, no quotes.`}chooseTone(e){return e.status==="error"||e.errorCount>0||e.recentEvents.some(n=>Gt.has(n.type))?"conversational":"status-report"}fallbackText(e){const s=e.recentEvents.flatMap(a=>a.tool?[a.tool]:[]),n=[...new Set(s)];return n.length>0?`Running: ${n.join(", ")} (${e.toolCallCount} tools)`:`Status: ${e.status} — ${e.toolCallCount} tool calls`}}async function Vt(){if(ge)return ge;Tt();const e=(await Wt()).NeuroLink;if(!e)return null;const s=window.__aiProviders,n=window.process?.env?.NEUROLINK_PROVIDER,a=Ot(s,n);if(!a)return console.warn("[SessionSummarizer] No AI provider configured"),null;const o=window.process;return o?.env&&s&&(s["google-ai"]&&!o.env.GOOGLE_AI_API_KEY&&(o.env.GOOGLE_AI_API_KEY="proxy-via-server"),s.anthropic&&!o.env.ANTHROPIC_API_KEY&&(o.env.ANTHROPIC_API_KEY="proxy-via-server"),s.openai&&!o.env.OPENAI_API_KEY&&(o.env.OPENAI_API_KEY="proxy-via-server"),s.mistral&&!o.env.MISTRAL_API_KEY&&(o.env.MISTRAL_API_KEY="proxy-via-server")),ge=new e({provider:a.provider}),he=a,console.log(`[SessionSummarizer] Using provider: ${a.provider}/${a.model}`),ge}function Wt(){return fe||(fe=import(Dt).catch(t=>{throw console.warn("[SessionSummarizer] Failed to load NeuroLink SDK:",t),fe=null,t})),fe}function Ht(t){return typeof t=="string"?t:typeof t=="number"||typeof t=="boolean"?String(t):""}function Me(){return new Date(Date.now()).toISOString()}const Jt=100,Xt=15e3,Zt=3e4,at=2e3,Qt=3e4;let j=q(et([])),ce=q(!1),R=null,Z=null,Q=null,pe=at,$t=0,K="";const ve=new Le,Y=new Le,_e=new Pt;async function ea(t){K=t||ra(),K&&(await Qe(K),await rt(K),Z&&clearInterval(Z),Z=setInterval(()=>{Qe(K)},Xt))}function ta(){R&&(R.onclose=null,R.close(),R=null),Z&&(clearInterval(Z),Z=null),Q&&(clearTimeout(Q),Q=null);for(const[,t]of Y)t.onclose=null,t.close();Y.clear(),_e.clear(),ve.clear(),_(ce,!1),K=""}function aa(){const t=Date.now();return qe(r(j)).map(e=>{const s=Date.parse(e.createdAt),n=e.events.length>0?Date.parse(e.events[e.events.length-1].timestamp):0;return{...e,duration:t-s,goal:e.goal,isActive:n>0&&t-n<Zt,isSummarizing:e.isSummarizing,summary:e.summary}})}function Xe(t,e){const s=r(j).find(n=>n.terminalId===t);s&&(s.goal=e)}function sa(t,e){const s=r(j).find(n=>n.terminalId===t);s&&(s.summary=e,s.summaryUpdatedAt=Me(),s.isSummarizing=!1)}function X(t,e,s){const n={data:s,id:`evt-${++$t}`,summarized:!1,terminalId:t.terminalId,timestamp:s.timestamp??Me(),type:e},a=t.events.length>=Jt?[...t.events.slice(1),n]:[...t.events,n];t.events=a,t.eventCount+=1}function st(t){return t.split("/").filter(Boolean).pop()??t}function ue(t){const e=Y.get(t);e&&(e.onclose=null,e.close(),Y.delete(t))}async function rt(t){if(!(R&&R.readyState<=1))try{const e=await fetch("/api/ws-ticket",{headers:{Authorization:`Bearer ${t}`},method:"POST"});if(!e.ok){Oe(t);return}const{ticket:s}=await e.json(),n=window.location.origin.replace(/^http/,"ws");R=new WebSocket(`${n}/ws/events?ticket=${s}`),R.onopen=()=>{_(ce,!0),pe=at},R.onmessage=a=>{try{const o=JSON.parse(a.data);o&&typeof o=="object"&&oa(o)}catch{}},R.onclose=()=>{_(ce,!1),R=null,Oe(t)},R.onerror=()=>{_(ce,!1)}}catch{_(ce,!1),Oe(t)}}function Ze(t){let e="";return typeof t=="string"?e=t:Array.isArray(t)&&(e=t.find(n=>n.type==="text")?.content??""),e.slice(0,200).trim()}async function Qe(t){if(t)try{const e=await fetch("/api/terminals",{headers:{Authorization:`Bearer ${t}`}});if(!e.ok)return;const n=(await e.json()).terminals??[];_(j,qe(ia(r(j),n)),!0)}catch{}}function ra(){try{const t=localStorage.getItem("shooter_config");if(!t)return"";const e=JSON.parse(t);if(e&&typeof e=="object"){const s=e;if(typeof s.apiKey=="string")return s.apiKey}}catch{}return""}function oa(t){const e=t.type;if(!e||e==="welcome")return;const s=t.terminalId??null;if(!s)return;const n=r(j).findIndex(S=>S.terminalId===s);if(n===-1)return;const a=r(j)[n];switch(e){case"agent-idle":case"agent-question":{a.status="idle",X(a,e,t);break}case"terminal-exited":{a.status="exited",a.exitedAt=t.exitedAt??Me(),X(a,e,t),ue(s),ve.delete(s);break}case"tool-completed":{X(a,e,t);break}case"tool-failed":{a.errorCount+=1,X(a,e,t);break}case"tool-started":{a.toolCallCount+=1,a.status="running",X(a,e,t);break}default:{X(a,e,t);break}}(e==="tool-failed"||e==="agent-question"||a.errorCount>=3||a.eventCount>0&&a.eventCount%20===0)&&!a.isSummarizing&&la(a),_(j,qe(r(j)),!0)}function na(t){return{command:t.command,createdAt:t.createdAt,cwd:t.cwd,errorCount:0,eventCount:0,events:[],exitedAt:t.exitedAt,goal:"",isSummarizing:!1,projectName:st(t.cwd),projectPath:t.cwd,status:ot(t.status),summary:"",summaryUpdatedAt:"",terminalId:t.id,toolCallCount:0}}function ot(t){return t==="running"?"running":t==="idle"?"idle":t==="exited"?"exited":"error"}function ia(t,e){const s=new Set(e.map(a=>a.id));for(const a of t)s.has(a.terminalId)||(ue(a.terminalId),ve.delete(a.terminalId));const n=new Le;for(const a of t)s.has(a.terminalId)&&n.set(a.terminalId,a);for(const a of e){const o=n.get(a.id);o?(o.command=a.command,o.cwd=a.cwd,o.projectName=st(a.cwd),o.projectPath=a.cwd,o.exitedAt=a.exitedAt,o.status!=="error"&&(o.status=ot(a.status)),o.goal||$e(a.id)):(n.set(a.id,na(a)),$e(a.id))}return Array.from(n.values())}async function $e(t){if(K&&!(Y.has(t)||_e.has(t))){_e.add(t),console.log(`[DashboardStore] Opening session socket for ${t}`);try{const e=await fetch("/api/ws-ticket",{headers:{Authorization:`Bearer ${K}`},method:"POST"});if(!e.ok){console.warn(`[DashboardStore] Failed to get WS ticket for ${t}:`,e.status);return}const{ticket:s}=await e.json(),a=`${window.location.origin.replace(/^http/,"ws")}/ws/session/${t}?ticket=${s}`;console.log(`[DashboardStore] Connecting session socket for ${t}`);const o=new WebSocket(a);Y.set(t,o),o.onopen=()=>{console.log(`[DashboardStore] Session socket opened for ${t}`)},o.onmessage=S=>{try{const y=JSON.parse(S.data);if(!y||typeof y!="object")return;const E=y,b=r(j).find(f=>f.terminalId===t),g=b?.goal&&b.goal.length>0;if(E.type==="history"){console.log(`[DashboardStore] Received history for ${t}, extracting goal...`);const f=E.messages;if(!Array.isArray(f)){console.warn(`[DashboardStore] No messages array in history for ${t}`);return}console.log(`[DashboardStore] Found ${f.length} messages, looking for first user message...`);for(const x of f)if(x.role==="user"){const k=Ze(x.content);console.log(`[DashboardStore] Extracted goal for ${t}: "${k.substring(0,50)}..."`),k&&Xe(t,k),ue(t);return}console.log(`[DashboardStore] No user message found in history for ${t}`);return}if(E.type==="message"&&E.role==="user"&&!g){const f=Ze(E.content);f&&(console.log(`[DashboardStore] Extracted goal from message for ${t}: "${f.substring(0,50)}..."`),Xe(t,f),ue(t));return}if(!g)return;ue(t)}catch(y){console.warn("[DashboardStore] Error processing session message:",y)}},o.onclose=()=>{console.log(`[DashboardStore] Session socket closed for ${t}`),Y.delete(t)},o.onerror=S=>{console.warn(`[DashboardStore] Session socket error for ${t}:`,S),Y.delete(t)}}catch(e){console.warn("[DashboardStore] Failed to open session socket:",e)}finally{_e.delete(t)}}}function Oe(t){Q||(Q=setTimeout(()=>{Q=null,rt(t)},pe),pe=Math.min(pe*2,Qt))}function qe(t){return[...t].sort((e,s)=>{const n={error:2,exited:3,idle:1,running:0},a=n[e.status],o=n[s.status];if(a!==o)return a-o;if(e.status!=="exited"&&s.status!=="exited")return s.createdAt.localeCompare(e.createdAt);const S=e.exitedAt??e.createdAt;return(s.exitedAt??s.createdAt).localeCompare(S)})}function la(t){t.isSummarizing=!0;let e=ve.get(t.terminalId);e||(e=new Ut,ve.set(t.terminalId,e));const s=t.events.slice(-10).map(a=>({command:typeof a.data.command=="string"?a.data.command:null,error:typeof a.data.error=="string"?a.data.error:null,tool:typeof a.data.tool=="string"?a.data.tool:null,type:a.type})),n={conversationExcerpt:t.goal??"",errorCount:t.errorCount,goal:t.goal,recentEvents:s,status:t.status,toolCallCount:t.toolCallCount};(async()=>{try{const a=await e.summarize(n);sa(t.terminalId,a.text)}catch(a){console.error(`[dashboard] Summarization failed for ${t.terminalId}:`,a)}finally{t.isSummarizing=!1}})()}var ca=p('<meta name="description" content="Active terminals and Claude Code sessions"/>'),da=p("<!> Refresh",1),ua=p('<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>'),va=p('<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>'),fa=p('<div class="loading-container"></div>'),ga=p('<div class="dashboard-section svelte-1uha8ag"><!></div>'),ma=p('<div class="loading-container"></div>'),ha=p('<h3 class="section-label svelte-1uha8ag">Sessions</h3>'),pa=p('<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>'),_a=p('<div style="text-align: center; padding: 1rem;"><!></div>'),Sa=p('<!> <div class="projects-container svelte-1uha8ag"></div> <!>',1),ya=p("<!> <!>",1),ba=p('<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 Ma(t,e){ze(e,!0);const s=1e4,n=20;let a=q(et([])),o=q(!1),S=!1,y=q(null),E=null,b=q(null),g=q(!1),f=q(0);const x=M(aa);ft(()=>{k();const i=Et("shooter_projects");i&&(_(a,i,!0),_(o,!1)),T(),E=setInterval(()=>{r(y)?.apiKey&&r(f)<=n&&T()},s)}),gt(()=>{E&&(clearInterval(E),E=null),ta()});function k(){try{const i=localStorage.getItem("shooter_config");if(i){const m=JSON.parse(i);Nt(m)?(_(y,m,!0),ea(r(y).apiKey)):(localStorage.removeItem("shooter_config"),_(y,null))}}catch{}}async function T(i=!1,m=!1){if(!r(y)?.apiKey||S)return;S=!0,r(a).length===0&&_(o,!0);const w=i?r(f):0;try{const G=await fetch(`${m?"/api/sessions?refresh=true&":"/api/sessions?"}limit=${n}&offset=${w}`,{headers:{Authorization:`Bearer ${r(y).apiKey}`}});if(!G.ok){_(b,`Failed to load projects (HTTP ${G.status})`);return}_(b,null);const L=await G.json();i?_(a,[...r(a),...L.projects],!0):_(a,L.projects,!0),_(f,r(a).length,!0),_(g,L.total!==void 0?r(a).length<L.total:!1,!0),At("shooter_projects",r(a))}catch(O){_(b,"Failed to load projects"),console.error("Failed to fetch sessions:",O)}finally{_(o,!1),S=!1}}async function Se(){await T(!0)}async function $(){_(o,!0),kt("shooter_projects"),await T(!1,!0)}function ye(){Ve("/config")}function be(i){Ve(`/terminals/${i}`)}function ee(){return r(a).reduce((i,m)=>i+m.sessionCount,0)}var te=ba();bt("1uha8ag",i=>{var m=ca();mt(()=>{ht.title="Dashboard - Shooter"}),h(i,m)});var W=c(te),F=c(W),ae=v(c(F),2),we=c(ae);Te(we,{classes:"btn-secondary",onclick:$,get disabled(){return r(o)},children:(i,m)=>{var w=da(),O=me(w);De(O,{get svg(){return Ct},classes:"icon-14"}),Ge(),h(i,w)},$$slots:{default:!0}}),l(ae),l(F);var se=v(F,2);{var Ce=i=>{var m=va(),w=c(m),O=c(w),G=c(O,!0);l(O);var L=v(O,2),Ae=c(L,!0);l(L),l(w);var ne=v(w,2),ie=c(ne),A=c(ie,!0);l(ie);var N=v(ie,2),z=c(N,!0);l(N),l(ne);var H=v(ne,2);{var le=U=>{var V=ua(),I=c(V),P=c(I,!0);l(I),Ge(2),l(V),B(()=>C(P,r(x).length)),h(U,V)};D(H,U=>{r(x).length>0&&U(le)})}l(m),B((U,V)=>{C(G,r(a).length),C(Ae,r(a).length===1?"project":"projects"),C(A,U),C(z,V)},[()=>ee(),()=>ee()===1?"session":"sessions"]),h(i,m)};D(se,i=>{r(a).length>0&&i(Ce)})}l(W);var re=v(W,2);{var xe=i=>{yt(i,{get text(){return r(b)},classes:"banner-error"})};D(re,i=>{r(b)&&i(xe)})}var oe=v(re,2);{var ke=i=>{var m=fa();de(m,20,()=>Array(3),Ue,(w,O)=>{We(w,{classes:"shimmer-card"})}),l(m),h(i,m)},d=i=>{He(i,{title:"Configuration Required",description:"Set up your API credentials to start tracking sessions",icon:w=>{De(w,{get svg(){return xt},classes:"icon-24"})},children:(w,O)=>{Te(w,{classes:"btn-primary",onclick:ye,text:"Configure Settings"})}})},u=i=>{var m=ya(),w=me(m);{var O=A=>{var N=ga(),z=c(N);Ft(z,{get cards(){return r(x)},onCardClick:H=>{be(H.terminalId)}}),l(N),h(A,N)};D(w,A=>{r(x).length>0&&A(O)})}var G=v(w,2);{var L=A=>{var N=ma();de(N,20,()=>Array(3),Ue,(z,H)=>{We(z,{classes:"shimmer-card"})}),l(N),h(A,N)},Ae=A=>{He(A,{title:"No sessions yet",description:"Claude Code sessions will appear here once JSONL files are found",icon:z=>{De(z,{get svg(){return wt},classes:"icon-24"})}})},ne=M(()=>ee()===0&&r(x).length===0),ie=A=>{var N=Sa(),z=me(N);{var H=I=>{var P=ha();h(I,P)};D(z,I=>{r(x).length>0&&I(H)})}var le=v(z,2);de(le,21,()=>r(a),I=>I.id,(I,P)=>{var J=pa(),Ee=c(J),Ne=c(Ee),Ie=c(Ne),nt=c(Ie,!0);l(Ie);var Be=v(Ie,2),it=c(Be,!0);l(Be),l(Ne);var lt=v(Ne,2);{let ut=M(()=>It(r(P).lastModified));tt(lt,{get text(){return`Last updated ${r(ut)??""}`},classes:"pill-session-time"})}l(Ee);var Ke=v(Ee,2),Ye=c(Ke),Pe=c(Ye),ct=c(Pe,!0);l(Pe);var dt=v(Pe);l(Ye),l(Ke),l(J),B(()=>{Re(J,"href",`/project?id=${r(P).id??""}`),C(nt,r(P).name),C(it,r(P).fullPath),C(ct,r(P).sessionCount),C(dt,` ${r(P).sessionCount===1?"session":"sessions"}`)}),h(I,J)}),l(le);var U=v(le,2);{var V=I=>{var P=_a(),J=c(P);Te(J,{classes:"btn-secondary",onclick:Se,text:"Load More"}),l(P),h(I,P)};D(U,I=>{r(g)&&I(V)})}h(A,N)};D(G,A=>{r(o)&&r(a).length===0?A(L):r(ne)?A(Ae,1):r(a).length>0&&A(ie,2)})}h(i,m)};D(oe,i=>{r(o)&&r(a).length===0&&r(x).length===0?i(ke):r(y)?.apiKey?i(u,-1):i(d,1)})}l(te),h(t,te),je()}export{Ma as component};
13
+ Short phrase only, no quotes.`}chooseTone(e){return e.status==="error"||e.errorCount>0||e.recentEvents.some(n=>Gt.has(n.type))?"conversational":"status-report"}fallbackText(e){const s=e.recentEvents.flatMap(a=>a.tool?[a.tool]:[]),n=[...new Set(s)];return n.length>0?`Running: ${n.join(", ")} (${e.toolCallCount} tools)`:`Status: ${e.status} — ${e.toolCallCount} tool calls`}}async function Vt(){if(ge)return ge;Dt();const e=(await Wt()).NeuroLink;if(!e)return null;const s=window.__aiProviders,n=window.process?.env?.NEUROLINK_PROVIDER,a=Ot(s,n);if(!a)return console.warn("[SessionSummarizer] No AI provider configured"),null;const o=window.process;return o?.env&&s&&(s["google-ai"]&&!o.env.GOOGLE_AI_API_KEY&&(o.env.GOOGLE_AI_API_KEY="proxy-via-server"),s.anthropic&&!o.env.ANTHROPIC_API_KEY&&(o.env.ANTHROPIC_API_KEY="proxy-via-server"),s.openai&&!o.env.OPENAI_API_KEY&&(o.env.OPENAI_API_KEY="proxy-via-server"),s.mistral&&!o.env.MISTRAL_API_KEY&&(o.env.MISTRAL_API_KEY="proxy-via-server")),ge=new e({provider:a.provider}),he=a,console.log(`[SessionSummarizer] Using provider: ${a.provider}/${a.model}`),ge}function Wt(){return fe||(fe=import(Tt).catch(t=>{throw console.warn("[SessionSummarizer] Failed to load NeuroLink SDK:",t),fe=null,t})),fe}function Ht(t){return typeof t=="string"?t:typeof t=="number"||typeof t=="boolean"?String(t):""}function Me(){return new Date(Date.now()).toISOString()}const Jt=100,Xt=15e3,Zt=3e4,at=2e3,Qt=3e4;let j=q(et([])),ce=q(!1),R=null,Z=null,Q=null,pe=at,$t=0,K="";const ve=new Le,Y=new Le,_e=new Pt;async function ea(t){K=t||ra(),K&&(await Qe(K),await rt(K),Z&&clearInterval(Z),Z=setInterval(()=>{Qe(K)},Xt))}function ta(){R&&(R.onclose=null,R.close(),R=null),Z&&(clearInterval(Z),Z=null),Q&&(clearTimeout(Q),Q=null);for(const[,t]of Y)t.onclose=null,t.close();Y.clear(),_e.clear(),ve.clear(),_(ce,!1),K=""}function aa(){const t=Date.now();return qe(r(j)).map(e=>{const s=Date.parse(e.createdAt),n=e.events.length>0?Date.parse(e.events[e.events.length-1].timestamp):0;return{...e,duration:t-s,goal:e.goal,isActive:n>0&&t-n<Zt,isSummarizing:e.isSummarizing,summary:e.summary}})}function Xe(t,e){const s=r(j).find(n=>n.terminalId===t);s&&(s.goal=e)}function sa(t,e){const s=r(j).find(n=>n.terminalId===t);s&&(s.summary=e,s.summaryUpdatedAt=Me(),s.isSummarizing=!1)}function X(t,e,s){const n={data:s,id:`evt-${++$t}`,summarized:!1,terminalId:t.terminalId,timestamp:s.timestamp??Me(),type:e},a=t.events.length>=Jt?[...t.events.slice(1),n]:[...t.events,n];t.events=a,t.eventCount+=1}function st(t){return t.split("/").filter(Boolean).pop()??t}function ue(t){const e=Y.get(t);e&&(e.onclose=null,e.close(),Y.delete(t))}async function rt(t){if(!(R&&R.readyState<=1))try{const e=await fetch("/api/ws-ticket",{headers:{Authorization:`Bearer ${t}`},method:"POST"});if(!e.ok){Oe(t);return}const{ticket:s}=await e.json(),n=window.location.origin.replace(/^http/,"ws");R=new WebSocket(`${n}/ws/events?ticket=${s}`),R.onopen=()=>{_(ce,!0),pe=at},R.onmessage=a=>{try{const o=JSON.parse(a.data);o&&typeof o=="object"&&oa(o)}catch{}},R.onclose=()=>{_(ce,!1),R=null,Oe(t)},R.onerror=()=>{_(ce,!1)}}catch{_(ce,!1),Oe(t)}}function Ze(t){let e="";return typeof t=="string"?e=t:Array.isArray(t)&&(e=t.find(n=>n.type==="text")?.content??""),e.slice(0,200).trim()}async function Qe(t){if(t)try{const e=await fetch("/api/terminals",{headers:{Authorization:`Bearer ${t}`}});if(!e.ok)return;const n=(await e.json()).terminals??[];_(j,qe(ia(r(j),n)),!0)}catch{}}function ra(){try{const t=localStorage.getItem("shooter_config");if(!t)return"";const e=JSON.parse(t);if(e&&typeof e=="object"){const s=e;if(typeof s.apiKey=="string")return s.apiKey}}catch{}return""}function oa(t){const e=t.type;if(!e||e==="welcome")return;const s=t.terminalId??null;if(!s)return;const n=r(j).findIndex(S=>S.terminalId===s);if(n===-1)return;const a=r(j)[n];switch(e){case"agent-idle":case"agent-question":{a.status="idle",X(a,e,t);break}case"terminal-exited":{a.status="exited",a.exitedAt=t.exitedAt??Me(),X(a,e,t),ue(s),ve.delete(s);break}case"tool-completed":{X(a,e,t);break}case"tool-failed":{a.errorCount+=1,X(a,e,t);break}case"tool-started":{a.toolCallCount+=1,a.status="running",X(a,e,t);break}default:{X(a,e,t);break}}(e==="tool-failed"||e==="agent-question"||a.errorCount>=3||a.eventCount>0&&a.eventCount%20===0)&&!a.isSummarizing&&la(a),_(j,qe(r(j)),!0)}function na(t){return{command:t.command,createdAt:t.createdAt,cwd:t.cwd,errorCount:0,eventCount:0,events:[],exitedAt:t.exitedAt,goal:"",isSummarizing:!1,projectName:st(t.cwd),projectPath:t.cwd,status:ot(t.status),summary:"",summaryUpdatedAt:"",terminalId:t.id,toolCallCount:0}}function ot(t){return t==="running"?"running":t==="idle"?"idle":t==="exited"?"exited":"error"}function ia(t,e){const s=new Set(e.map(a=>a.id));for(const a of t)s.has(a.terminalId)||(ue(a.terminalId),ve.delete(a.terminalId));const n=new Le;for(const a of t)s.has(a.terminalId)&&n.set(a.terminalId,a);for(const a of e){const o=n.get(a.id);o?(o.command=a.command,o.cwd=a.cwd,o.projectName=st(a.cwd),o.projectPath=a.cwd,o.exitedAt=a.exitedAt,o.status!=="error"&&(o.status=ot(a.status)),o.goal||$e(a.id)):(n.set(a.id,na(a)),$e(a.id))}return Array.from(n.values())}async function $e(t){if(K&&!(Y.has(t)||_e.has(t))){_e.add(t),console.log(`[DashboardStore] Opening session socket for ${t}`);try{const e=await fetch("/api/ws-ticket",{headers:{Authorization:`Bearer ${K}`},method:"POST"});if(!e.ok){console.warn(`[DashboardStore] Failed to get WS ticket for ${t}:`,e.status);return}const{ticket:s}=await e.json(),a=`${window.location.origin.replace(/^http/,"ws")}/ws/session/${t}?ticket=${s}`;console.log(`[DashboardStore] Connecting session socket for ${t}`);const o=new WebSocket(a);Y.set(t,o),o.onopen=()=>{console.log(`[DashboardStore] Session socket opened for ${t}`)},o.onmessage=S=>{try{const y=JSON.parse(S.data);if(!y||typeof y!="object")return;const E=y,b=r(j).find(f=>f.terminalId===t),g=b?.goal&&b.goal.length>0;if(E.type==="history"){console.log(`[DashboardStore] Received history for ${t}, extracting goal...`);const f=E.messages;if(!Array.isArray(f)){console.warn(`[DashboardStore] No messages array in history for ${t}`);return}console.log(`[DashboardStore] Found ${f.length} messages, looking for first user message...`);for(const x of f)if(x.role==="user"){const k=Ze(x.content);console.log(`[DashboardStore] Extracted goal for ${t}: "${k.substring(0,50)}..."`),k&&Xe(t,k),ue(t);return}console.log(`[DashboardStore] No user message found in history for ${t}`);return}if(E.type==="message"&&E.role==="user"&&!g){const f=Ze(E.content);f&&(console.log(`[DashboardStore] Extracted goal from message for ${t}: "${f.substring(0,50)}..."`),Xe(t,f),ue(t));return}if(!g)return;ue(t)}catch(y){console.warn("[DashboardStore] Error processing session message:",y)}},o.onclose=()=>{console.log(`[DashboardStore] Session socket closed for ${t}`),Y.delete(t)},o.onerror=S=>{console.warn(`[DashboardStore] Session socket error for ${t}:`,S),Y.delete(t)}}catch(e){console.warn("[DashboardStore] Failed to open session socket:",e)}finally{_e.delete(t)}}}function Oe(t){Q||(Q=setTimeout(()=>{Q=null,rt(t)},pe),pe=Math.min(pe*2,Qt))}function qe(t){return[...t].sort((e,s)=>{const n={error:2,exited:3,idle:1,running:0},a=n[e.status],o=n[s.status];if(a!==o)return a-o;if(e.status!=="exited"&&s.status!=="exited")return s.createdAt.localeCompare(e.createdAt);const S=e.exitedAt??e.createdAt;return(s.exitedAt??s.createdAt).localeCompare(S)})}function la(t){t.isSummarizing=!0;let e=ve.get(t.terminalId);e||(e=new Ut,ve.set(t.terminalId,e));const s=t.events.slice(-10).map(a=>({command:typeof a.data.command=="string"?a.data.command:null,error:typeof a.data.error=="string"?a.data.error:null,tool:typeof a.data.tool=="string"?a.data.tool:null,type:a.type})),n={conversationExcerpt:t.goal??"",errorCount:t.errorCount,goal:t.goal,recentEvents:s,status:t.status,toolCallCount:t.toolCallCount};(async()=>{try{const a=await e.summarize(n);sa(t.terminalId,a.text)}catch(a){console.error(`[dashboard] Summarization failed for ${t.terminalId}:`,a)}finally{t.isSummarizing=!1}})()}var ca=p('<meta name="description" content="Active terminals and Claude Code sessions"/>'),da=p("<!> Refresh",1),ua=p('<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>'),va=p('<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>'),fa=p('<div class="loading-container"></div>'),ga=p('<div class="dashboard-section svelte-1uha8ag"><!></div>'),ma=p('<div class="loading-container"></div>'),ha=p('<h3 class="section-label svelte-1uha8ag">Sessions</h3>'),pa=p('<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>'),_a=p('<div style="text-align: center; padding: 1rem;"><!></div>'),Sa=p('<!> <div class="projects-container svelte-1uha8ag"></div> <!>',1),ya=p("<!> <!>",1),ba=p('<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 Ma(t,e){ze(e,!0);const s=1e4,n=20;let a=q(et([])),o=q(!1),S=!1,y=q(null),E=null,b=q(null),g=q(!1),f=q(0);const x=M(aa);ft(()=>{k();const i=Et("shooter_projects");i&&(_(a,i,!0),_(o,!1)),D(),E=setInterval(()=>{r(y)?.apiKey&&r(f)<=n&&D()},s)}),gt(()=>{E&&(clearInterval(E),E=null),ta()});function k(){try{const i=localStorage.getItem("shooter_config");if(i){const m=JSON.parse(i);Nt(m)?(_(y,m,!0),ea(r(y).apiKey)):(localStorage.removeItem("shooter_config"),_(y,null))}}catch{}}async function D(i=!1,m=!1){if(!r(y)?.apiKey||S)return;S=!0,r(a).length===0&&_(o,!0);const w=i?r(f):0;try{const G=await fetch(`${m?"/api/sessions?refresh=true&":"/api/sessions?"}limit=${n}&offset=${w}`,{headers:{Authorization:`Bearer ${r(y).apiKey}`}});if(!G.ok){_(b,`Failed to load projects (HTTP ${G.status})`);return}_(b,null);const L=await G.json();i?_(a,[...r(a),...L.projects],!0):_(a,L.projects,!0),_(f,r(a).length,!0),_(g,L.total!==void 0?r(a).length<L.total:!1,!0),At("shooter_projects",r(a))}catch(O){_(b,"Failed to load projects"),console.error("Failed to fetch sessions:",O)}finally{_(o,!1),S=!1}}async function Se(){await D(!0)}async function $(){_(o,!0),kt("shooter_projects"),await D(!1,!0)}function ye(){Ve("/config")}function be(i){Ve(`/terminals/${i}`)}function ee(){return r(a).reduce((i,m)=>i+m.sessionCount,0)}var te=ba();bt("1uha8ag",i=>{var m=ca();mt(()=>{ht.title="Dashboard - Shooter"}),h(i,m)});var W=c(te),F=c(W),ae=v(c(F),2),we=c(ae);De(we,{classes:"btn-secondary",onclick:$,get disabled(){return r(o)},children:(i,m)=>{var w=da(),O=me(w);Te(O,{get svg(){return Ct},classes:"icon-14"}),Ge(),h(i,w)},$$slots:{default:!0}}),l(ae),l(F);var se=v(F,2);{var Ce=i=>{var m=va(),w=c(m),O=c(w),G=c(O,!0);l(O);var L=v(O,2),Ae=c(L,!0);l(L),l(w);var ne=v(w,2),ie=c(ne),A=c(ie,!0);l(ie);var N=v(ie,2),z=c(N,!0);l(N),l(ne);var H=v(ne,2);{var le=U=>{var V=ua(),I=c(V),P=c(I,!0);l(I),Ge(2),l(V),B(()=>C(P,r(x).length)),h(U,V)};T(H,U=>{r(x).length>0&&U(le)})}l(m),B((U,V)=>{C(G,r(a).length),C(Ae,r(a).length===1?"project":"projects"),C(A,U),C(z,V)},[()=>ee(),()=>ee()===1?"session":"sessions"]),h(i,m)};T(se,i=>{r(a).length>0&&i(Ce)})}l(W);var re=v(W,2);{var xe=i=>{yt(i,{get text(){return r(b)},classes:"banner-error"})};T(re,i=>{r(b)&&i(xe)})}var oe=v(re,2);{var ke=i=>{var m=fa();de(m,20,()=>Array(3),Ue,(w,O)=>{We(w,{classes:"shimmer-card"})}),l(m),h(i,m)},d=i=>{He(i,{title:"Configuration Required",description:"Set up your API credentials to start tracking sessions",icon:w=>{Te(w,{get svg(){return xt},classes:"icon-24"})},children:(w,O)=>{De(w,{classes:"btn-primary",onclick:ye,text:"Configure Settings"})}})},u=i=>{var m=ya(),w=me(m);{var O=A=>{var N=ga(),z=c(N);Ft(z,{get cards(){return r(x)},onCardClick:H=>{be(H.terminalId)}}),l(N),h(A,N)};T(w,A=>{r(x).length>0&&A(O)})}var G=v(w,2);{var L=A=>{var N=ma();de(N,20,()=>Array(3),Ue,(z,H)=>{We(z,{classes:"shimmer-card"})}),l(N),h(A,N)},Ae=A=>{He(A,{title:"No sessions yet",description:"Claude Code sessions will appear here once JSONL files are found",icon:z=>{Te(z,{get svg(){return wt},classes:"icon-24"})}})},ne=M(()=>ee()===0&&r(x).length===0),ie=A=>{var N=Sa(),z=me(N);{var H=I=>{var P=ha();h(I,P)};T(z,I=>{r(x).length>0&&I(H)})}var le=v(z,2);de(le,21,()=>r(a),I=>I.id,(I,P)=>{var J=pa(),Ee=c(J),Ne=c(Ee),Ie=c(Ne),nt=c(Ie,!0);l(Ie);var Be=v(Ie,2),it=c(Be,!0);l(Be),l(Ne);var lt=v(Ne,2);{let ut=M(()=>It(r(P).lastModified));tt(lt,{get text(){return`Last updated ${r(ut)??""}`},classes:"pill-session-time"})}l(Ee);var Ke=v(Ee,2),Ye=c(Ke),Pe=c(Ye),ct=c(Pe,!0);l(Pe);var dt=v(Pe);l(Ye),l(Ke),l(J),B(()=>{Re(J,"href",`/project?id=${r(P).id??""}`),C(nt,r(P).name),C(it,r(P).fullPath),C(ct,r(P).sessionCount),C(dt,` ${r(P).sessionCount===1?"session":"sessions"}`)}),h(I,J)}),l(le);var U=v(le,2);{var V=I=>{var P=_a(),J=c(P);De(J,{classes:"btn-secondary",onclick:Se,text:"Load More"}),l(P),h(I,P)};T(U,I=>{r(g)&&I(V)})}h(A,N)};T(G,A=>{r(o)&&r(a).length===0?A(L):r(ne)?A(Ae,1):r(a).length>0&&A(ie,2)})}h(i,m)};T(oe,i=>{r(o)&&r(a).length===0&&r(x).length===0?i(ke):r(y)?.apiKey?i(u,-1):i(d,1)})}l(te),h(t,te),je()}export{Ma as component};
@@ -1,9 +1,9 @@
1
- import{i as P,s as h,a as g,t as Be,f as A}from"../chunks/Cg3dlX05.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,N as Ve,$ as We}from"../chunks/DYuMZGL5.js";import{h as Je}from"../chunks/DZQMsHM5.js";import{g as ce}from"../chunks/nWG9RHyB.js";import{j as ue,e as le,B as qe,s as Ae,b as Xe}from"../chunks/DZvnhU_8.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/C_9BZILB.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/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.
2
2
 
3
3
  ${t?`Project: ${t}
4
4
  `:""}Events:
5
5
  ${s}
6
6
 
7
7
  Summary:`;try{const o=await i.generate({input:{text:a},maxTokens:300,...me?{model:me}:{},...de?{provider:de}:{}});return{error:null,text:w(o.content??o.text).trim()||`${e.length} events processed`}}catch(o){return{error:o instanceof Error?o.message:String(o),text:`${e.length} events (summary unavailable)`}}}function nt(e){const t=e.data,i=e.projectName?`[${e.projectName}] `:"",s=w(t.tool)||w(t.name)||"",r=w(t.filePath),a=w(t.command),o=w(t.pattern);switch(e.type){case"agent-idle":case"agent-question":return`${i}${e.type}: ${w(t.message).slice(0,80)}`;case"error":return`${i}Error: ${w(t.error||t.message).slice(0,100)}`;case"session_end":return`${i}Session ended`;case"tool-completed":return`${i}[${s}] completed`;case"tool-failed":return`${i}[${s}] FAILED: ${w(t.error).slice(0,80)}`;case"tool-started":return`${i}[${s}] started${r?`: ${r}`:""}`;case"tool_result":{const l=t.is_error?"FAILED":"done";return`${i}${s?`[${s}] → `:""}${l}`}case"tool_use":{const l=r||a||o||"";return s?`${i}[${s}] ${l}`.trim():`${i}[tool] ${l}`.trim()}case"user_message":return`${i}User: ${w(t.text).slice(0,80)}`;default:return`${i}${e.type}`}}function at(e){return e.map(nt).join(`
8
- `)}let me="",de="";async function it(){if(Q)return Q;if(Y)return Y;if(L>=Se){if(Date.now()<$e)return null;L=0}return L++,Y=(async()=>{try{et();const e=await import(tt),t=window.__aiProviders,i=window.process?.env?.NEUROLINK_PROVIDER,s=ot(t,i);if(!s)return console.warn("[ActivityFeed] No AI provider configured"),null;const r=window.process;return r?.env&&t&&(t["google-ai"]&&!r.env.GOOGLE_AI_API_KEY&&(r.env.GOOGLE_AI_API_KEY="proxy-via-server"),t.anthropic&&!r.env.ANTHROPIC_API_KEY&&(r.env.ANTHROPIC_API_KEY="proxy-via-server"),t.openai&&!r.env.OPENAI_API_KEY&&(r.env.OPENAI_API_KEY="proxy-via-server"),t.mistral&&!r.env.MISTRAL_API_KEY&&(r.env.MISTRAL_API_KEY="proxy-via-server")),Q=new e.NeuroLink({provider:s.provider}),me=s.model,de=s.provider,L=0,console.log(`[ActivityFeed] NeuroLink SDK loaded: ${s.provider}/${s.model}`),Q}catch(e){return console.warn("[ActivityFeed] NeuroLink SDK load failed (attempt",L,"):",e instanceof Error?e.message:String(e)),L>=Se&&($e=Date.now()+rt),null}finally{Y=null}})(),Y}function w(e){return e==null?"":typeof e=="string"?e:typeof e=="number"||typeof e=="boolean"?String(e):JSON.stringify(e)}const ct=50,Oe=5,lt=15e3,mt=15e3,dt=5;let S=b(ke([])),te=b(ke([])),ve=b(!0),M=b(!1),B=b(!1),G=null,ee=null,fe=0;const I=new ue;let H="",oe=null;async function ut(e){if(!G){if(H=je(),!H){console.warn("[ActivityStore] No API key available");return}oe=e,await Ie(),G=setInterval(()=>{Ie()},mt),ee=setInterval(()=>{T()},lt)}}function vt(){G&&(clearInterval(G),G=null),ee&&(clearInterval(ee),ee=null);for(const[e,t]of I)t.onclose=null,t.close(),console.log(`[ActivityStore] Closed session socket for ${e}`);I.clear(),_(S,[],!0),_(te,[],!0),fe=0,_(ve,!0),_(B,!1),_(M,!1),H="",oe=null}function ft(){return n(S)}function pt(){return n(te)}function _t(){return n(ve)}function gt(){return n(M)}function yt(){return n(B)}function R(e,t,i,s){const r={data:i,id:`evt-${++fe}`,projectName:e.projectName,sessionId:e.id,summarized:!1,timestamp:s||new Date().toISOString(),type:t};_(S,[...n(S),r].slice(-200),!0),n(S).filter(o=>!o.summarized).length>=Oe&&T()}async function ht(e){if(oe)try{const t=await oe(),s=`${window.location.origin.replace(/^http/,"ws")}/ws/session/${e.id}?ticket=${t}`;console.log(`[ActivityStore] Connecting to session ${e.id}`);const r=new WebSocket(s);I.set(e.id,r),r.onopen=()=>{console.log(`[ActivityStore] Session socket opened: ${e.id}`),_(M,!0)},r.onmessage=a=>{try{const o=JSON.parse(a.data);if(!o||typeof o!="object")return;const l=o;At(e,l),l.type==="history"&&T()}catch{}},r.onclose=()=>{console.log(`[ActivityStore] Session socket closed: ${e.id}`),I.delete(e.id),_(M,I.size>0)},r.onerror=a=>{console.warn(`[ActivityStore] Session socket error for ${e.id}:`,a),I.delete(e.id),_(M,I.size>0)}}catch(t){console.warn(`[ActivityStore] Failed to connect session ${e.id}:`,t)}}async function Ie(){if(H)try{const e=await fetch("/api/sessions?limit=50",{headers:{Authorization:`Bearer ${H}`}});if(!e.ok){console.warn("[ActivityStore] Failed to fetch sessions:",e.status);return}const i=(await e.json()).projects??[],s=Date.now()-dt*60*1e3,r=[];for(const o of i)for(const l of o.sessions)Date.parse(l.modified)>s&&r.push({createdAt:l.created,id:l.id,modifiedAt:l.modified,projectName:o.name,projectPath:o.fullPath});const a=new Set(r.map(o=>o.id));for(const[o,l]of I)a.has(o)||(l.onclose=null,l.close(),I.delete(o),console.log(`[ActivityStore] Session ${o} went stale, closed socket`));for(const o of r)I.has(o.id)||ht(o);_(M,I.size>0)}catch(e){console.warn("[ActivityStore] Error discovering sessions:",e)}}function At(e,t){const i=t.type;if(i==="history"&&Array.isArray(t.messages)){const r=t.messages.slice(-20);for(const a of r)xe(e,a)}else if(i==="message")xe(e,{content:t.content||"",role:t.role||"assistant",timestamp:t.timestamp});else if(i==="tool-use"){const s=t.name||"unknown",r=typeof t.input=="object"&&t.input!==null?t.input:{},a=r.file_path||r.path||"",o=r.command||"",l=r.pattern||"";R(e,"tool_use",{command:o.slice(0,120),filePath:a.slice(0,200),name:s,pattern:l.slice(0,100),tool:s})}else if(i==="tool-result"){const s=t.isError===!0,r=(t.output||"").slice(0,200);let a=t.name||"";if(!a){for(let o=n(S).length-1;o>=0;o--)if(n(S)[o].type==="tool_use"&&n(S)[o].data.name){a=n(S)[o].data.name;break}}R(e,"tool_result",{is_error:s,output:r,status:s?"error":"done",tool:a}),s&&T()}else i==="thinking"||(i==="error"?(R(e,"error",{message:t.message||"Unknown error"}),T()):i==="session-end"&&(R(e,"session_end",{}),T()))}function xe(e,t){const i=t.timestamp||new Date().toISOString();let s="";if(typeof t.content=="string"?s=t.content:Array.isArray(t.content)&&(s=t.content.filter(a=>a.type==="text").map(a=>a.text||a.content||"").join("")),t.role==="user")R(e,"user_message",{text:s.slice(0,150)},i);else if(t.role==="assistant"&&Array.isArray(t.content)){const r=t.content.filter(a=>a.type==="tool_use");for(const a of r){const o=a,l=typeof o.input=="object"&&o.input!==null?o.input:{};R(e,"tool_use",{command:(l.command||"").slice(0,120),filePath:(l.file_path||l.path||"").slice(0,200),name:a.name||"unknown",tool:a.name||"unknown"},i)}}}async function T(){if(n(B))return;const e=n(S).filter(s=>!s.summarized);if(e.length===0)return;const t=new ue;for(const s of e){const r=s.projectName||"Unknown";t.has(r)||t.set(r,[]);const a=t.get(r);a&&a.push(s)}const i=Array.from(t.entries()).filter(([,s])=>s.length>=Oe);if(i.length!==0){_(B,!0);try{const s=await Promise.allSettled(i.slice(0,3).map(async([r,a])=>{const o=await st(a,r);return{projectEvents:a,projectName:r,result:o}}));for(const r of s){if(r.status!=="fulfilled"||!r.value.result.text)continue;const{projectEvents:a,projectName:o,result:l}=r.value;l.error?.includes("No AI provider")&&_(ve,!1);const x={eventIds:a.map(k=>k.id),id:`sum-${++fe}`,projectName:o,text:l.text,timestamp:new Date().toISOString()};_(te,[...n(te),x].slice(-ct),!0);const V=new Set(a.map(k=>k.id));_(S,n(S).map(k=>V.has(k.id)?{...k,summarized:!0}:k),!0)}}catch(s){console.warn("[ActivityStore] Summarization failed:",s)}finally{_(B,!1)}}}var wt=A('<span class="summarizing svelte-tc58m">Summarizing...</span>'),St=A(`<p class="empty svelte-tc58m">No recent activity. Summaries will appear here when Claude Code sessions are active on this
9
- machine.</p>`),$t=A('<div class="summary-card svelte-tc58m"><time class="svelte-tc58m"> </time> <p class="svelte-tc58m"> </p> <span class="event-count svelte-tc58m"> </span></div>'),It=A('<div class="project-group svelte-tc58m"><h3 class="project-name svelte-tc58m"> </h3> <!></div>'),xt=A('<div class="pending svelte-tc58m"><span> </span></div>'),kt=A('<span class="tool svelte-tc58m"> </span>'),Et=A('<code class="file-path svelte-tc58m"> </code>'),Pt=A('<code class="svelte-tc58m"> </code>'),Nt=A('<div><time class="svelte-tc58m"> </time> <span class="project svelte-tc58m"> </span> <span class="type svelte-tc58m"> </span> <!> <!> <!></div>'),jt=A('<div class="raw-events svelte-tc58m"></div>'),Ot=A('<div class="feed svelte-tc58m"><header class="svelte-tc58m"><h2 class="svelte-tc58m">Activity</h2> <span> </span> <!></header> <!> <div class="entries svelte-tc58m"><!> <!> <!></div> <!> <!></div>');function bt(e,t){Ee(t,!0);let i=b(!1);async function s(){const c=je();if(!c)throw new Error("No API key configured");const m=await fetch("/api/ws-ticket",{headers:{Authorization:`Bearer ${c}`},method:"POST"});if(!m.ok)throw new Error("Failed to get WS ticket");return(await m.json()).ticket}Pe(()=>{ut(s)}),Ge(()=>{vt()});const r=N(pt),a=N(ft),o=N(gt),l=N(_t),x=N(yt),V=N(()=>n(a).filter(c=>!c.summarized).length),k=N(()=>{const c=new Qe;for(const m of n(a))m.sessionId&&c.add(m.sessionId);return c.size}),be=N(()=>{const c=new ue;for(const m of[...n(r)].reverse()){const v=m.projectName||"Unknown";c.has(v)||c.set(v,{name:v,summaries:[]});const f=c.get(v);f&&f.summaries.push(m)}return Array.from(c.values())});var re=Ot(),se=u(re),W=p(u(se),2);let pe;var ze=u(W,!0);d(W);var Le=p(W,2);{var Re=c=>{var m=wt();g(c,m)};P(Le,c=>{n(x)&&c(Re)})}d(se);var _e=p(se,2);{var Me=c=>{Xe(c,{text:"AI summaries unavailable — configure a provider to enable",classes:"banner-warning"})};P(_e,c=>{n(l)||c(Me)})}var ne=p(_e,2),ge=u(ne);{var Te=c=>{var m=St();g(c,m)};P(ge,c=>{n(r).length===0&&n(a).length===0&&c(Te)})}var ye=p(ge,2);le(ye,17,()=>n(be),c=>c.name,(c,m)=>{var v=It(),f=u(v),z=u(f,!0);d(f);var J=p(f,2);le(J,17,()=>n(m).summaries,j=>j.id,(j,D)=>{var O=$t(),C=u(O),K=u(C,!0);d(C);var F=p(C,2),q=u(F,!0);d(F);var X=p(F,2),Z=u(X);d(X),d(O),E(ae=>{h(K,ae),h(q,n(D).text),h(Z,`${n(D).eventIds.length??""} events`)},[()=>we(n(D).timestamp)]),g(j,O)}),d(v),E(()=>h(z,n(m).name)),g(c,v)});var De=p(ye,2);{var Ce=c=>{var m=xt(),v=u(m),f=u(v);d(v),d(m),E(()=>h(f,`${n(V)??""} events pending summary...`)),g(c,m)};P(De,c=>{n(V)>0&&c(Ce)})}d(ne);var he=p(ne,2);qe(he,{classes:"btn-ghost raw-toggle",onclick:()=>{_(i,!n(i))},children:(c,m)=>{He();var v=Be();E(()=>h(v,`${n(i)?"▾":"▸"} Raw events (${n(a).length??""})`)),g(c,v)},$$slots:{default:!0}});var Ke=p(he,2);{var Fe=c=>{var m=jt();le(m,21,()=>[...n(a)].reverse().slice(0,50),v=>v.id,(v,f)=>{var z=Nt();let J;var j=u(z),D=u(j,!0);d(j);var O=p(j,2),C=u(O,!0);d(O);var K=p(O,2),F=u(K,!0);d(K);var q=p(K,2);{var X=y=>{var $=kt(),U=u($,!0);d($),E(()=>h(U,n(f).data.tool)),g(y,$)};P(q,y=>{n(f).data.tool&&y(X)})}var Z=p(q,2);{var ae=y=>{var $=Et(),U=u($,!0);d($),E(ie=>h(U,ie),[()=>n(f).data.filePath.slice(0,80)]),g(y,$)};P(Z,y=>{n(f).data.filePath&&y(ae)})}var Ue=p(Z,2);{var Ye=y=>{var $=Pt(),U=u($,!0);d($),E(ie=>h(U,ie),[()=>n(f).data.command.slice(0,60)]),g(y,$)};P(Ue,y=>{n(f).data.command&&y(Ye)})}d(z),E(y=>{J=Ae(z,1,"raw-event svelte-tc58m",null,J,{summarized:n(f).summarized}),h(D,y),h(C,n(f).projectName||"Unknown"),h(F,n(f).type)},[()=>we(n(f).timestamp)]),g(v,z)}),d(m),g(c,m)};P(Ke,c=>{n(i)&&c(Fe)})}d(re),E(()=>{pe=Ae(W,1,"status svelte-tc58m",null,pe,{live:n(o)}),h(ze,n(o)?`● Watching ${n(k)} sessions`:"○ No active sessions")}),g(e,re),Ne()}var zt=A('<meta name="description" content="Real-time activity feed"/>'),Lt=A('<main class="main"><h1 class="page-title svelte-13r34ge">Activity Feed</h1> <!></main>');function Ht(e,t){Ee(t,!0);let i=b(!1);Pe(()=>{try{const o=localStorage.getItem("shooter_config");if(!o){ce("/config");return}const l=JSON.parse(o);if(!Ze(l)){localStorage.removeItem("shooter_config"),ce("/config");return}_(i,!0)}catch{localStorage.removeItem("shooter_config"),ce("/config")}});var s=Lt();Je("13r34ge",o=>{var l=zt();Ve(()=>{We.title="Activity Feed - Shooter"}),g(o,l)});var r=p(u(s),2);{var a=o=>{bt(o,{})};P(r,o=>{n(i)&&o(a)})}d(s),g(e,s),Ne()}export{Ht as component};
8
+ `)}let me="",de="";async function it(){if(Q)return Q;if(Y)return Y;if(L>=Se){if(Date.now()<$e)return null;L=0}return L++,Y=(async()=>{try{et();const e=await import(tt),t=window.__aiProviders,i=window.process?.env?.NEUROLINK_PROVIDER,s=ot(t,i);if(!s)return console.warn("[ActivityFeed] No AI provider configured"),null;const r=window.process;return r?.env&&t&&(t["google-ai"]&&!r.env.GOOGLE_AI_API_KEY&&(r.env.GOOGLE_AI_API_KEY="proxy-via-server"),t.anthropic&&!r.env.ANTHROPIC_API_KEY&&(r.env.ANTHROPIC_API_KEY="proxy-via-server"),t.openai&&!r.env.OPENAI_API_KEY&&(r.env.OPENAI_API_KEY="proxy-via-server"),t.mistral&&!r.env.MISTRAL_API_KEY&&(r.env.MISTRAL_API_KEY="proxy-via-server")),Q=new e.NeuroLink({provider:s.provider}),me=s.model,de=s.provider,L=0,console.log(`[ActivityFeed] NeuroLink SDK loaded: ${s.provider}/${s.model}`),Q}catch(e){return console.warn("[ActivityFeed] NeuroLink SDK load failed (attempt",L,"):",e instanceof Error?e.message:String(e)),L>=Se&&($e=Date.now()+rt),null}finally{Y=null}})(),Y}function w(e){return e==null?"":typeof e=="string"?e:typeof e=="number"||typeof e=="boolean"?String(e):JSON.stringify(e)}const ct=50,Oe=5,lt=15e3,mt=15e3,dt=5;let S=b(ke([])),te=b(ke([])),ve=b(!0),D=b(!1),B=b(!1),G=null,ee=null,fe=0;const I=new ue;let H="",oe=null;async function ut(e){if(!G){if(H=je(),!H){console.warn("[ActivityStore] No API key available");return}oe=e,await Ie(),G=setInterval(()=>{Ie()},mt),ee=setInterval(()=>{M()},lt)}}function vt(){G&&(clearInterval(G),G=null),ee&&(clearInterval(ee),ee=null);for(const[e,t]of I)t.onclose=null,t.close(),console.log(`[ActivityStore] Closed session socket for ${e}`);I.clear(),_(S,[],!0),_(te,[],!0),fe=0,_(ve,!0),_(B,!1),_(D,!1),H="",oe=null}function ft(){return n(S)}function pt(){return n(te)}function _t(){return n(ve)}function gt(){return n(D)}function yt(){return n(B)}function R(e,t,i,s){const r={data:i,id:`evt-${++fe}`,projectName:e.projectName,sessionId:e.id,summarized:!1,timestamp:s||new Date().toISOString(),type:t};_(S,[...n(S),r].slice(-200),!0),n(S).filter(o=>!o.summarized).length>=Oe&&M()}async function ht(e){if(oe)try{const t=await oe(),s=`${window.location.origin.replace(/^http/,"ws")}/ws/session/${e.id}?ticket=${t}`;console.log(`[ActivityStore] Connecting to session ${e.id}`);const r=new WebSocket(s);I.set(e.id,r),r.onopen=()=>{console.log(`[ActivityStore] Session socket opened: ${e.id}`),_(D,!0)},r.onmessage=a=>{try{const o=JSON.parse(a.data);if(!o||typeof o!="object")return;const l=o;At(e,l),l.type==="history"&&M()}catch{}},r.onclose=()=>{console.log(`[ActivityStore] Session socket closed: ${e.id}`),I.delete(e.id),_(D,I.size>0)},r.onerror=a=>{console.warn(`[ActivityStore] Session socket error for ${e.id}:`,a),I.delete(e.id),_(D,I.size>0)}}catch(t){console.warn(`[ActivityStore] Failed to connect session ${e.id}:`,t)}}async function Ie(){if(H)try{const e=await fetch("/api/sessions?limit=50",{headers:{Authorization:`Bearer ${H}`}});if(!e.ok){console.warn("[ActivityStore] Failed to fetch sessions:",e.status);return}const i=(await e.json()).projects??[],s=Date.now()-dt*60*1e3,r=[];for(const o of i)for(const l of o.sessions)Date.parse(l.modified)>s&&r.push({createdAt:l.created,id:l.id,modifiedAt:l.modified,projectName:o.name,projectPath:o.fullPath});const a=new Set(r.map(o=>o.id));for(const[o,l]of I)a.has(o)||(l.onclose=null,l.close(),I.delete(o),console.log(`[ActivityStore] Session ${o} went stale, closed socket`));for(const o of r)I.has(o.id)||ht(o);_(D,I.size>0)}catch(e){console.warn("[ActivityStore] Error discovering sessions:",e)}}function At(e,t){const i=t.type;if(i==="history"&&Array.isArray(t.messages)){const r=t.messages.slice(-20);for(const a of r)xe(e,a)}else if(i==="message")xe(e,{content:t.content||"",role:t.role||"assistant",timestamp:t.timestamp});else if(i==="tool-use"){const s=t.name||"unknown",r=typeof t.input=="object"&&t.input!==null?t.input:{},a=r.file_path||r.path||"",o=r.command||"",l=r.pattern||"";R(e,"tool_use",{command:o.slice(0,120),filePath:a.slice(0,200),name:s,pattern:l.slice(0,100),tool:s})}else if(i==="tool-result"){const s=t.isError===!0,r=(t.output||"").slice(0,200);let a=t.name||"";if(!a){for(let o=n(S).length-1;o>=0;o--)if(n(S)[o].type==="tool_use"&&n(S)[o].data.name){a=n(S)[o].data.name;break}}R(e,"tool_result",{is_error:s,output:r,status:s?"error":"done",tool:a}),s&&M()}else i==="thinking"||(i==="error"?(R(e,"error",{message:t.message||"Unknown error"}),M()):i==="session-end"&&(R(e,"session_end",{}),M()))}function xe(e,t){const i=t.timestamp||new Date().toISOString();let s="";if(typeof t.content=="string"?s=t.content:Array.isArray(t.content)&&(s=t.content.filter(a=>a.type==="text").map(a=>a.text||a.content||"").join("")),t.role==="user")R(e,"user_message",{text:s.slice(0,150)},i);else if(t.role==="assistant"&&Array.isArray(t.content)){const r=t.content.filter(a=>a.type==="tool_use");for(const a of r){const o=a,l=typeof o.input=="object"&&o.input!==null?o.input:{};R(e,"tool_use",{command:(l.command||"").slice(0,120),filePath:(l.file_path||l.path||"").slice(0,200),name:a.name||"unknown",tool:a.name||"unknown"},i)}}}async function M(){if(n(B))return;const e=n(S).filter(s=>!s.summarized);if(e.length===0)return;const t=new ue;for(const s of e){const r=s.projectName||"Unknown";t.has(r)||t.set(r,[]);const a=t.get(r);a&&a.push(s)}const i=Array.from(t.entries()).filter(([,s])=>s.length>=Oe);if(i.length!==0){_(B,!0);try{const s=await Promise.allSettled(i.slice(0,3).map(async([r,a])=>{const o=await st(a,r);return{projectEvents:a,projectName:r,result:o}}));for(const r of s){if(r.status!=="fulfilled"||!r.value.result.text)continue;const{projectEvents:a,projectName:o,result:l}=r.value;l.error?.includes("No AI provider")&&_(ve,!1);const x={eventIds:a.map(k=>k.id),id:`sum-${++fe}`,projectName:o,text:l.text,timestamp:new Date().toISOString()};_(te,[...n(te),x].slice(-ct),!0);const V=new Set(a.map(k=>k.id));_(S,n(S).map(k=>V.has(k.id)?{...k,summarized:!0}:k),!0)}}catch(s){console.warn("[ActivityStore] Summarization failed:",s)}finally{_(B,!1)}}}var wt=A('<span class="summarizing svelte-tc58m">Summarizing...</span>'),St=A(`<p class="empty svelte-tc58m">No recent activity. Summaries will appear here when Claude Code sessions are active on this
9
+ machine.</p>`),$t=A('<div class="summary-card svelte-tc58m"><time class="svelte-tc58m"> </time> <p class="svelte-tc58m"> </p> <span class="event-count svelte-tc58m"> </span></div>'),It=A('<div class="project-group svelte-tc58m"><h3 class="project-name svelte-tc58m"> </h3> <!></div>'),xt=A('<div class="pending svelte-tc58m"><span> </span></div>'),kt=A('<span class="tool svelte-tc58m"> </span>'),Et=A('<code class="file-path svelte-tc58m"> </code>'),Pt=A('<code class="svelte-tc58m"> </code>'),Nt=A('<div><time class="svelte-tc58m"> </time> <span class="project svelte-tc58m"> </span> <span class="type svelte-tc58m"> </span> <!> <!> <!></div>'),jt=A('<div class="raw-events svelte-tc58m"></div>'),Ot=A('<div class="feed svelte-tc58m"><header class="svelte-tc58m"><h2 class="svelte-tc58m">Activity</h2> <span> </span> <!></header> <!> <div class="entries svelte-tc58m"><!> <!> <!></div> <!> <!></div>');function bt(e,t){Ee(t,!0);let i=b(!1);async function s(){const c=je();if(!c)throw new Error("No API key configured");const m=await fetch("/api/ws-ticket",{headers:{Authorization:`Bearer ${c}`},method:"POST"});if(!m.ok)throw new Error("Failed to get WS ticket");return(await m.json()).ticket}Pe(()=>{ut(s)}),Ge(()=>{vt()});const r=N(pt),a=N(ft),o=N(gt),l=N(_t),x=N(yt),V=N(()=>n(a).filter(c=>!c.summarized).length),k=N(()=>{const c=new Qe;for(const m of n(a))m.sessionId&&c.add(m.sessionId);return c.size}),be=N(()=>{const c=new ue;for(const m of[...n(r)].reverse()){const v=m.projectName||"Unknown";c.has(v)||c.set(v,{name:v,summaries:[]});const f=c.get(v);f&&f.summaries.push(m)}return Array.from(c.values())});var re=Ot(),se=u(re),W=p(u(se),2);let pe;var ze=u(W,!0);d(W);var Le=p(W,2);{var Re=c=>{var m=wt();g(c,m)};P(Le,c=>{n(x)&&c(Re)})}d(se);var _e=p(se,2);{var De=c=>{Xe(c,{text:"AI summaries unavailable — configure a provider to enable",classes:"banner-warning"})};P(_e,c=>{n(l)||c(De)})}var ne=p(_e,2),ge=u(ne);{var Me=c=>{var m=St();g(c,m)};P(ge,c=>{n(r).length===0&&n(a).length===0&&c(Me)})}var ye=p(ge,2);le(ye,17,()=>n(be),c=>c.name,(c,m)=>{var v=It(),f=u(v),z=u(f,!0);d(f);var J=p(f,2);le(J,17,()=>n(m).summaries,j=>j.id,(j,T)=>{var O=$t(),C=u(O),K=u(C,!0);d(C);var F=p(C,2),q=u(F,!0);d(F);var X=p(F,2),Z=u(X);d(X),d(O),E(ae=>{h(K,ae),h(q,n(T).text),h(Z,`${n(T).eventIds.length??""} events`)},[()=>we(n(T).timestamp)]),g(j,O)}),d(v),E(()=>h(z,n(m).name)),g(c,v)});var Te=p(ye,2);{var Ce=c=>{var m=xt(),v=u(m),f=u(v);d(v),d(m),E(()=>h(f,`${n(V)??""} events pending summary...`)),g(c,m)};P(Te,c=>{n(V)>0&&c(Ce)})}d(ne);var he=p(ne,2);qe(he,{classes:"btn-ghost raw-toggle",onclick:()=>{_(i,!n(i))},children:(c,m)=>{He();var v=Be();E(()=>h(v,`${n(i)?"▾":"▸"} Raw events (${n(a).length??""})`)),g(c,v)},$$slots:{default:!0}});var Ke=p(he,2);{var Fe=c=>{var m=jt();le(m,21,()=>[...n(a)].reverse().slice(0,50),v=>v.id,(v,f)=>{var z=Nt();let J;var j=u(z),T=u(j,!0);d(j);var O=p(j,2),C=u(O,!0);d(O);var K=p(O,2),F=u(K,!0);d(K);var q=p(K,2);{var X=y=>{var $=kt(),U=u($,!0);d($),E(()=>h(U,n(f).data.tool)),g(y,$)};P(q,y=>{n(f).data.tool&&y(X)})}var Z=p(q,2);{var ae=y=>{var $=Et(),U=u($,!0);d($),E(ie=>h(U,ie),[()=>n(f).data.filePath.slice(0,80)]),g(y,$)};P(Z,y=>{n(f).data.filePath&&y(ae)})}var Ue=p(Z,2);{var Ye=y=>{var $=Pt(),U=u($,!0);d($),E(ie=>h(U,ie),[()=>n(f).data.command.slice(0,60)]),g(y,$)};P(Ue,y=>{n(f).data.command&&y(Ye)})}d(z),E(y=>{J=Ae(z,1,"raw-event svelte-tc58m",null,J,{summarized:n(f).summarized}),h(T,y),h(C,n(f).projectName||"Unknown"),h(F,n(f).type)},[()=>we(n(f).timestamp)]),g(v,z)}),d(m),g(c,m)};P(Ke,c=>{n(i)&&c(Fe)})}d(re),E(()=>{pe=Ae(W,1,"status svelte-tc58m",null,pe,{live:n(o)}),h(ze,n(o)?`● Watching ${n(k)} sessions`:"○ No active sessions")}),g(e,re),Ne()}var zt=A('<meta name="description" content="Real-time activity feed"/>'),Lt=A('<main class="main"><h1 class="page-title svelte-13r34ge">Activity Feed</h1> <!></main>');function Ht(e,t){Ee(t,!0);let i=b(!1);Pe(()=>{try{const o=localStorage.getItem("shooter_config");if(!o){ce("/config");return}const l=JSON.parse(o);if(!Ze(l)){localStorage.removeItem("shooter_config"),ce("/config");return}_(i,!0)}catch{localStorage.removeItem("shooter_config"),ce("/config")}});var s=Lt();Je("13r34ge",o=>{var l=zt();Ve(()=>{We.title="Activity Feed - Shooter"}),g(o,l)});var r=p(u(s),2);{var a=o=>{bt(o,{})};P(r,o=>{n(i)&&o(a)})}d(s),g(e,s),Ne()}export{Ht as component};
@@ -1,4 +1,4 @@
1
- import{a as d,f as u,i as Q,s as D}from"../chunks/Cg3dlX05.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 Oe,N as De,A as J,b as t,x,s as k,$ as Le,B as we}from"../chunks/DYuMZGL5.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/DZvnhU_8.js";import{h as Fe}from"../chunks/DZQMsHM5.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(()=>D(z,o.description)),d(A,M)};Q(j,A=>{typeof o.description=="string"&&o.description.length>0&&A(q)})}c(I),U(()=>D(L,o.title)),d(i,I)};Q(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 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">
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>
@@ -13,4 +13,4 @@ import{a as d,f as u,i as Q,s as D}from"../chunks/Cg3dlX05.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)}Oe(()=>{{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();De(()=>{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 K=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(K,{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}})}};Q(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 K=C=>{se(C,{get svg(){return nt},classes:"icon-14"})};Q(P,C=>{e(S)||C(K)})}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 K=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(),O=J(b),ne=v(O);c(O);var Ne=g(O,4);{var Qe=ae=>{var oe=ct(),_e=g(v(oe)),Ke=v(_e,!0);c(_e),c(oe),U(()=>D(Ke,e(L))),d(ae,oe)};Q(Ne,ae=>{e(L)&&ae(Qe)})}U(()=>Ee(ne,"src",e(T))),d(y,b)},N=y=>{var b=dt();d(y,b)},$=y=>{var b=vt(),O=v(b,!0);c(b),U(()=>D(O,e(q))),d(y,b)},E=y=>{var b=ut();d(y,b)};Q(m,y=>{e(T)?y(_):e(j)?y(N,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)};Q(P,R=>{e(A)?R(K):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 N=pt(),$=v(N);{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 O=v(y,!0);c(y),c(N),U(()=>{D(re,e(_).label),b=W(y,1,"provider-status svelte-1gp6n77",null,b,{configured:o.data.aiProviders[e(_).id]}),D(O,o.data.aiProviders[e(_).id]?"configured":"not configured")}),d(m,N)});var P=g(p,2);{var K=m=>{var _=ht(),N=g(v(_)),$=v(N,!0);c(N),c(_),U(()=>D($,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,_)};Q(P,m=>{o.data.activeProvider?m(K):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){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};
@@ -1 +1 @@
1
- import{d as q,i as T,b as H,a as k,f as N,s as V}from"../chunks/Cg3dlX05.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/DYuMZGL5.js";import{e as K,I as Z,B as ee,s as te,i as ae,P as I}from"../chunks/DZvnhU_8.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/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 +1 @@
1
- import{i as w,a as p,f as m,s as $}from"../chunks/Cg3dlX05.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/DYuMZGL5.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/DZvnhU_8.js";import{h as nt}from"../chunks/DZQMsHM5.js";import{g as it}from"../chunks/nWG9RHyB.js";import{p as ct}from"../chunks/8lO1IL7u.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/BRqaaL5D.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/C5VOyQCG.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/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,4 +1,4 @@
1
- import{i as K,a as h,f as g,s as V}from"../chunks/Cg3dlX05.js";import{p as ge,s as v,q as we,v as ye,w as be,z as Se,b as s,g as e,$ as _e,c as _,r as $,x as P,A as H,d as D,t as Q}from"../chunks/DYuMZGL5.js";import{h as $e}from"../chunks/DZQMsHM5.js";import{d as X,B as ke}from"../chunks/DZvnhU_8.js";import{p as x}from"../chunks/8lO1IL7u.js";import{g as Ie,s as Y}from"../chunks/xs1Xl3_e.js";import"../chunks/BDcFu3l7.js";import{s as Z}from"../chunks/BdtLzPpO.js";import{C as je}from"../chunks/B9WQy_3X.js";var Ce=g('<meta name="description" content="Session conversation view"/>'),Oe=g('<div class="loading-container" aria-live="polite" aria-busy="true"><div class="shimmer shimmer-header" aria-hidden="true"></div> <div class="chat-container"><div class="shimmer shimmer-bubble shimmer-bubble-user" aria-hidden="true"></div> <div class="shimmer shimmer-bubble shimmer-bubble-assistant" aria-hidden="true"></div> <div class="shimmer shimmer-bubble shimmer-bubble-user-short" aria-hidden="true"></div> <div class="shimmer shimmer-bubble shimmer-bubble-assistant-wide" aria-hidden="true"></div></div></div>'),Me=g('<div class="session-back-row svelte-1a2wdfb"><a class="back-link">← Back</a></div> <p class="error-text svelte-1a2wdfb"> </p>',1),Ne=g('<span class="resume-status svelte-1a2wdfb">Connecting...</span>'),Ae=g('<span class="resume-status svelte-1a2wdfb">Resuming session...</span>'),Te=g('<span class="connection-dot connected svelte-1a2wdfb"></span>'),Pe=g('<span class="connection-dot reconnecting svelte-1a2wdfb"></span>'),De=g('<div class="load-earlier-row svelte-1a2wdfb"><!></div>'),Re=g('<div class="session-header svelte-1a2wdfb"><div class="session-header-row svelte-1a2wdfb"><a class="back-link">← Back</a> <!></div> <h1 class="session-title svelte-1a2wdfb"> </h1></div> <div class="session-chat-container svelte-1a2wdfb"><!> <!></div>',1),We=g('<main class="main session-page-main svelte-1a2wdfb"><!></main>');function Fe(ee,te){ge(te,!0);let f=v(null),i=v(we([])),w=v(!0),I=v(null),R=v(!1),N=v(!1),A=v(200),j=v(null),k=v("idle"),c=v("idle"),y=null,b=null,C=null,O=null,d=!1;const W=P(()=>x.params.id),M=P(()=>x.url.searchParams.get("project")||""),se=P(()=>e(c)==="connecting"||e(c)==="resuming");function T(){try{const t=localStorage.getItem("shooter_config");return t?JSON.parse(t):null}catch{return null}}async function L(){const t=T();if(!t)return null;try{const n=await fetch("/api/ws-ticket",{headers:{Authorization:`Bearer ${t.apiKey}`},method:"POST"});return n.ok?(await n.json()).ticket:null}catch{return null}}async function z(t,n){if(d||C&&(C.readyState===WebSocket.OPEN||C.readyState===WebSocket.CONNECTING))return;const a=await L();if(!a||d)return;s(k,"connecting");const o=window.location.protocol==="https:"?"wss:":"ws:",r=new WebSocket(`${o}//${window.location.host}${t}?ticket=${a}`);r.onopen=()=>{if(d){r.close();return}s(k,"connected"),r.send(JSON.stringify({sessionId:n,type:"subscribe"}))},r.onmessage=u=>{if(!d)try{const p=JSON.parse(u.data);ne(p)}catch{}},r.onclose=()=>{d||(s(k,"disconnected"),C=null,e(j)&&(O&&clearTimeout(O),O=setTimeout(()=>{O=null,!d&&e(j)&&z(`/ws/session/${e(j)}`,e(j))},2e3)))},r.onerror=()=>{d||s(k,"disconnected")},C=r}async function q(t){if(d)return;const n=await L();if(!n||d)return;const a=window.location.protocol==="https:"?"wss:":"ws:",o=new WebSocket(`${a}//${window.location.host}${t}?ticket=${n}`);o.onopen=()=>{if(d){o.close();return}b=o,e(c)==="ready"&&y&&(o.send(JSON.stringify({data:`${y}
1
+ import{i as K,a as h,f as g,s as V}from"../chunks/BPDiEZo0.js";import{p as ge,s as v,q as we,v as ye,w as be,z as Se,b as s,g as e,$ as _e,c as _,r as $,x as P,A as H,d as D,t as Q}from"../chunks/DWmC0QM7.js";import{h as $e}from"../chunks/2rBV5OkJ.js";import{d as X,B as ke}from"../chunks/ZS5XYDx_.js";import{p as x}from"../chunks/DIZ3Qst5.js";import{g as Ie,s as Y}from"../chunks/xs1Xl3_e.js";import"../chunks/BDcFu3l7.js";import{s as Z}from"../chunks/BdtLzPpO.js";import{C as je}from"../chunks/BB2l8o4X.js";var Ce=g('<meta name="description" content="Session conversation view"/>'),Oe=g('<div class="loading-container" aria-live="polite" aria-busy="true"><div class="shimmer shimmer-header" aria-hidden="true"></div> <div class="chat-container"><div class="shimmer shimmer-bubble shimmer-bubble-user" aria-hidden="true"></div> <div class="shimmer shimmer-bubble shimmer-bubble-assistant" aria-hidden="true"></div> <div class="shimmer shimmer-bubble shimmer-bubble-user-short" aria-hidden="true"></div> <div class="shimmer shimmer-bubble shimmer-bubble-assistant-wide" aria-hidden="true"></div></div></div>'),Me=g('<div class="session-back-row svelte-1a2wdfb"><a class="back-link">← Back</a></div> <p class="error-text svelte-1a2wdfb"> </p>',1),Ne=g('<span class="resume-status svelte-1a2wdfb">Connecting...</span>'),Ae=g('<span class="resume-status svelte-1a2wdfb">Resuming session...</span>'),Te=g('<span class="connection-dot connected svelte-1a2wdfb"></span>'),Pe=g('<span class="connection-dot reconnecting svelte-1a2wdfb"></span>'),De=g('<div class="load-earlier-row svelte-1a2wdfb"><!></div>'),Re=g('<div class="session-header svelte-1a2wdfb"><div class="session-header-row svelte-1a2wdfb"><a class="back-link">← Back</a> <!></div> <h1 class="session-title svelte-1a2wdfb"> </h1></div> <div class="session-chat-container svelte-1a2wdfb"><!> <!></div>',1),We=g('<main class="main session-page-main svelte-1a2wdfb"><!></main>');function Fe(ee,te){ge(te,!0);let f=v(null),i=v(we([])),w=v(!0),I=v(null),R=v(!1),N=v(!1),A=v(200),j=v(null),k=v("idle"),c=v("idle"),y=null,b=null,C=null,O=null,d=!1;const W=P(()=>x.params.id),M=P(()=>x.url.searchParams.get("project")||""),se=P(()=>e(c)==="connecting"||e(c)==="resuming");function T(){try{const t=localStorage.getItem("shooter_config");return t?JSON.parse(t):null}catch{return null}}async function L(){const t=T();if(!t)return null;try{const n=await fetch("/api/ws-ticket",{headers:{Authorization:`Bearer ${t.apiKey}`},method:"POST"});return n.ok?(await n.json()).ticket:null}catch{return null}}async function z(t,n){if(d||C&&(C.readyState===WebSocket.OPEN||C.readyState===WebSocket.CONNECTING))return;const a=await L();if(!a||d)return;s(k,"connecting");const o=window.location.protocol==="https:"?"wss:":"ws:",r=new WebSocket(`${o}//${window.location.host}${t}?ticket=${a}`);r.onopen=()=>{if(d){r.close();return}s(k,"connected"),r.send(JSON.stringify({sessionId:n,type:"subscribe"}))},r.onmessage=u=>{if(!d)try{const p=JSON.parse(u.data);ne(p)}catch{}},r.onclose=()=>{d||(s(k,"disconnected"),C=null,e(j)&&(O&&clearTimeout(O),O=setTimeout(()=>{O=null,!d&&e(j)&&z(`/ws/session/${e(j)}`,e(j))},2e3)))},r.onerror=()=>{d||s(k,"disconnected")},C=r}async function q(t){if(d)return;const n=await L();if(!n||d)return;const a=window.location.protocol==="https:"?"wss:":"ws:",o=new WebSocket(`${a}//${window.location.host}${t}?ticket=${n}`);o.onopen=()=>{if(d){o.close();return}b=o,e(c)==="ready"&&y&&(o.send(JSON.stringify({data:`${y}
2
2
  `,type:"input"})),y=null)},o.onclose=()=>{b===o&&(b=null)}}function ne(t){if(t.type==="history"){const n=t.messages||[];s(i,n.map(a=>({id:a.id,parts:a.content,role:a.role,timestamp:a.timestamp})),!0),s(R,!1),e(c)==="resuming"&&(s(c,"ready"),y&&b?.readyState===WebSocket.OPEN&&(b.send(JSON.stringify({data:`${y}
3
3
  `,type:"input"})),y=null))}else if(t.type==="message")s(i,[...e(i),{id:`msg-${Date.now()}-${Math.random().toString(36).slice(2,8)}`,parts:t.content||[],role:t.role||"assistant",timestamp:t.timestamp||new Date().toISOString()}],!0);else if(t.type==="tool-use"){const n={id:t.id||`tool-${Date.now()}`,input:t.input||{},toolName:t.name,type:"tool_use"},a=e(i).length>0?e(i)[e(i).length-1]:null;a?.role==="assistant"?s(i,[...e(i).slice(0,-1),{...a,parts:[...a.parts,n]}],!0):s(i,[...e(i),{id:`tool-${Date.now()}-${Math.random().toString(36).slice(2,8)}`,parts:[n],role:"assistant",timestamp:new Date().toISOString()}],!0)}else if(t.type==="tool-result"){const n={isError:t.isError||!1,output:t.output||"",toolUseId:t.id,type:"tool_result"},a=e(i).length>0?e(i)[e(i).length-1]:null;a?.role==="system"?s(i,[...e(i).slice(0,-1),{...a,parts:[...a.parts,n]}],!0):s(i,[...e(i),{id:`result-${Date.now()}-${Math.random().toString(36).slice(2,8)}`,parts:[n],role:"system",timestamp:new Date().toISOString()}],!0)}else if(t.type==="thinking"){const n={content:t.text||"",type:"thinking"},a=e(i).length>0?e(i)[e(i).length-1]:null;a?.role==="assistant"?s(i,[...e(i).slice(0,-1),{...a,parts:[...a.parts,n]}],!0):s(i,[...e(i),{id:`think-${Date.now()}-${Math.random().toString(36).slice(2,8)}`,parts:[n],role:"assistant",timestamp:new Date().toISOString()}],!0)}else t.type==="session-end"&&s(c,"idle")}async function ae(){if(!e(f)||d){s(c,"idle");return}const t=T();if(!t){s(c,"idle");return}s(c,"connecting");try{const n=Z(e(f).source),a=await fetch("/api/sessions/connect",{body:JSON.stringify({command:n,cwd:e(f).projectPath,sessionId:e(W)}),headers:{Authorization:`Bearer ${t.apiKey}`,"Content-Type":"application/json"},method:"POST"});if(!a.ok||d){s(c,"idle");return}const o=await a.json();s(j,o.terminalId,!0),s(c,"resuming"),z(o.sessionWs,o.terminalId),q(o.ws)}catch{s(c,"idle")}}function ie(t){if(t.trim()){if(e(c)==="ready"&&b?.readyState===WebSocket.OPEN){b.send(JSON.stringify({data:`${t}
4
4
  `,type:"input"}));return}if(e(c)==="connecting"||e(c)==="resuming"){y=t;return}y=t,ae()}}async function oe(){e(i).length===0&&s(w,!0);try{const t=T();if(!t){s(I,"No configuration found. Please configure settings first."),s(w,!1);return}const n=e(W)??"",a=e(M);if(!n){s(I,"No session ID"),s(w,!1);return}const o=a?`id=${encodeURIComponent(n)}&project=${encodeURIComponent(a)}&limit=${e(A)}`:`id=${encodeURIComponent(n)}&limit=${e(A)}`;let r=await fetch(`/api/sessions?${o}`,{headers:{Authorization:`Bearer ${t.apiKey}`}});if(r.status===404&&!a){const S=await fetch("/api/sessions",{headers:{Authorization:`Bearer ${t.apiKey}`}});if(S.ok){const J=await S.json();for(const B of J.projects||[])if((B.sessions||[]).find(U=>U.id===n)){r=await fetch(`/api/sessions?id=${encodeURIComponent(n)}&project=${encodeURIComponent(B.id)}`,{headers:{Authorization:`Bearer ${t.apiKey}`}});break}}}if(!r.ok){s(I,"Session not found"),s(w,!1);return}const u=await r.json(),p=Array.isArray(u.messages)?u.messages:[];Y(`shooter_session_${n}`,{messages:p,session:u.session}),s(f,u.session,!0),s(i,p,!0),s(R,p.length>=e(A)),s(w,!1);return}catch{s(I,"Failed to load session")}s(w,!1)}async function re(){if(e(N))return;const t=T();if(t){s(N,!0);try{const n=e(A)+200,a=e(W)??"",o=e(M);if(!a)return;const r=[`id=${encodeURIComponent(a)}`,`limit=${n}`];o&&r.push(`project=${encodeURIComponent(o)}`);const u=await fetch(`/api/sessions?${r.join("&")}`,{headers:{Authorization:`Bearer ${t.apiKey}`}});if(!u.ok)return;const p=await u.json(),S=Array.isArray(p.messages)?p.messages:[];s(i,S,!0),s(A,n),s(R,S.length>=n),Y(`shooter_session_${a}`,{messages:S,session:p.session})}catch{}finally{s(N,!1)}}}ye(()=>{const t=Ie(`shooter_session_${x.params.id}`);return t&&(s(f,t.session,!0),s(i,Array.isArray(t.messages)?t.messages:[],!0),s(w,!1)),oe().then(async()=>{if(!e(f)||d)return;const n=T();if(n)try{const a=Z(e(f).source),o=await fetch("/api/sessions/connect",{body:JSON.stringify({command:a,cwd:e(f).projectPath,noCreate:!0,sessionId:e(W)}),headers:{Authorization:`Bearer ${n.apiKey}`,"Content-Type":"application/json"},method:"POST"});if(o.ok&&!d){const r=await o.json();s(j,r.terminalId,!0),s(c,"resuming"),z(r.sessionWs,r.terminalId),q(r.ws)}}catch{}}),()=>{d=!0,O&&clearTimeout(O),C?.close(),b?.close()}});var E=We();$e("1a2wdfb",t=>{var n=Ce();Se(()=>{_e.title=`${(e(f)?.title||"Session")??""} - Shooter`}),h(t,n)});var ce=_(E);{var le=t=>{var n=Oe();h(t,n)},de=t=>{var n=Me(),a=H(n),o=_(a);$(a);var r=D(a,2),u=_(r,!0);$(r),Q(()=>{X(o,"href",e(M)?`/project?id=${e(M)}`:"/"),V(u,e(I))}),h(t,n)},ue=t=>{var n=Re(),a=H(n),o=_(a),r=_(o),u=D(r,2);{var p=l=>{var m=Ne();h(l,m)},S=l=>{var m=Ae();h(l,m)},J=l=>{var m=Te();h(l,m)},B=l=>{var m=Pe();h(l,m)};K(u,l=>{e(c)==="connecting"?l(p):e(c)==="resuming"?l(S,1):e(k)==="connected"?l(J,2):e(k)==="reconnecting"&&l(B,3)})}$(o);var U=D(o,2),fe=_(U,!0);$(U),$(a);var F=D(a,2),G=_(F);{var pe=l=>{var m=De(),he=_(m);{let ve=P(()=>e(N)?"Loading...":"Load earlier messages");ke(he,{get text(){return e(ve)},classes:"btn-ghost btn-sm",get disabled(){return e(N)},onclick:re})}$(m),h(l,m)};K(G,l=>{e(R)&&l(pe)})}var me=D(G,2);{let l=P(()=>[...e(i)].reverse());je(me,{get messages(){return e(l)},newestFirst:!0,get connectionState(){return e(k)},showInput:!0,get sendDisabled(){return e(se)},onSendInput:ie,sessionEnded:!1})}$(F),Q(()=>{X(r,"href",e(M)?`/project?id=${e(M)}`:"/"),V(fe,e(f).title)}),h(t,n)};K(ce,t=>{e(w)&&e(i).length===0?t(le):e(I)?t(de,1):e(f)&&t(ue,2)})}$(E),h(ee,E),be()}export{Fe as component};
@@ -0,0 +1 @@
1
+ import{i as B,a as p,f,s as $}from"../chunks/BPDiEZo0.js";import{p as G,s as g,q as H,v as Q,w as U,D as V,b as a,g as s,c as o,x as j,d as c,$ as W,r as n,t as X}from"../chunks/DWmC0QM7.js";import{I as Y,B as Z,b as ee,e as se,P as te,d as ae}from"../chunks/ZS5XYDx_.js";import{h as re}from"../chunks/2rBV5OkJ.js";import{g as ne}from"../chunks/C_YNQL8b.js";import{E as oe}from"../chunks/ClIPTXf3.js";var ie=f('<p class="muted svelte-1ggfn1w">Loading…</p>'),le=f('<a class="ss-card svelte-1ggfn1w"><div class="ss-card-head svelte-1ggfn1w"><span class="ss-label svelte-1ggfn1w"> </span> <!></div> <div class="ss-meta svelte-1ggfn1w"><span> </span> <span> </span></div></a>'),ce=f('<div class="ss-grid svelte-1ggfn1w"></div>'),ve=f('<main class="main sos-list svelte-1ggfn1w"><div class="page-head svelte-1ggfn1w"><div><h1 class="svelte-1ggfn1w">Session Over Sessions</h1> <p class="subtitle svelte-1ggfn1w">Coordinate multiple running agents as one super-session.</p></div></div> <div class="create-row svelte-1ggfn1w"><!> <!></div> <!> <!></main>');function he(I,P){G(P,!0);let m=g(H([])),h=g(!0),i=g(""),v=g(""),d=g(!1);function x(){try{const e=localStorage.getItem("shooter_config");return e?JSON.parse(e):null}catch{return null}}async function T(){const e=x();if(!e){a(i,"No configuration found. Open Settings first."),a(h,!1);return}try{const t=await fetch("/api/sos",{headers:{Authorization:`Bearer ${e.apiKey}`}});if(!t.ok){a(i,`Failed to load (${t.status})`);return}const r=await t.json();a(m,r.superSessions??[],!0)}catch{a(i,"Network error — is the server running?")}finally{a(h,!1)}}async function z(){const e=x();if(!(!e||!s(v).trim())){a(d,!0);try{const t=await fetch("/api/sos",{body:JSON.stringify({label:s(v).trim()}),headers:{Authorization:`Bearer ${e.apiKey}`,"Content-Type":"application/json"},method:"POST"});if(t.ok){const r=await t.json();ne(`/sos/${r.id}`)}else{const r=await t.json().catch(()=>({}));a(i,r.error??`Failed to create (${t.status})`,!0)}}catch{a(i,"Network error — could not create super-session")}finally{a(d,!1)}}}Q(()=>{T()});var w=ve();re("1ggfn1w",e=>{V(()=>{W.title="Session Over Sessions - Shooter"})});var _=c(o(w),2),k=o(_);Y(k,{dataType:"text",placeholder:"New super-session label…",classes:"sos-create-input",get value(){return s(v)},set value(e){a(v,e,!0)}});var A=c(k,2);{let e=j(()=>s(d)?"Creating…":"Create"),t=j(()=>s(d)||!s(v).trim());Z(A,{get text(){return s(e)},get disabled(){return s(t)},onclick:z,classes:"btn-create"})}n(_);var N=c(_,2);{var E=e=>{ee(e,{get text(){return s(i)},classes:"banner-error"})};B(N,e=>{s(i)&&e(E)})}var F=c(N,2);{var J=e=>{var t=ie();p(e,t)},K=e=>{oe(e,{title:"No super-sessions yet",description:"Create one above, then add running agent sessions as members."})},L=e=>{var t=ce();se(t,21,()=>s(m),r=>r.id,(r,l)=>{var u=le(),b=o(u),y=o(b),R=o(y,!0);n(y);var q=c(y,2);te(q,{get text(){return s(l).status},classes:"pill-status-unknown"}),n(b);var C=c(b,2),S=o(C),D=o(S);n(S);var O=c(S,2),M=o(O);n(O),n(C),n(u),X(()=>{ae(u,"href",`/sos/${s(l).id}`),$(R,s(l).label),$(D,`${s(l).members.length??""} member${s(l).members.length===1?"":"s"}`),$(M,`${s(l).routingRules.length??""} rule${s(l).routingRules.length===1?"":"s"}`)}),p(r,u)}),n(t),p(e,t)};B(F,e=>{s(h)?e(J):s(m).length===0?e(K,1):e(L,-1)})}n(w),p(I,w),U()}export{he as component};
@@ -0,0 +1,2 @@
1
+ import{i as Y,a as I,c as tt,e as rt,f as S,s as _,g as st}from"../chunks/BPDiEZo0.js";import{p as at,s as m,q as Te,E as ot,g as e,v as nt,y as lt,w as it,z as ct,$ as dt,d as l,c as i,r as c,b as s,x as v,A as ut,t as q}from"../chunks/DWmC0QM7.js";import{b as vt,P as ie,e as Z,B as F,s as pt,S as D,I as ee,d as mt}from"../chunks/ZS5XYDx_.js";import{h as gt}from"../chunks/2rBV5OkJ.js";import{p as ft}from"../chunks/DT4H19pV.js";var ht=S('<div class="pending svelte-4802gc"><span class="pending-text svelte-4802gc"> <em> </em></span> <div class="pending-actions svelte-4802gc"><!> <!></div></div>'),bt=S('<p class="muted svelte-4802gc">No messages yet. Add members below.</p>'),yt=S('<span class="relay-badge svelte-4802gc">relayed</span>'),_t=S('<div><div class="entry-tag svelte-4802gc"><!> <span class="member-id svelte-4802gc"> </span> <!></div> <pre class="entry-body svelte-4802gc"> </pre></div>'),wt=S('<div class="member-row svelte-4802gc"><!> <span class="member-key svelte-4802gc"> </span> <span class="member-flag svelte-4802gc"> </span> <!></div>'),$t=S('<div class="rule-row svelte-4802gc"><span> </span> <span class="rule-action svelte-4802gc"> </span> <span class="rule-pattern svelte-4802gc"> </span> <!></div>'),kt=S('<div class="head svelte-4802gc"><h1 class="svelte-4802gc"> </h1> <!></div> <!> <section class="panel svelte-4802gc"><h2 class="svelte-4802gc">Merged transcript</h2> <div class="transcript svelte-4802gc"><!> <!></div></section> <section class="panel svelte-4802gc"><h2 class="svelte-4802gc">Forward to a member</h2> <div class="row svelte-4802gc"><!> <!> <!></div></section> <section class="panel svelte-4802gc"><h2 class="svelte-4802gc">Members</h2> <!> <div class="row add-row svelte-4802gc"><!> <!> <!> <!></div></section> <section class="panel svelte-4802gc"><h2 class="svelte-4802gc">Routing rules</h2> <!> <div class="row add-row svelte-4802gc"><!> <!> <!> <!> <!></div></section>',1),xt=S('<main class="main sos-view svelte-4802gc"><a class="back svelte-4802gc" href="/sos">← All super-sessions</a> <!> <!></main>');function At(Ne,Ae){at(Ae,!0);const je=()=>tt(ft,"$page",Oe),[Oe,Pe]=rt(),Re=["claude-code","codex","opencode","gemini","qwen","cursor","copilot","amp"],M=je().params.id??"";let d=m(null),T=m(Te([])),W=m(Te([])),p=m(""),N=null,z=!1,w=m(""),C=m(""),E=m(""),te=m("claude-code"),U=m(""),J=m(""),K=m(""),re=m("relay"),G=m("");const $=v(()=>e(d)?.members??[]),Q=v(()=>e(d)?.routingRules??[]);let B=m(void 0);ot(()=>{e(B)&&e(T).length>0&&(e(B).scrollTop=e(B).scrollHeight)});function Fe(){try{const t=localStorage.getItem("shooter_config");return t?JSON.parse(t):null}catch{return null}}function Ce(){return Fe()?.apiKey??""}function A(t=!1){const o={Authorization:`Bearer ${Ce()}`};return t&&(o["Content-Type"]="application/json"),o}function j(t){const o=e($).find(u=>u.id===t);return o?`${V(o.provider)} · ${o.id.slice(0,6)}`:t.slice(0,6)}function V(t){return t==="claude-code"?"Claude":t.charAt(0).toUpperCase()+t.slice(1)}function Ee(t){return t.message.parts.map(o=>o.type==="text"||o.type==="thinking"?o.content:o.type==="tool_use"?`🔧 ${o.toolName}`:`↳ ${o.output.slice(0,200)}`).join(`
2
+ `).trim()}async function Je(){try{const t=await fetch(`/api/sos/${M}`,{headers:A()});return t.ok?(s(d,await t.json(),!0),s(T,e(d).transcript??[],!0),!e(w)&&e($)[0]&&s(w,e($)[0].id,!0),!0):(s(p,t.status===404?"Super-session not found":`Failed to load (${t.status})`,!0),!1)}catch{return s(p,"Network error"),!1}}async function Ke(){try{const t=await fetch("/api/ws-ticket",{headers:A(),method:"POST"});if(!t.ok){s(p,"Failed to open the live connection (ticket request failed)");return}const{ticket:o}=await t.json();if(z)return;const u=window.location.protocol==="https:"?"wss:":"ws:";N=new WebSocket(`${u}//${window.location.host}/ws/super-session/${M}?ticket=${o}`),N.onmessage=O=>{let X;try{X=JSON.parse(O.data)}catch{return}We(X)},N.onerror=()=>{s(p,"Live connection error")}}catch{s(p,"Failed to open the live connection (network error)")}}function We(t){switch(t.type){case"sos-error":s(p,t.message,!0);break;case"sos-history":s(T,t.entries,!0);break;case"sos-member-added":e(d)&&s(d,{...e(d),members:[...e(d).members,t.member]},!0);break;case"sos-member-removed":e(d)&&s(d,{...e(d),members:e(d).members.filter(o=>o.id!==t.memberId)},!0);break;case"sos-message":s(T,[...e(T),t.entry],!0);break;case"sos-relay-pending":s(W,[...e(W),{expiresAt:t.expiresAt,fromMemberId:t.fromMemberId,preview:t.preview,relayId:t.relayId,toMemberId:t.toMemberId}],!0);break;case"sos-relay-resolved":s(W,e(W).filter(o=>o.relayId!==t.relayId),!0);break}}function ce(t){N?.readyState===WebSocket.OPEN&&N.send(JSON.stringify(t))}async function Be(){if(!(!e(w)||!e(C).trim()))try{const t=await fetch(`/api/sos/${M}/inject`,{body:JSON.stringify({text:e(C),toMemberId:e(w)}),headers:A(!0),method:"POST"});if(!t.ok){const o=await t.json().catch(()=>({}));s(p,o.error??"Failed to forward message",!0);return}s(C,"")}catch{s(p,"Network error — could not forward message")}}async function He(){if(e(E).trim())try{const t=await fetch(`/api/sos/${M}/members`,{body:JSON.stringify({provider:e(te),sessionKey:e(E).trim(),terminalId:e(U).trim()||void 0}),headers:A(!0),method:"POST"});if(t.ok)s(E,""),s(U,"");else{const o=await t.json().catch(()=>({}));s(p,o.error??"Failed to add member",!0)}}catch{s(p,"Network error — could not add member")}}async function Le(t){try{const o=await fetch(`/api/sos/${M}/members/${t}`,{headers:A(),method:"DELETE"});if(!o.ok){const u=await o.json().catch(()=>({}));s(p,u.error??"Failed to remove member",!0)}}catch{s(p,"Network error — could not remove member")}}async function qe(){if(!e(J)||!e(K))return;const t=[...e(Q),{action:e(re),fromMemberId:e(J),id:"",matchPattern:e(G),priority:e(Q).length+1,toMemberId:e(K)}];try{const o=await fetch(`/api/sos/${M}/rules`,{body:JSON.stringify({routingRules:t}),headers:A(!0),method:"PATCH"});if(o.ok&&e(d)){const u=await o.json();s(d,{...e(d),routingRules:u.routingRules},!0),s(G,"")}else{const u=await o.json().catch(()=>({}));s(p,u.error??"Failed to add rule",!0)}}catch{s(p,"Network error — could not add rule")}}async function De(t){const o=e(Q).filter(u=>u.id!==t);try{const u=await fetch(`/api/sos/${M}/rules`,{body:JSON.stringify({routingRules:o}),headers:A(!0),method:"PATCH"});if(u.ok&&e(d))s(d,{...e(d),routingRules:o},!0);else if(!u.ok){const O=await u.json().catch(()=>({}));s(p,O.error??"Failed to delete rule",!0)}}catch{s(p,"Network error — could not delete rule")}}nt(()=>(Je().then(t=>{t&&!z&&Ke()}),()=>{z=!0,N?.close()})),lt(()=>{z=!0,N?.close()});var se=xt();gt("4802gc",t=>{ct(()=>{dt.title=`${e(d)?.label??"Super-session"??""} - Shooter`})});var de=l(i(se),2);{var ze=t=>{vt(t,{get text(){return e(p)},classes:"banner-error"})};Y(de,t=>{e(p)&&t(ze)})}var Ue=l(de,2);{var Ge=t=>{var o=kt(),u=ut(o),O=i(u),X=i(O,!0);c(O);var Qe=l(O,2);{let r=v(()=>`${e($).length} members`);ie(Qe,{get text(){return e(r)},classes:"pill-status-unknown"})}c(u);var ue=l(u,2);Z(ue,17,()=>e(W),r=>r.relayId,(r,a)=>{var n=ht(),g=i(n),f=i(g),h=l(f),b=i(h,!0);c(h),c(g);var y=l(g,2),k=i(y);F(k,{text:"Approve",classes:"btn-approve",onclick:()=>{ce({relayId:e(a).relayId,type:"relay-approve"})}});var P=l(k,2);F(P,{text:"Deny",classes:"btn-deny",onclick:()=>{ce({relayId:e(a).relayId,type:"relay-deny"})}}),c(y),c(n),q((x,H)=>{_(f,`Relay ${x??""} → ${H??""}: `),_(b,e(a).preview)},[()=>j(e(a).fromMemberId),()=>j(e(a).toMemberId)]),I(r,n)});var ae=l(ue,2),oe=l(i(ae),2),ve=i(oe);{var Ve=r=>{var a=bt();I(r,a)};Y(ve,r=>{e(T).length===0&&r(Ve)})}var Xe=l(ve,2);Z(Xe,19,()=>e(T),(r,a)=>`${r.message.id}-${a}`,(r,a)=>{var n=_t();let g;var f=i(n),h=i(f);{let R=v(()=>V(e(a).provider)),L=v(()=>`pill-source-${e(a).provider}`);ie(h,{get text(){return e(R)},get classes(){return e(L)}})}var b=l(h,2),y=i(b,!0);c(b);var k=l(b,2);{var P=R=>{var L=yt();I(R,L)};Y(k,R=>{e(a).relayed&&R(P)})}c(f);var x=l(f,2),H=i(x,!0);c(x),c(n),q((R,L)=>{g=pt(n,1,"entry svelte-4802gc",null,g,{relayed:e(a).relayed}),_(y,R),_(H,L)},[()=>e(a).memberId.slice(0,6),()=>Ee(e(a))]),I(r,n)}),c(oe),st(oe,r=>s(B,r),()=>e(B)),c(ae);var ne=l(ae,2),pe=l(i(ne),2),me=i(pe);{let r=v(()=>e($).map(n=>({id:n.id,label:j(n.id)}))),a=v(()=>e(w)?[e(w)]:[]);D(me,{get items(){return e(r)},get value(){return e(a)},placeholder:"Member",onchange:n=>{s(w,n[0]??"",!0)},classes:"sos-select"})}var ge=l(me,2);ee(ge,{dataType:"text",placeholder:"Message to inject…",classes:"sos-input",get value(){return e(C)},set value(r){s(C,r,!0)}});var Ye=l(ge,2);{let r=v(()=>!e(w)||!e(C).trim());F(Ye,{text:"Send",get disabled(){return e(r)},onclick:Be,classes:"btn-send"})}c(pe),c(ne);var le=l(ne,2),fe=l(i(le),2);Z(fe,17,()=>e($),r=>r.id,(r,a)=>{var n=wt(),g=i(n);{let P=v(()=>V(e(a).provider)),x=v(()=>`pill-source-${e(a).provider}`);ie(g,{get text(){return e(P)},get classes(){return e(x)}})}var f=l(g,2),h=i(f,!0);c(f);var b=l(f,2),y=i(b,!0);c(b);var k=l(b,2);F(k,{text:"Remove",classes:"btn-remove",onclick:()=>{Le(e(a).id)}}),c(n),q(()=>{mt(f,"title",e(a).sessionKey),_(h,e(a).sessionKey),_(y,e(a).terminalId?"⌁ terminal":"observed")}),I(r,n)});var he=l(fe,2),be=i(he);ee(be,{dataType:"text",placeholder:"sessionKey (file path or session id)",classes:"sos-input",get value(){return e(E)},set value(r){s(E,r,!0)}});var ye=l(be,2);{let r=v(()=>Re.map(n=>({id:n,label:V(n)}))),a=v(()=>[e(te)]);D(ye,{get items(){return e(r)},get value(){return e(a)},onchange:n=>{s(te,n[0]??"claude-code",!0)},classes:"sos-select"})}var _e=l(ye,2);ee(_e,{dataType:"text",placeholder:"terminalId (optional)",classes:"sos-input",get value(){return e(U)},set value(r){s(U,r,!0)}});var Ze=l(_e,2);{let r=v(()=>!e(E).trim());F(Ze,{text:"Add",get disabled(){return e(r)},onclick:He,classes:"btn-send"})}c(he),c(le);var we=l(le,2),$e=l(i(we),2);Z($e,17,()=>e(Q),r=>r.id,(r,a)=>{var n=$t(),g=i(n),f=i(g);c(g);var h=l(g,2),b=i(h,!0);c(h);var y=l(h,2),k=i(y,!0);c(y);var P=l(y,2);F(P,{text:"✕",classes:"btn-remove",onclick:()=>{De(e(a).id)}}),c(n),q((x,H)=>{_(f,`${x??""} → ${H??""}`),_(b,e(a).action),_(k,e(a).matchPattern||"(any)")},[()=>j(e(a).fromMemberId),()=>j(e(a).toMemberId)]),I(r,n)});var ke=l($e,2),xe=i(ke);{let r=v(()=>e($).map(n=>({id:n.id,label:j(n.id)}))),a=v(()=>e(J)?[e(J)]:[]);D(xe,{get items(){return e(r)},get value(){return e(a)},placeholder:"From",onchange:n=>{s(J,n[0]??"",!0)},classes:"sos-select"})}var Ie=l(xe,2);{let r=v(()=>e($).map(n=>({id:n.id,label:j(n.id)}))),a=v(()=>e(K)?[e(K)]:[]);D(Ie,{get items(){return e(r)},get value(){return e(a)},placeholder:"To",onchange:n=>{s(K,n[0]??"",!0)},classes:"sos-select"})}var Se=l(Ie,2);{let r=v(()=>[e(re)]);D(Se,{items:[{id:"relay",label:"relay"},{id:"block",label:"block"},{id:"escalate",label:"escalate"}],get value(){return e(r)},onchange:a=>{s(re,a[0]??"relay",!0)},classes:"sos-select"})}var Me=l(Se,2);ee(Me,{dataType:"text",placeholder:"match (substring, empty=any)",classes:"sos-input",get value(){return e(G)},set value(r){s(G,r,!0)}});var et=l(Me,2);{let r=v(()=>!e(J)||!e(K));F(et,{text:"Add rule",get disabled(){return e(r)},onclick:qe,classes:"btn-send"})}c(ke),c(we),q(()=>_(X,e(d).label)),I(t,o)};Y(Ue,t=>{e(d)&&t(Ge)})}c(se),I(Ne,se),it(),Pe()}export{At as component};
@@ -1 +1 @@
1
- {"version":"1780830864274"}
1
+ {"version":"1781328368816"}
Binary file
Binary file