vibepulse 0.2.0 → 0.2.1

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 (420) hide show
  1. package/.next/BUILD_ID +1 -1
  2. package/.next/app-path-routes-manifest.json +4 -0
  3. package/.next/build-manifest.json +2 -2
  4. package/.next/cache/.previewinfo +1 -1
  5. package/.next/cache/.rscinfo +1 -1
  6. package/.next/cache/.tsbuildinfo +1 -1
  7. package/.next/cache/config.json +3 -3
  8. package/.next/fallback-build-manifest.json +2 -2
  9. package/.next/prerender-manifest.json +3 -3
  10. package/.next/routes-manifest.json +32 -0
  11. package/.next/server/app/_global-error/page.js +1 -1
  12. package/.next/server/app/_global-error/page.js.nft.json +1 -1
  13. package/.next/server/app/_global-error.html +2 -2
  14. package/.next/server/app/_global-error.rsc +1 -1
  15. package/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  16. package/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  17. package/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  18. package/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  19. package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  20. package/.next/server/app/_not-found/page.js +1 -1
  21. package/.next/server/app/_not-found/page.js.nft.json +1 -1
  22. package/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  23. package/.next/server/app/_not-found.html +1 -1
  24. package/.next/server/app/_not-found.rsc +2 -2
  25. package/.next/server/app/_not-found.segments/_full.segment.rsc +2 -2
  26. package/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  27. package/.next/server/app/_not-found.segments/_index.segment.rsc +2 -2
  28. package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  29. package/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  30. package/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  31. package/.next/server/app/api/node/events/route.js +1 -1
  32. package/.next/server/app/api/node/events/route.js.nft.json +1 -1
  33. package/.next/server/app/api/node/health/route.js +1 -1
  34. package/.next/server/app/api/node/health/route.js.nft.json +1 -1
  35. package/.next/server/app/api/node/sessions/[id]/archive/route/app-paths-manifest.json +3 -0
  36. package/.next/server/app/api/node/sessions/[id]/archive/route/build-manifest.json +11 -0
  37. package/.next/server/app/api/node/sessions/[id]/archive/route/server-reference-manifest.json +4 -0
  38. package/.next/server/app/api/node/sessions/[id]/archive/route.js +6 -0
  39. package/.next/server/app/api/node/sessions/[id]/archive/route.js.map +5 -0
  40. package/.next/server/app/api/node/sessions/[id]/archive/route.js.nft.json +1 -0
  41. package/.next/server/app/api/node/sessions/[id]/archive/route_client-reference-manifest.js +2 -0
  42. package/.next/server/app/api/node/sessions/[id]/delete/route/app-paths-manifest.json +3 -0
  43. package/.next/server/app/api/node/sessions/[id]/delete/route/build-manifest.json +11 -0
  44. package/.next/server/app/api/node/sessions/[id]/delete/route/server-reference-manifest.json +4 -0
  45. package/.next/server/app/api/node/sessions/[id]/delete/route.js +7 -0
  46. package/.next/server/app/api/node/sessions/[id]/delete/route.js.map +5 -0
  47. package/.next/server/app/api/node/sessions/[id]/delete/route.js.nft.json +1 -0
  48. package/.next/server/app/api/node/sessions/[id]/delete/route_client-reference-manifest.js +2 -0
  49. package/.next/server/app/api/node/sessions/[id]/open-editor/route/app-paths-manifest.json +3 -0
  50. package/.next/server/app/api/node/sessions/[id]/open-editor/route/build-manifest.json +11 -0
  51. package/.next/server/app/api/node/sessions/[id]/open-editor/route/server-reference-manifest.json +4 -0
  52. package/.next/server/app/api/node/sessions/[id]/open-editor/route.js +7 -0
  53. package/.next/server/app/api/node/sessions/[id]/open-editor/route.js.map +5 -0
  54. package/.next/server/app/api/node/sessions/[id]/open-editor/route.js.nft.json +1 -0
  55. package/.next/server/app/api/node/sessions/[id]/open-editor/route_client-reference-manifest.js +2 -0
  56. package/.next/server/app/api/node/sessions/route.js +1 -1
  57. package/.next/server/app/api/node/sessions/route.js.nft.json +1 -1
  58. package/.next/server/app/api/opencode-events/route.js +1 -1
  59. package/.next/server/app/api/opencode-events/route.js.nft.json +1 -1
  60. package/.next/server/app/api/sessions/[id]/archive/route.js +2 -1
  61. package/.next/server/app/api/sessions/[id]/archive/route.js.nft.json +1 -1
  62. package/.next/server/app/api/sessions/[id]/delete/route.js +3 -2
  63. package/.next/server/app/api/sessions/[id]/delete/route.js.nft.json +1 -1
  64. package/.next/server/app/api/sessions/[id]/open-editor/route/app-paths-manifest.json +3 -0
  65. package/.next/server/app/api/sessions/[id]/open-editor/route/build-manifest.json +11 -0
  66. package/.next/server/app/api/sessions/[id]/open-editor/route/server-reference-manifest.json +4 -0
  67. package/.next/server/app/api/sessions/[id]/open-editor/route.js +7 -0
  68. package/.next/server/app/api/sessions/[id]/open-editor/route.js.map +5 -0
  69. package/.next/server/app/api/sessions/[id]/open-editor/route.js.nft.json +1 -0
  70. package/.next/server/app/api/sessions/[id]/open-editor/route_client-reference-manifest.js +2 -0
  71. package/.next/server/app/api/sessions/route.js +1 -1
  72. package/.next/server/app/api/sessions/route.js.nft.json +1 -1
  73. package/.next/server/app/index.html +1 -1
  74. package/.next/server/app/index.rsc +3 -3
  75. package/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  76. package/.next/server/app/index.segments/_full.segment.rsc +3 -3
  77. package/.next/server/app/index.segments/_head.segment.rsc +1 -1
  78. package/.next/server/app/index.segments/_index.segment.rsc +2 -2
  79. package/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  80. package/.next/server/app/page.js +1 -1
  81. package/.next/server/app/page.js.nft.json +1 -1
  82. package/.next/server/app/page_client-reference-manifest.js +1 -1
  83. package/.next/server/app-paths-manifest.json +4 -0
  84. package/.next/server/chunks/[root-of-the-server]__1211da38._.js +3 -0
  85. package/.next/server/chunks/[root-of-the-server]__1211da38._.js.map +1 -0
  86. package/.next/{standalone/.next/server/chunks/[root-of-the-server]__b698889b._.js → server/chunks/[root-of-the-server]__1b87ec42._.js} +2 -2
  87. package/.next/server/chunks/[root-of-the-server]__1b87ec42._.js.map +1 -0
  88. package/.next/server/chunks/[root-of-the-server]__2b526e7a._.js +3 -0
  89. package/.next/server/chunks/[root-of-the-server]__2b526e7a._.js.map +1 -0
  90. package/.next/server/chunks/[root-of-the-server]__2f981540._.js +3 -0
  91. package/.next/server/chunks/[root-of-the-server]__2f981540._.js.map +1 -0
  92. package/.next/server/chunks/[root-of-the-server]__3745b314._.js +3 -0
  93. package/.next/server/chunks/[root-of-the-server]__3745b314._.js.map +1 -0
  94. package/.next/server/chunks/[root-of-the-server]__56690af0._.js +1 -1
  95. package/.next/server/chunks/[root-of-the-server]__56690af0._.js.map +1 -1
  96. package/.next/server/chunks/[root-of-the-server]__56f5f249._.js +1 -1
  97. package/.next/server/chunks/[root-of-the-server]__56f5f249._.js.map +1 -1
  98. package/.next/server/chunks/[root-of-the-server]__59175de4._.js +1 -1
  99. package/.next/server/chunks/[root-of-the-server]__59175de4._.js.map +1 -1
  100. package/.next/server/chunks/[root-of-the-server]__64fffc02._.js +1 -1
  101. package/.next/server/chunks/[root-of-the-server]__64fffc02._.js.map +1 -1
  102. package/.next/server/chunks/[root-of-the-server]__6c428a24._.js +3 -0
  103. package/.next/server/chunks/[root-of-the-server]__6c428a24._.js.map +1 -0
  104. package/.next/server/chunks/[root-of-the-server]__73a00b88._.js +3 -0
  105. package/.next/server/chunks/[root-of-the-server]__73a00b88._.js.map +1 -0
  106. package/.next/server/chunks/[root-of-the-server]__89c5eeab._.js +1 -1
  107. package/.next/server/chunks/[root-of-the-server]__89c5eeab._.js.map +1 -1
  108. package/.next/server/chunks/[root-of-the-server]__8da6c5a8._.js +1 -1
  109. package/.next/server/chunks/[root-of-the-server]__8da6c5a8._.js.map +1 -1
  110. package/.next/server/chunks/[root-of-the-server]__b796d06c._.js +1 -1
  111. package/.next/server/chunks/[root-of-the-server]__b796d06c._.js.map +1 -1
  112. package/.next/server/chunks/[root-of-the-server]__c2ce5c0f._.js +1 -1
  113. package/.next/server/chunks/[root-of-the-server]__c2ce5c0f._.js.map +1 -1
  114. package/.next/server/chunks/[root-of-the-server]__d8e61048._.js +3 -0
  115. package/.next/server/chunks/[root-of-the-server]__d8e61048._.js.map +1 -0
  116. package/.next/server/chunks/[root-of-the-server]__db285678._.js +3 -0
  117. package/.next/server/chunks/[root-of-the-server]__db285678._.js.map +1 -0
  118. package/.next/{standalone/.next/server/chunks/[root-of-the-server]__16a9eb0a._.js → server/chunks/[root-of-the-server]__e00a9200._.js} +2 -2
  119. package/.next/server/chunks/{[root-of-the-server]__16a9eb0a._.js.map → [root-of-the-server]__e00a9200._.js.map} +1 -1
  120. package/.next/server/chunks/[root-of-the-server]__e5df5e5f._.js +3 -0
  121. package/.next/server/chunks/[root-of-the-server]__e5df5e5f._.js.map +1 -0
  122. package/.next/server/chunks/_next-internal_server_app_api_node_sessions_[id]_archive_route_actions_237255a5.js +3 -0
  123. package/.next/server/chunks/_next-internal_server_app_api_node_sessions_[id]_archive_route_actions_237255a5.js.map +1 -0
  124. package/.next/server/chunks/_next-internal_server_app_api_node_sessions_[id]_delete_route_actions_e5d426f6.js +3 -0
  125. package/.next/server/chunks/_next-internal_server_app_api_node_sessions_[id]_delete_route_actions_e5d426f6.js.map +1 -0
  126. package/.next/server/chunks/_next-internal_server_app_api_sessions_[id]_open-editor_route_actions_eaebf476.js +3 -0
  127. package/.next/server/chunks/_next-internal_server_app_api_sessions_[id]_open-editor_route_actions_eaebf476.js.map +1 -0
  128. package/.next/server/chunks/ce889_server_app_api_node_sessions_[id]_open-editor_route_actions_791cdf5b.js +3 -0
  129. package/.next/server/chunks/ce889_server_app_api_node_sessions_[id]_open-editor_route_actions_791cdf5b.js.map +1 -0
  130. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_7e181e75.js +1 -1
  131. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_7e181e75.js.map +1 -1
  132. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_b054aff3.js +1 -1
  133. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_b054aff3.js.map +1 -1
  134. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_fa835ac3.js +2 -2
  135. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_fa835ac3.js.map +1 -1
  136. package/.next/server/chunks/ssr/{[root-of-the-server]__efc52f08._.js → [root-of-the-server]__631e12d0._.js} +2 -2
  137. package/.next/server/chunks/ssr/[root-of-the-server]__a8cd3911._.js +3 -0
  138. package/.next/server/chunks/ssr/src_app_page_tsx_a7111f3e._.js +3 -3
  139. package/.next/server/chunks/ssr/src_app_page_tsx_a7111f3e._.js.map +1 -1
  140. package/.next/server/pages/404.html +1 -1
  141. package/.next/server/pages/500.html +2 -2
  142. package/.next/server/server-reference-manifest.js +1 -1
  143. package/.next/server/server-reference-manifest.json +1 -1
  144. package/.next/standalone/.next/BUILD_ID +1 -1
  145. package/.next/standalone/.next/app-path-routes-manifest.json +4 -0
  146. package/.next/standalone/.next/build-manifest.json +2 -2
  147. package/.next/standalone/.next/prerender-manifest.json +3 -3
  148. package/.next/standalone/.next/routes-manifest.json +32 -0
  149. package/.next/standalone/.next/server/app/_global-error/page.js +1 -1
  150. package/.next/standalone/.next/server/app/_global-error/page.js.nft.json +1 -1
  151. package/.next/standalone/.next/server/app/_global-error.html +2 -2
  152. package/.next/standalone/.next/server/app/_global-error.rsc +1 -1
  153. package/.next/standalone/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  154. package/.next/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  155. package/.next/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  156. package/.next/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  157. package/.next/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  158. package/.next/standalone/.next/server/app/_not-found/page.js +1 -1
  159. package/.next/standalone/.next/server/app/_not-found/page.js.nft.json +1 -1
  160. package/.next/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  161. package/.next/standalone/.next/server/app/_not-found.html +1 -1
  162. package/.next/standalone/.next/server/app/_not-found.rsc +2 -2
  163. package/.next/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +2 -2
  164. package/.next/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  165. package/.next/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +2 -2
  166. package/.next/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  167. package/.next/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  168. package/.next/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  169. package/.next/standalone/.next/server/app/api/node/events/route.js +1 -1
  170. package/.next/standalone/.next/server/app/api/node/events/route.js.nft.json +1 -1
  171. package/.next/standalone/.next/server/app/api/node/health/route.js +1 -1
  172. package/.next/standalone/.next/server/app/api/node/health/route.js.nft.json +1 -1
  173. package/.next/standalone/.next/server/app/api/node/sessions/[id]/archive/route/app-paths-manifest.json +3 -0
  174. package/.next/standalone/.next/server/app/api/node/sessions/[id]/archive/route/build-manifest.json +11 -0
  175. package/.next/standalone/.next/server/app/api/node/sessions/[id]/archive/route/server-reference-manifest.json +4 -0
  176. package/.next/standalone/.next/server/app/api/node/sessions/[id]/archive/route.js +6 -0
  177. package/.next/standalone/.next/server/app/api/node/sessions/[id]/archive/route.js.map +5 -0
  178. package/.next/standalone/.next/server/app/api/node/sessions/[id]/archive/route.js.nft.json +1 -0
  179. package/.next/standalone/.next/server/app/api/node/sessions/[id]/archive/route_client-reference-manifest.js +2 -0
  180. package/.next/standalone/.next/server/app/api/node/sessions/[id]/delete/route/app-paths-manifest.json +3 -0
  181. package/.next/standalone/.next/server/app/api/node/sessions/[id]/delete/route/build-manifest.json +11 -0
  182. package/.next/standalone/.next/server/app/api/node/sessions/[id]/delete/route/server-reference-manifest.json +4 -0
  183. package/.next/standalone/.next/server/app/api/node/sessions/[id]/delete/route.js +7 -0
  184. package/.next/standalone/.next/server/app/api/node/sessions/[id]/delete/route.js.map +5 -0
  185. package/.next/standalone/.next/server/app/api/node/sessions/[id]/delete/route.js.nft.json +1 -0
  186. package/.next/standalone/.next/server/app/api/node/sessions/[id]/delete/route_client-reference-manifest.js +2 -0
  187. package/.next/standalone/.next/server/app/api/node/sessions/[id]/open-editor/route/app-paths-manifest.json +3 -0
  188. package/.next/standalone/.next/server/app/api/node/sessions/[id]/open-editor/route/build-manifest.json +11 -0
  189. package/.next/standalone/.next/server/app/api/node/sessions/[id]/open-editor/route/server-reference-manifest.json +4 -0
  190. package/.next/standalone/.next/server/app/api/node/sessions/[id]/open-editor/route.js +7 -0
  191. package/.next/standalone/.next/server/app/api/node/sessions/[id]/open-editor/route.js.map +5 -0
  192. package/.next/standalone/.next/server/app/api/node/sessions/[id]/open-editor/route.js.nft.json +1 -0
  193. package/.next/standalone/.next/server/app/api/node/sessions/[id]/open-editor/route_client-reference-manifest.js +2 -0
  194. package/.next/standalone/.next/server/app/api/node/sessions/route.js +1 -1
  195. package/.next/standalone/.next/server/app/api/node/sessions/route.js.nft.json +1 -1
  196. package/.next/standalone/.next/server/app/api/opencode-events/route.js +1 -1
  197. package/.next/standalone/.next/server/app/api/opencode-events/route.js.nft.json +1 -1
  198. package/.next/standalone/.next/server/app/api/sessions/[id]/archive/route.js +2 -1
  199. package/.next/standalone/.next/server/app/api/sessions/[id]/archive/route.js.nft.json +1 -1
  200. package/.next/standalone/.next/server/app/api/sessions/[id]/delete/route.js +3 -2
  201. package/.next/standalone/.next/server/app/api/sessions/[id]/delete/route.js.nft.json +1 -1
  202. package/.next/standalone/.next/server/app/api/sessions/[id]/open-editor/route/app-paths-manifest.json +3 -0
  203. package/.next/standalone/.next/server/app/api/sessions/[id]/open-editor/route/build-manifest.json +11 -0
  204. package/.next/standalone/.next/server/app/api/sessions/[id]/open-editor/route/server-reference-manifest.json +4 -0
  205. package/.next/standalone/.next/server/app/api/sessions/[id]/open-editor/route.js +7 -0
  206. package/.next/standalone/.next/server/app/api/sessions/[id]/open-editor/route.js.map +5 -0
  207. package/.next/standalone/.next/server/app/api/sessions/[id]/open-editor/route.js.nft.json +1 -0
  208. package/.next/standalone/.next/server/app/api/sessions/[id]/open-editor/route_client-reference-manifest.js +2 -0
  209. package/.next/standalone/.next/server/app/api/sessions/route.js +1 -1
  210. package/.next/standalone/.next/server/app/api/sessions/route.js.nft.json +1 -1
  211. package/.next/standalone/.next/server/app/index.html +1 -1
  212. package/.next/standalone/.next/server/app/index.rsc +3 -3
  213. package/.next/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  214. package/.next/standalone/.next/server/app/index.segments/_full.segment.rsc +3 -3
  215. package/.next/standalone/.next/server/app/index.segments/_head.segment.rsc +1 -1
  216. package/.next/standalone/.next/server/app/index.segments/_index.segment.rsc +2 -2
  217. package/.next/standalone/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  218. package/.next/standalone/.next/server/app/page.js +1 -1
  219. package/.next/standalone/.next/server/app/page.js.nft.json +1 -1
  220. package/.next/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
  221. package/.next/standalone/.next/server/app-paths-manifest.json +4 -0
  222. package/.next/standalone/.next/server/chunks/[root-of-the-server]__1211da38._.js +3 -0
  223. package/.next/{server/chunks/[root-of-the-server]__b698889b._.js → standalone/.next/server/chunks/[root-of-the-server]__1b87ec42._.js} +2 -2
  224. package/.next/standalone/.next/server/chunks/[root-of-the-server]__2b526e7a._.js +3 -0
  225. package/.next/standalone/.next/server/chunks/[root-of-the-server]__2f981540._.js +3 -0
  226. package/.next/standalone/.next/server/chunks/[root-of-the-server]__3745b314._.js +3 -0
  227. package/.next/standalone/.next/server/chunks/[root-of-the-server]__56690af0._.js +1 -1
  228. package/.next/standalone/.next/server/chunks/[root-of-the-server]__56f5f249._.js +1 -1
  229. package/.next/standalone/.next/server/chunks/[root-of-the-server]__59175de4._.js +1 -1
  230. package/.next/standalone/.next/server/chunks/[root-of-the-server]__64fffc02._.js +1 -1
  231. package/.next/standalone/.next/server/chunks/[root-of-the-server]__6c428a24._.js +3 -0
  232. package/.next/standalone/.next/server/chunks/[root-of-the-server]__73a00b88._.js +3 -0
  233. package/.next/standalone/.next/server/chunks/[root-of-the-server]__89c5eeab._.js +1 -1
  234. package/.next/standalone/.next/server/chunks/[root-of-the-server]__8da6c5a8._.js +1 -1
  235. package/.next/standalone/.next/server/chunks/[root-of-the-server]__b796d06c._.js +1 -1
  236. package/.next/standalone/.next/server/chunks/[root-of-the-server]__c2ce5c0f._.js +1 -1
  237. package/.next/standalone/.next/server/chunks/[root-of-the-server]__d8e61048._.js +3 -0
  238. package/.next/standalone/.next/server/chunks/[root-of-the-server]__db285678._.js +3 -0
  239. package/.next/{server/chunks/[root-of-the-server]__16a9eb0a._.js → standalone/.next/server/chunks/[root-of-the-server]__e00a9200._.js} +2 -2
  240. package/.next/standalone/.next/server/chunks/[root-of-the-server]__e5df5e5f._.js +3 -0
  241. package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_node_sessions_[id]_archive_route_actions_237255a5.js +3 -0
  242. package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_node_sessions_[id]_delete_route_actions_e5d426f6.js +3 -0
  243. package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_sessions_[id]_open-editor_route_actions_eaebf476.js +3 -0
  244. package/.next/standalone/.next/server/chunks/ce889_server_app_api_node_sessions_[id]_open-editor_route_actions_791cdf5b.js +3 -0
  245. package/.next/standalone/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_7e181e75.js +1 -1
  246. package/.next/standalone/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_b054aff3.js +1 -1
  247. package/.next/standalone/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_fa835ac3.js +2 -2
  248. package/.next/standalone/.next/server/chunks/ssr/{[root-of-the-server]__efc52f08._.js → [root-of-the-server]__631e12d0._.js} +2 -2
  249. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__a8cd3911._.js +3 -0
  250. package/.next/standalone/.next/server/chunks/ssr/src_app_page_tsx_a7111f3e._.js +3 -3
  251. package/.next/standalone/.next/server/pages/404.html +1 -1
  252. package/.next/standalone/.next/server/pages/500.html +2 -2
  253. package/.next/standalone/.next/server/server-reference-manifest.js +1 -1
  254. package/.next/standalone/.next/server/server-reference-manifest.json +1 -1
  255. package/.next/standalone/.next/static/chunks/7ac19aaef01f4a03.js +13 -0
  256. package/.next/standalone/.next/static/chunks/f42202943f6742e5.css +3 -0
  257. package/.next/standalone/AGENTS.md +85 -0
  258. package/.next/standalone/README.md +76 -0
  259. package/.next/standalone/__mocks__/child_process.ts +4 -0
  260. package/.next/standalone/bin/dev-runtime.js +58 -0
  261. package/.next/standalone/bin/vibepulse.js +87 -0
  262. package/.next/standalone/check-hsql.mjs +71 -0
  263. package/.next/standalone/docs/session-status-detection.md +258 -0
  264. package/.next/standalone/eslint.config.mjs +31 -0
  265. package/.next/standalone/next.config.ts +8 -0
  266. package/.next/standalone/package-lock.json +10312 -0
  267. package/.next/standalone/package.json +1 -1
  268. package/.next/standalone/postcss.config.mjs +7 -0
  269. package/.next/standalone/src/AGENTS.md +41 -0
  270. package/.next/standalone/src/app/api/AGENTS.md +40 -0
  271. package/.next/standalone/src/app/api/node/events/route.test.ts +196 -0
  272. package/.next/standalone/src/app/api/node/events/route.ts +259 -0
  273. package/.next/standalone/src/app/api/node/health/route.test.ts +190 -0
  274. package/.next/standalone/src/app/api/node/health/route.ts +48 -0
  275. package/.next/standalone/src/app/api/node/sessions/[id]/archive/route.test.ts +128 -0
  276. package/.next/standalone/src/app/api/node/sessions/[id]/archive/route.ts +97 -0
  277. package/.next/standalone/src/app/api/node/sessions/[id]/delete/route.test.ts +113 -0
  278. package/.next/standalone/src/app/api/node/sessions/[id]/delete/route.ts +81 -0
  279. package/.next/standalone/src/app/api/node/sessions/[id]/open-editor/route.test.ts +206 -0
  280. package/.next/standalone/src/app/api/node/sessions/[id]/open-editor/route.ts +123 -0
  281. package/.next/standalone/src/app/api/node/sessions/route.test.ts +408 -0
  282. package/.next/standalone/src/app/api/node/sessions/route.ts +1094 -0
  283. package/.next/standalone/src/app/api/nodes/route.test.ts +237 -0
  284. package/.next/standalone/src/app/api/nodes/route.ts +176 -0
  285. package/.next/standalone/src/app/api/opencode-config/route.test.ts +86 -0
  286. package/.next/standalone/src/app/api/opencode-config/route.ts +376 -0
  287. package/.next/standalone/src/app/api/opencode-config/status/route.ts +31 -0
  288. package/.next/standalone/src/app/api/opencode-events/route.test.ts +624 -0
  289. package/.next/standalone/src/app/api/opencode-events/route.ts +508 -0
  290. package/.next/standalone/src/app/api/opencode-models/route.test.ts +167 -0
  291. package/.next/standalone/src/app/api/opencode-models/route.ts +76 -0
  292. package/.next/standalone/src/app/api/profiles/[id]/apply/route.ts +49 -0
  293. package/.next/standalone/src/app/api/profiles/[id]/export/route.ts +31 -0
  294. package/.next/standalone/src/app/api/profiles/[id]/route.ts +160 -0
  295. package/.next/standalone/src/app/api/profiles/import/route.test.js +107 -0
  296. package/.next/standalone/src/app/api/profiles/import/route.ts +65 -0
  297. package/.next/standalone/src/app/api/profiles/route.ts +107 -0
  298. package/.next/standalone/src/app/api/sessions/[id]/archive/route.test.ts +136 -0
  299. package/.next/standalone/src/app/api/sessions/[id]/archive/route.ts +170 -0
  300. package/.next/standalone/src/app/api/sessions/[id]/delete/route.test.ts +113 -0
  301. package/.next/standalone/src/app/api/sessions/[id]/delete/route.ts +137 -0
  302. package/.next/standalone/src/app/api/sessions/[id]/open-editor/route.test.ts +218 -0
  303. package/.next/standalone/src/app/api/sessions/[id]/open-editor/route.ts +85 -0
  304. package/.next/standalone/src/app/api/sessions/[id]/route.test.ts +531 -0
  305. package/.next/standalone/src/app/api/sessions/[id]/route.ts +75 -0
  306. package/.next/standalone/src/app/api/sessions/route.test.ts +1298 -0
  307. package/.next/standalone/src/app/api/sessions/route.ts +1695 -0
  308. package/.next/standalone/src/app/favicon.ico +0 -0
  309. package/.next/standalone/src/app/globals.css +66 -0
  310. package/.next/standalone/src/app/layout.tsx +37 -0
  311. package/.next/standalone/src/app/page.test.tsx +134 -0
  312. package/.next/standalone/src/app/page.tsx +358 -0
  313. package/.next/standalone/src/components/AGENTS.md +42 -0
  314. package/.next/standalone/src/components/ErrorBoundary.tsx +72 -0
  315. package/.next/standalone/src/components/KanbanBoard.test.tsx +704 -0
  316. package/.next/standalone/src/components/KanbanBoard.tsx +852 -0
  317. package/.next/standalone/src/components/LoadingState.tsx +37 -0
  318. package/.next/standalone/src/components/ProjectCard.test.tsx +773 -0
  319. package/.next/standalone/src/components/ProjectCard.tsx +595 -0
  320. package/.next/standalone/src/components/QueryProvider.tsx +25 -0
  321. package/.next/standalone/src/components/SessionCard.test.tsx +566 -0
  322. package/.next/standalone/src/components/SessionCard.tsx +434 -0
  323. package/.next/standalone/src/components/SessionList.tsx +60 -0
  324. package/.next/standalone/src/components/host-config/HostManagerDialog.test.tsx +252 -0
  325. package/.next/standalone/src/components/host-config/HostManagerDialog.tsx +476 -0
  326. package/.next/standalone/src/components/opencode-config/AgentConfigForm.test.tsx +72 -0
  327. package/.next/standalone/src/components/opencode-config/AgentConfigForm.tsx +483 -0
  328. package/.next/standalone/src/components/opencode-config/AgentModelSelector.tsx +284 -0
  329. package/.next/standalone/src/components/opencode-config/AgentsConfigPanel.tsx +162 -0
  330. package/.next/standalone/src/components/opencode-config/ConfigButton.tsx +43 -0
  331. package/.next/standalone/src/components/opencode-config/ConfigPanel.tsx +91 -0
  332. package/.next/standalone/src/components/opencode-config/FullscreenConfigPanel.tsx +435 -0
  333. package/.next/standalone/src/components/opencode-config/GeneralSettingsForm.test.tsx +91 -0
  334. package/.next/standalone/src/components/opencode-config/GeneralSettingsForm.tsx +288 -0
  335. package/.next/standalone/src/components/opencode-config/categories/CategoriesList.tsx +382 -0
  336. package/.next/standalone/src/components/opencode-config/categories/CategoriesManager.test.tsx +111 -0
  337. package/.next/standalone/src/components/opencode-config/categories/CategoriesManager.tsx +174 -0
  338. package/.next/standalone/src/components/opencode-config/categories/CategoryConfigForm.tsx +453 -0
  339. package/.next/standalone/src/components/opencode-config/profiles/ProfileCard.tsx +140 -0
  340. package/.next/standalone/src/components/opencode-config/profiles/ProfileEditor.tsx +446 -0
  341. package/.next/standalone/src/components/opencode-config/profiles/ProfileList.tsx +446 -0
  342. package/.next/standalone/src/components/opencode-config/profiles/ProfileManager.test.tsx +225 -0
  343. package/.next/standalone/src/components/opencode-config/profiles/ProfileManager.tsx +405 -0
  344. package/.next/standalone/src/components/ui/Tabs.tsx +59 -0
  345. package/.next/standalone/src/hooks/useHostSources.test.ts +509 -0
  346. package/.next/standalone/src/hooks/useHostSources.ts +299 -0
  347. package/.next/standalone/src/hooks/useOpencodeSync.test.ts +387 -0
  348. package/.next/standalone/src/hooks/useOpencodeSync.ts +571 -0
  349. package/.next/standalone/src/index.ts +2 -0
  350. package/.next/standalone/src/lib/editorLauncher.server.ts +36 -0
  351. package/.next/standalone/src/lib/editorLauncher.test.ts +35 -0
  352. package/.next/standalone/src/lib/editorLauncher.ts +25 -0
  353. package/.next/standalone/src/lib/hostAccent.test.ts +58 -0
  354. package/.next/standalone/src/lib/hostAccent.ts +46 -0
  355. package/.next/standalone/src/lib/hostIdentity.test.ts +187 -0
  356. package/.next/standalone/src/lib/hostIdentity.ts +122 -0
  357. package/.next/standalone/src/lib/hostSourcesStorage.test.ts +141 -0
  358. package/.next/standalone/src/lib/hostSourcesStorage.ts +72 -0
  359. package/.next/standalone/src/lib/nodeProtocol.test.ts +159 -0
  360. package/.next/standalone/src/lib/nodeProtocol.ts +142 -0
  361. package/.next/standalone/src/lib/nodeRegistry.test.ts +173 -0
  362. package/.next/standalone/src/lib/nodeRegistry.ts +398 -0
  363. package/.next/standalone/src/lib/notificationSound.ts +292 -0
  364. package/.next/standalone/src/lib/opencodeConfig.test.ts +100 -0
  365. package/.next/standalone/src/lib/opencodeConfig.ts +76 -0
  366. package/.next/standalone/src/lib/opencodeDiscovery.ts +275 -0
  367. package/.next/standalone/src/lib/profiles/share.test.ts +91 -0
  368. package/.next/standalone/src/lib/profiles/share.ts +93 -0
  369. package/.next/standalone/src/lib/profiles/storage.test.ts +108 -0
  370. package/.next/standalone/src/lib/profiles/storage.ts +370 -0
  371. package/.next/standalone/src/lib/runtimeMode.test.ts +29 -0
  372. package/.next/standalone/src/lib/runtimeMode.ts +29 -0
  373. package/.next/standalone/src/lib/sessionActionErrors.ts +37 -0
  374. package/.next/standalone/src/lib/sessionArchiveOverrides.test.ts +43 -0
  375. package/.next/standalone/src/lib/sessionArchiveOverrides.ts +116 -0
  376. package/.next/standalone/src/lib/transform.test.ts +121 -0
  377. package/.next/standalone/src/lib/transform.ts +193 -0
  378. package/.next/standalone/src/test/setup.ts +8 -0
  379. package/.next/standalone/src/types/index.ts +152 -0
  380. package/.next/standalone/src/types/opencodeConfig.ts +149 -0
  381. package/.next/standalone/tsconfig.json +34 -0
  382. package/.next/standalone/tsconfig.lib.json +17 -0
  383. package/.next/standalone/vitest.config.ts +16 -0
  384. package/.next/static/chunks/7ac19aaef01f4a03.js +13 -0
  385. package/.next/static/chunks/f42202943f6742e5.css +3 -0
  386. package/.next/trace +1 -1
  387. package/.next/trace-build +1 -1
  388. package/.next/types/routes.d.ts +5 -1
  389. package/.next/types/validator.ts +36 -0
  390. package/package.json +1 -1
  391. package/.next/server/chunks/[root-of-the-server]__0b017945._.js +0 -3
  392. package/.next/server/chunks/[root-of-the-server]__0b017945._.js.map +0 -1
  393. package/.next/server/chunks/[root-of-the-server]__1e118bd3._.js +0 -3
  394. package/.next/server/chunks/[root-of-the-server]__1e118bd3._.js.map +0 -1
  395. package/.next/server/chunks/[root-of-the-server]__6979e732._.js +0 -3
  396. package/.next/server/chunks/[root-of-the-server]__6979e732._.js.map +0 -1
  397. package/.next/server/chunks/[root-of-the-server]__a7b4d79d._.js +0 -3
  398. package/.next/server/chunks/[root-of-the-server]__a7b4d79d._.js.map +0 -1
  399. package/.next/server/chunks/[root-of-the-server]__b698889b._.js.map +0 -1
  400. package/.next/server/chunks/[root-of-the-server]__ddc251b7._.js +0 -3
  401. package/.next/server/chunks/[root-of-the-server]__ddc251b7._.js.map +0 -1
  402. package/.next/server/chunks/ssr/[root-of-the-server]__b0788643._.js +0 -3
  403. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0b017945._.js +0 -3
  404. package/.next/standalone/.next/server/chunks/[root-of-the-server]__1e118bd3._.js +0 -3
  405. package/.next/standalone/.next/server/chunks/[root-of-the-server]__6979e732._.js +0 -3
  406. package/.next/standalone/.next/server/chunks/[root-of-the-server]__a7b4d79d._.js +0 -3
  407. package/.next/standalone/.next/server/chunks/[root-of-the-server]__ddc251b7._.js +0 -3
  408. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__b0788643._.js +0 -3
  409. package/.next/standalone/.next/static/chunks/9f8c22002e7395e8.js +0 -13
  410. package/.next/standalone/.next/static/chunks/f1b55db60e7ed6f3.css +0 -3
  411. package/.next/static/chunks/9f8c22002e7395e8.js +0 -13
  412. package/.next/static/chunks/f1b55db60e7ed6f3.css +0 -3
  413. /package/.next/server/chunks/ssr/{[root-of-the-server]__efc52f08._.js.map → [root-of-the-server]__631e12d0._.js.map} +0 -0
  414. /package/.next/server/chunks/ssr/{[root-of-the-server]__b0788643._.js.map → [root-of-the-server]__a8cd3911._.js.map} +0 -0
  415. /package/.next/standalone/.next/static/{L_tmqf71LaeMzApO4SiU- → Fw2R3y-fHX4B2SWxNy_4X}/_buildManifest.js +0 -0
  416. /package/.next/standalone/.next/static/{L_tmqf71LaeMzApO4SiU- → Fw2R3y-fHX4B2SWxNy_4X}/_clientMiddlewareManifest.json +0 -0
  417. /package/.next/standalone/.next/static/{L_tmqf71LaeMzApO4SiU- → Fw2R3y-fHX4B2SWxNy_4X}/_ssgManifest.js +0 -0
  418. /package/.next/static/{L_tmqf71LaeMzApO4SiU- → Fw2R3y-fHX4B2SWxNy_4X}/_buildManifest.js +0 -0
  419. /package/.next/static/{L_tmqf71LaeMzApO4SiU- → Fw2R3y-fHX4B2SWxNy_4X}/_clientMiddlewareManifest.json +0 -0
  420. /package/.next/static/{L_tmqf71LaeMzApO4SiU- → Fw2R3y-fHX4B2SWxNy_4X}/_ssgManifest.js +0 -0
@@ -0,0 +1,566 @@
1
+ import * as React from 'react';
2
+ import * as tlReact from '@testing-library/react';
3
+ import userEvent from '@testing-library/user-event';
4
+ import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
5
+ import { beforeEach, describe, expect, it, vi } from 'vitest';
6
+
7
+ import { SessionCard } from './SessionCard';
8
+ import type { KanbanCard } from '@/types';
9
+
10
+ const { render, screen, fireEvent, waitFor } = tlReact;
11
+
12
+ function renderWithProviders(ui: React.ReactElement) {
13
+ const queryClient = new QueryClient({
14
+ defaultOptions: {
15
+ queries: { retry: false },
16
+ mutations: { retry: false },
17
+ },
18
+ });
19
+
20
+ return render(
21
+ <QueryClientProvider client={queryClient}>
22
+ {ui}
23
+ </QueryClientProvider>
24
+ );
25
+ }
26
+
27
+ function createCard(overrides: Partial<KanbanCard> = {}): KanbanCard {
28
+ return {
29
+ id: 'node-1:ses_123',
30
+ sessionSlug: 'ses_123',
31
+ title: 'Remote Session',
32
+ directory: '/tmp/demo',
33
+ projectName: 'demo',
34
+ agents: [],
35
+ messageCount: 0,
36
+ status: 'idle',
37
+ opencodeStatus: 'idle',
38
+ waitingForUser: false,
39
+ todosTotal: 0,
40
+ todosCompleted: 0,
41
+ createdAt: 1000,
42
+ updatedAt: 2000,
43
+ sortOrder: 0,
44
+ hostId: 'node-1',
45
+ hostLabel: 'Node 1',
46
+ hostKind: 'remote',
47
+ hostBaseUrl: 'https://node-1.test',
48
+ rawSessionId: 'ses_123',
49
+ readOnly: false,
50
+ ...overrides,
51
+ };
52
+ }
53
+
54
+ describe('SessionCard', () => {
55
+ beforeEach(() => {
56
+ vi.clearAllMocks();
57
+ window.localStorage.clear();
58
+ Object.defineProperty(window, 'location', {
59
+ value: {
60
+ assign: vi.fn(),
61
+ hostname: 'localhost',
62
+ },
63
+ configurable: true,
64
+ writable: true,
65
+ });
66
+ });
67
+
68
+ it('keeps URI-based open behavior for remote sessions when target mode is hub', async () => {
69
+ const queryClient = new QueryClient({
70
+ defaultOptions: {
71
+ queries: { retry: false },
72
+ },
73
+ });
74
+ queryClient.setQueryData(['opencode-config'], { vibepulse: { openEditorTargetMode: 'hub' } });
75
+ const fetchMock = vi.fn(async (_input: RequestInfo | URL, init?: RequestInit) => {
76
+ if (!init?.method || init.method === 'GET') {
77
+ return new Response(JSON.stringify({ vibepulse: { openEditorTargetMode: 'hub' } }), {
78
+ status: 200,
79
+ headers: { 'Content-Type': 'application/json' },
80
+ });
81
+ }
82
+
83
+ return new Response(JSON.stringify({ success: true }), {
84
+ status: 200,
85
+ headers: { 'Content-Type': 'application/json' },
86
+ });
87
+ });
88
+ Object.defineProperty(globalThis, 'fetch', { value: fetchMock, configurable: true });
89
+
90
+ render(
91
+ <QueryClientProvider client={queryClient}>
92
+ <SessionCard card={createCard()} />
93
+ </QueryClientProvider>
94
+ );
95
+
96
+ await screen.findByText('Remote Session');
97
+ fireEvent.doubleClick(screen.getByRole('button', { name: /remote session/i }));
98
+
99
+ expect(window.location.assign).toHaveBeenCalledWith('vscode://vscode-remote/ssh-remote+node-1.test/tmp/demo');
100
+ expect((fetchMock.mock.calls as unknown as Array<[RequestInfo | URL, RequestInit | undefined]>).filter(([, init]) => init?.method === 'POST')).toHaveLength(0);
101
+ });
102
+
103
+ it('prefers stored SSH host overrides for remote hub-mode opens', async () => {
104
+ window.localStorage.setItem('vibepulse:ssh-host', 'override-host.test');
105
+ const queryClient = new QueryClient({
106
+ defaultOptions: {
107
+ queries: { retry: false },
108
+ },
109
+ });
110
+ queryClient.setQueryData(['opencode-config'], { vibepulse: { openEditorTargetMode: 'hub' } });
111
+ const fetchMock = vi.fn(async (_input: RequestInfo | URL, init?: RequestInit) => {
112
+ if (!init?.method || init.method === 'GET') {
113
+ return new Response(JSON.stringify({ vibepulse: { openEditorTargetMode: 'hub' } }), {
114
+ status: 200,
115
+ headers: { 'Content-Type': 'application/json' },
116
+ });
117
+ }
118
+
119
+ return new Response(JSON.stringify({ success: true }), {
120
+ status: 200,
121
+ headers: { 'Content-Type': 'application/json' },
122
+ });
123
+ });
124
+ Object.defineProperty(globalThis, 'fetch', { value: fetchMock, configurable: true });
125
+
126
+ render(
127
+ <QueryClientProvider client={queryClient}>
128
+ <SessionCard card={createCard()} />
129
+ </QueryClientProvider>
130
+ );
131
+
132
+ await screen.findByText('Remote Session');
133
+ fireEvent.doubleClick(screen.getByRole('button', { name: /remote session/i }));
134
+
135
+ expect(window.location.assign).toHaveBeenCalledWith('vscode://vscode-remote/ssh-remote+override-host.test/tmp/demo');
136
+ expect((fetchMock.mock.calls as unknown as Array<[RequestInfo | URL, RequestInit | undefined]>).filter(([, init]) => init?.method === 'POST')).toHaveLength(0);
137
+ });
138
+
139
+ it('shows an explicit error for remote hub-mode Antigravity opens', async () => {
140
+ window.localStorage.setItem('vibepulse:open-tool', 'antigravity');
141
+ const queryClient = new QueryClient({
142
+ defaultOptions: {
143
+ queries: { retry: false },
144
+ },
145
+ });
146
+ queryClient.setQueryData(['opencode-config'], { vibepulse: { openEditorTargetMode: 'hub' } });
147
+ const fetchMock = vi.fn(async (_input: RequestInfo | URL, init?: RequestInit) => {
148
+ if (!init?.method || init.method === 'GET') {
149
+ return new Response(JSON.stringify({ vibepulse: { openEditorTargetMode: 'hub' } }), {
150
+ status: 200,
151
+ headers: { 'Content-Type': 'application/json' },
152
+ });
153
+ }
154
+
155
+ return new Response(JSON.stringify({ success: true }), {
156
+ status: 200,
157
+ headers: { 'Content-Type': 'application/json' },
158
+ });
159
+ });
160
+ Object.defineProperty(globalThis, 'fetch', { value: fetchMock, configurable: true });
161
+
162
+ render(
163
+ <QueryClientProvider client={queryClient}>
164
+ <SessionCard card={createCard()} />
165
+ </QueryClientProvider>
166
+ );
167
+
168
+ await screen.findByText('Remote Session');
169
+ fireEvent.doubleClick(screen.getByRole('button', { name: /remote session/i }));
170
+
171
+ expect(await screen.findByText('Antigravity does not support hub-mode remote opens. Use VS Code or switch target mode to Remote node.')).toBeTruthy();
172
+ expect(window.location.assign).not.toHaveBeenCalled();
173
+ expect((fetchMock.mock.calls as unknown as Array<[RequestInfo | URL, RequestInit | undefined]>).filter(([, init]) => init?.method === 'POST')).toHaveLength(0);
174
+ });
175
+
176
+ it('keeps local sessions on the existing file-based open flow', async () => {
177
+ window.localStorage.setItem('vibepulse:ssh-host', 'node-1.test');
178
+ const fetchMock = vi.fn(async () => new Response(JSON.stringify({ vibepulse: { openEditorTargetMode: 'remote' } }), {
179
+ status: 200,
180
+ headers: { 'Content-Type': 'application/json' },
181
+ }));
182
+ Object.defineProperty(globalThis, 'fetch', { value: fetchMock, configurable: true });
183
+
184
+ renderWithProviders(<SessionCard card={createCard({
185
+ id: 'local:ses_local_123',
186
+ hostId: 'local',
187
+ hostLabel: 'Local',
188
+ hostKind: 'local',
189
+ hostBaseUrl: undefined,
190
+ })} />);
191
+
192
+ await screen.findByText('Remote Session');
193
+ fireEvent.doubleClick(screen.getByRole('button', { name: /remote session/i }));
194
+
195
+ expect(window.location.assign).toHaveBeenCalledWith('vscode://file/tmp/demo');
196
+ expect((fetchMock.mock.calls as unknown as Array<[RequestInfo | URL, RequestInit | undefined]>).filter(([, init]) => init?.method === 'POST')).toHaveLength(0);
197
+ });
198
+
199
+ it('calls the hub open-editor route for remote mode remote sessions', async () => {
200
+ const queryClient = new QueryClient({
201
+ defaultOptions: {
202
+ queries: { retry: false },
203
+ },
204
+ });
205
+ queryClient.setQueryData(['opencode-config'], { vibepulse: { openEditorTargetMode: 'remote' } });
206
+ const fetchMock = vi.fn(async (_input: RequestInfo | URL, init?: RequestInit) => {
207
+ return new Response(JSON.stringify({ success: true }), {
208
+ status: 200,
209
+ headers: { 'Content-Type': 'application/json' },
210
+ });
211
+ });
212
+ Object.defineProperty(globalThis, 'fetch', { value: fetchMock, configurable: true });
213
+
214
+ render(
215
+ <QueryClientProvider client={queryClient}>
216
+ <SessionCard card={createCard()} />
217
+ </QueryClientProvider>
218
+ );
219
+
220
+ await screen.findByText('Remote Session');
221
+ await waitFor(() => {
222
+ expect(screen.getByRole('button', { name: /remote session/i })).not.toBeDisabled();
223
+ });
224
+ fireEvent.doubleClick(screen.getByRole('button', { name: /remote session/i }));
225
+
226
+ await waitFor(() => {
227
+ expect(fetchMock).toHaveBeenCalledWith('/api/sessions/node-1:ses_123/open-editor', expect.objectContaining({
228
+ method: 'POST',
229
+ }));
230
+ });
231
+
232
+ const postCall = fetchMock.mock.calls.find(([, init]) => init?.method === 'POST');
233
+ expect(JSON.parse(String(postCall?.[1]?.body))).toEqual({ tool: 'vscode' });
234
+ expect(window.location.assign).not.toHaveBeenCalled();
235
+ });
236
+
237
+ it('shows an explicit loading state while a remote open request is in flight', async () => {
238
+ const queryClient = new QueryClient({
239
+ defaultOptions: {
240
+ queries: { retry: false },
241
+ },
242
+ });
243
+ queryClient.setQueryData(['opencode-config'], { vibepulse: { openEditorTargetMode: 'remote' } });
244
+ const deferred: { resolve: null | (() => void) } = { resolve: null };
245
+ const fetchMock = vi.fn(async (_input: RequestInfo | URL, init?: RequestInit) => {
246
+ await new Promise<void>((resolve) => {
247
+ deferred.resolve = resolve;
248
+ });
249
+
250
+ return new Response(JSON.stringify({ success: true }), {
251
+ status: 200,
252
+ headers: { 'Content-Type': 'application/json' },
253
+ });
254
+ });
255
+ Object.defineProperty(globalThis, 'fetch', { value: fetchMock, configurable: true });
256
+
257
+ render(
258
+ <QueryClientProvider client={queryClient}>
259
+ <SessionCard card={createCard()} />
260
+ </QueryClientProvider>
261
+ );
262
+
263
+ await screen.findByText('Remote Session');
264
+ await waitFor(() => {
265
+ expect(screen.getByRole('button', { name: /remote session/i })).not.toBeDisabled();
266
+ });
267
+ fireEvent.doubleClick(screen.getByRole('button', { name: /remote session/i }));
268
+
269
+ expect(await screen.findByText('Opening…')).toBeTruthy();
270
+ if (deferred.resolve) {
271
+ deferred.resolve();
272
+ }
273
+ await waitFor(() => {
274
+ expect(screen.queryByText('Opening…')).toBeNull();
275
+ });
276
+ });
277
+
278
+ it('shows explicit error feedback when a remote archive action fails', async () => {
279
+ const fetchMock = vi.fn(async (input: RequestInfo | URL, init?: RequestInit) => {
280
+ const url = String(input);
281
+ if (!init?.method || init.method === 'GET') {
282
+ return new Response(JSON.stringify({ vibepulse: { openEditorTargetMode: 'remote' } }), {
283
+ status: 200,
284
+ headers: { 'Content-Type': 'application/json' },
285
+ });
286
+ }
287
+
288
+ if (url === '/api/sessions/node-1:ses_123/archive') {
289
+ return new Response(JSON.stringify({ error: 'Remote archive failed' }), {
290
+ status: 503,
291
+ headers: { 'Content-Type': 'application/json' },
292
+ });
293
+ }
294
+
295
+ return new Response(JSON.stringify({ success: true }), {
296
+ status: 200,
297
+ headers: { 'Content-Type': 'application/json' },
298
+ });
299
+ });
300
+ Object.defineProperty(globalThis, 'fetch', { value: fetchMock, configurable: true });
301
+
302
+ const user = userEvent.setup();
303
+ renderWithProviders(<SessionCard card={createCard()} />);
304
+
305
+ await screen.findByText('Remote Session');
306
+ await user.click(screen.getByTitle('Actions'));
307
+ await user.click(screen.getByRole('button', { name: 'Archive' }));
308
+
309
+ expect(await screen.findByText('Remote archive failed')).toBeTruthy();
310
+ });
311
+
312
+ it('invalidates the sessions query after a successful remote archive action', async () => {
313
+ const fetchMock = vi.fn(async (_input: RequestInfo | URL, init?: RequestInit) => {
314
+ if (!init?.method || init.method === 'GET') {
315
+ return new Response(JSON.stringify({ vibepulse: { openEditorTargetMode: 'remote' } }), {
316
+ status: 200,
317
+ headers: { 'Content-Type': 'application/json' },
318
+ });
319
+ }
320
+
321
+ return new Response(JSON.stringify({ success: true }), {
322
+ status: 200,
323
+ headers: { 'Content-Type': 'application/json' },
324
+ });
325
+ });
326
+ Object.defineProperty(globalThis, 'fetch', { value: fetchMock, configurable: true });
327
+
328
+ const queryClient = new QueryClient({
329
+ defaultOptions: {
330
+ queries: { retry: false },
331
+ },
332
+ });
333
+ const invalidateQueriesSpy = vi.spyOn(queryClient, 'invalidateQueries');
334
+ const user = userEvent.setup();
335
+
336
+ render(
337
+ <QueryClientProvider client={queryClient}>
338
+ <SessionCard card={createCard()} />
339
+ </QueryClientProvider>
340
+ );
341
+
342
+ await screen.findByText('Remote Session');
343
+ await user.click(screen.getByTitle('Actions'));
344
+ await user.click(screen.getByRole('button', { name: 'Archive' }));
345
+
346
+ await waitFor(() => {
347
+ expect(invalidateQueriesSpy).toHaveBeenCalledWith({ queryKey: ['sessions'] });
348
+ });
349
+ });
350
+
351
+ it('invalidates the sessions query after a successful remote delete action', async () => {
352
+ const fetchMock = vi.fn(async (_input: RequestInfo | URL, init?: RequestInit) => {
353
+ if (!init?.method || init.method === 'GET') {
354
+ return new Response(JSON.stringify({ vibepulse: { openEditorTargetMode: 'remote' } }), {
355
+ status: 200,
356
+ headers: { 'Content-Type': 'application/json' },
357
+ });
358
+ }
359
+
360
+ return new Response(JSON.stringify({ success: true }), {
361
+ status: 200,
362
+ headers: { 'Content-Type': 'application/json' },
363
+ });
364
+ });
365
+ Object.defineProperty(globalThis, 'fetch', { value: fetchMock, configurable: true });
366
+
367
+ const queryClient = new QueryClient({
368
+ defaultOptions: {
369
+ queries: { retry: false },
370
+ },
371
+ });
372
+ const invalidateQueriesSpy = vi.spyOn(queryClient, 'invalidateQueries');
373
+ const user = userEvent.setup();
374
+
375
+ render(
376
+ <QueryClientProvider client={queryClient}>
377
+ <SessionCard card={createCard()} />
378
+ </QueryClientProvider>
379
+ );
380
+
381
+ await screen.findByText('Remote Session');
382
+ await user.click(screen.getByTitle('Actions'));
383
+ await user.click(screen.getByRole('button', { name: 'Delete' }));
384
+
385
+ await waitFor(() => {
386
+ expect(invalidateQueriesSpy).toHaveBeenCalledWith({ queryKey: ['sessions'] });
387
+ });
388
+ });
389
+
390
+ it('shows explicit error feedback when a remote delete action fails', async () => {
391
+ const fetchMock = vi.fn(async (input: RequestInfo | URL, init?: RequestInit) => {
392
+ const url = String(input);
393
+ if (!init?.method || init.method === 'GET') {
394
+ return new Response(JSON.stringify({ vibepulse: { openEditorTargetMode: 'remote' } }), {
395
+ status: 200,
396
+ headers: { 'Content-Type': 'application/json' },
397
+ });
398
+ }
399
+
400
+ if (url === '/api/sessions/node-1:ses_123/delete') {
401
+ return new Response(JSON.stringify({ reason: 'unauthorized' }), {
402
+ status: 401,
403
+ headers: { 'Content-Type': 'application/json' },
404
+ });
405
+ }
406
+
407
+ return new Response(JSON.stringify({ success: true }), {
408
+ status: 200,
409
+ headers: { 'Content-Type': 'application/json' },
410
+ });
411
+ });
412
+ Object.defineProperty(globalThis, 'fetch', { value: fetchMock, configurable: true });
413
+
414
+ const user = userEvent.setup();
415
+ renderWithProviders(<SessionCard card={createCard()} />);
416
+
417
+ await screen.findByText('Remote Session');
418
+ await user.click(screen.getByTitle('Actions'));
419
+ await user.click(screen.getByRole('button', { name: 'Delete' }));
420
+
421
+ expect(await screen.findByText('Remote node rejected the request. Check node access token settings.')).toBeTruthy();
422
+ });
423
+
424
+ it('shows explicit error feedback when remote open fails and does not fall back locally', async () => {
425
+ const queryClient = new QueryClient({
426
+ defaultOptions: {
427
+ queries: { retry: false },
428
+ },
429
+ });
430
+ queryClient.setQueryData(['opencode-config'], { vibepulse: { openEditorTargetMode: 'remote' } });
431
+ const fetchMock = vi.fn(async (_input: RequestInfo | URL, init?: RequestInit) => {
432
+ return new Response(JSON.stringify({ reason: 'editor_unavailable' }), {
433
+ status: 503,
434
+ headers: { 'Content-Type': 'application/json' },
435
+ });
436
+ });
437
+ Object.defineProperty(globalThis, 'fetch', { value: fetchMock, configurable: true });
438
+
439
+ render(
440
+ <QueryClientProvider client={queryClient}>
441
+ <SessionCard card={createCard()} />
442
+ </QueryClientProvider>
443
+ );
444
+
445
+ await screen.findByText('Remote Session');
446
+ await waitFor(() => {
447
+ expect(screen.getByRole('button', { name: /remote session/i })).not.toBeDisabled();
448
+ });
449
+ fireEvent.doubleClick(screen.getByRole('button', { name: /remote session/i }));
450
+
451
+ expect(await screen.findByText('Remote node could not open the editor on that machine.')).toBeTruthy();
452
+ expect(window.location.assign).not.toHaveBeenCalled();
453
+ });
454
+
455
+ it('maps unsupported remote open-editor responses to the compatibility message', async () => {
456
+ const queryClient = new QueryClient({
457
+ defaultOptions: {
458
+ queries: { retry: false },
459
+ },
460
+ });
461
+ queryClient.setQueryData(['opencode-config'], { vibepulse: { openEditorTargetMode: 'remote' } });
462
+ const fetchMock = vi.fn(async (_input: RequestInfo | URL, init?: RequestInit) => {
463
+ return new Response(JSON.stringify({ reason: 'node_request_failed_501' }), {
464
+ status: 501,
465
+ headers: { 'Content-Type': 'application/json' },
466
+ });
467
+ });
468
+ Object.defineProperty(globalThis, 'fetch', { value: fetchMock, configurable: true });
469
+
470
+ render(
471
+ <QueryClientProvider client={queryClient}>
472
+ <SessionCard card={createCard()} />
473
+ </QueryClientProvider>
474
+ );
475
+
476
+ await screen.findByText('Remote Session');
477
+ await waitFor(() => {
478
+ expect(screen.getByRole('button', { name: /remote session/i })).not.toBeDisabled();
479
+ });
480
+ fireEvent.doubleClick(screen.getByRole('button', { name: /remote session/i }));
481
+
482
+ expect(await screen.findByText('Remote node does not support this action yet.')).toBeTruthy();
483
+ });
484
+
485
+ it('shows the session-not-found message when the remote node reports the session is gone', async () => {
486
+ const queryClient = new QueryClient({
487
+ defaultOptions: {
488
+ queries: { retry: false },
489
+ },
490
+ });
491
+ queryClient.setQueryData(['opencode-config'], { vibepulse: { openEditorTargetMode: 'remote' } });
492
+ const fetchMock = vi.fn(async (_input: RequestInfo | URL, init?: RequestInit) => {
493
+ return new Response(JSON.stringify({
494
+ error: 'Session not found',
495
+ reason: 'session_not_found',
496
+ }), {
497
+ status: 404,
498
+ headers: { 'Content-Type': 'application/json' },
499
+ });
500
+ });
501
+ Object.defineProperty(globalThis, 'fetch', { value: fetchMock, configurable: true });
502
+
503
+ render(
504
+ <QueryClientProvider client={queryClient}>
505
+ <SessionCard card={createCard()} />
506
+ </QueryClientProvider>
507
+ );
508
+
509
+ await screen.findByText('Remote Session');
510
+ await waitFor(() => {
511
+ expect(screen.getByRole('button', { name: /remote session/i })).not.toBeDisabled();
512
+ });
513
+ fireEvent.doubleClick(screen.getByRole('button', { name: /remote session/i }));
514
+
515
+ expect(await screen.findByText('Session was not found.')).toBeTruthy();
516
+ });
517
+
518
+ it('shows a loading-settings state before remote open mode is hydrated', async () => {
519
+ const fetchMock = vi.fn(async () => new Promise<Response>(() => {}));
520
+ Object.defineProperty(globalThis, 'fetch', { value: fetchMock, configurable: true });
521
+
522
+ renderWithProviders(<SessionCard card={createCard()} />);
523
+
524
+ expect(await screen.findByText('Loading open settings…')).toBeTruthy();
525
+ expect(screen.getByRole('button', { name: /remote session/i })).toBeDisabled();
526
+ });
527
+
528
+ it('shows an error and keeps remote open disabled when config loading fails', async () => {
529
+ const fetchMock = vi.fn(async () => {
530
+ throw new Error('config failed');
531
+ });
532
+ Object.defineProperty(globalThis, 'fetch', { value: fetchMock, configurable: true });
533
+
534
+ renderWithProviders(<SessionCard card={createCard()} />);
535
+
536
+ expect(await screen.findByText('Failed to load open settings. Remote open is unavailable until configuration loads.')).toBeTruthy();
537
+ expect(screen.getByRole('button', { name: /remote session/i })).toBeDisabled();
538
+ });
539
+
540
+ it('shows explicit error feedback when remote action fetch rejects', async () => {
541
+ const queryClient = new QueryClient({
542
+ defaultOptions: {
543
+ queries: { retry: false },
544
+ },
545
+ });
546
+ queryClient.setQueryData(['opencode-config'], { vibepulse: { openEditorTargetMode: 'remote' } });
547
+ const fetchMock = vi.fn(async (_input: RequestInfo | URL, init?: RequestInit) => {
548
+ throw new Error('network failed');
549
+ });
550
+ Object.defineProperty(globalThis, 'fetch', { value: fetchMock, configurable: true });
551
+
552
+ render(
553
+ <QueryClientProvider client={queryClient}>
554
+ <SessionCard card={createCard()} />
555
+ </QueryClientProvider>
556
+ );
557
+
558
+ await screen.findByText('Remote Session');
559
+ await waitFor(() => {
560
+ expect(screen.getByRole('button', { name: /remote session/i })).not.toBeDisabled();
561
+ });
562
+ fireEvent.doubleClick(screen.getByRole('button', { name: /remote session/i }));
563
+
564
+ expect(await screen.findByText('Remote node is offline or unreachable.')).toBeTruthy();
565
+ });
566
+ });