viba-cli 0.2.0 → 0.4.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 (196) hide show
  1. package/.next/BUILD_ID +1 -1
  2. package/.next/app-path-routes-manifest.json +3 -0
  3. package/.next/build-manifest.json +5 -5
  4. package/.next/fallback-build-manifest.json +2 -2
  5. package/.next/prerender-manifest.json +3 -3
  6. package/.next/required-server-files.js +11 -1
  7. package/.next/required-server-files.json +11 -1
  8. package/.next/routes-manifest.json +18 -0
  9. package/.next/server/app/_global-error/page/build-manifest.json +3 -3
  10. package/.next/server/app/_global-error/page.js +2 -2
  11. package/.next/server/app/_global-error/page.js.nft.json +1 -1
  12. package/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  13. package/.next/server/app/_global-error.html +2 -2
  14. package/.next/server/app/_global-error.rsc +7 -7
  15. package/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +2 -2
  16. package/.next/server/app/_global-error.segments/_full.segment.rsc +7 -7
  17. package/.next/server/app/_global-error.segments/_head.segment.rsc +3 -3
  18. package/.next/server/app/_global-error.segments/_index.segment.rsc +3 -3
  19. package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  20. package/.next/server/app/_not-found/page/build-manifest.json +3 -3
  21. package/.next/server/app/_not-found/page.js +1 -1
  22. package/.next/server/app/_not-found/page.js.nft.json +1 -1
  23. package/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  24. package/.next/server/app/_not-found.html +1 -1
  25. package/.next/server/app/_not-found.rsc +9 -9
  26. package/.next/server/app/_not-found.segments/_full.segment.rsc +9 -9
  27. package/.next/server/app/_not-found.segments/_head.segment.rsc +4 -4
  28. package/.next/server/app/_not-found.segments/_index.segment.rsc +4 -4
  29. package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +2 -2
  30. package/.next/server/app/_not-found.segments/_not-found.segment.rsc +3 -3
  31. package/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  32. package/.next/server/app/api/component-source/resolve/route/app-paths-manifest.json +3 -0
  33. package/.next/server/app/api/component-source/resolve/route/build-manifest.json +11 -0
  34. package/.next/server/app/api/component-source/resolve/route/server-reference-manifest.json +4 -0
  35. package/.next/server/app/api/component-source/resolve/route.js +7 -0
  36. package/.next/server/app/api/component-source/resolve/route.js.map +5 -0
  37. package/.next/server/app/api/component-source/resolve/route.js.nft.json +1 -0
  38. package/.next/server/app/api/component-source/resolve/route_client-reference-manifest.js +2 -0
  39. package/.next/server/app/api/file-thumbnail/route/app-paths-manifest.json +3 -0
  40. package/.next/server/app/api/file-thumbnail/route/build-manifest.json +11 -0
  41. package/.next/server/app/api/file-thumbnail/route/server-reference-manifest.json +4 -0
  42. package/.next/server/app/api/file-thumbnail/route.js +6 -0
  43. package/.next/server/app/api/file-thumbnail/route.js.map +5 -0
  44. package/.next/server/app/api/file-thumbnail/route.js.nft.json +1 -0
  45. package/.next/server/app/api/file-thumbnail/route_client-reference-manifest.js +2 -0
  46. package/.next/server/app/api/preview-proxy/start/route/app-paths-manifest.json +3 -0
  47. package/.next/server/app/api/preview-proxy/start/route/build-manifest.json +11 -0
  48. package/.next/server/app/api/preview-proxy/start/route/server-reference-manifest.json +4 -0
  49. package/.next/server/app/api/preview-proxy/start/route.js +8 -0
  50. package/.next/server/app/api/preview-proxy/start/route.js.map +5 -0
  51. package/.next/server/app/api/preview-proxy/start/route.js.nft.json +1 -0
  52. package/.next/server/app/api/preview-proxy/start/route_client-reference-manifest.js +2 -0
  53. package/.next/server/app/icon.png/route.js +3 -1
  54. package/.next/server/app/icon.png/route.js.nft.json +1 -1
  55. package/.next/server/app/index.html +1 -1
  56. package/.next/server/app/index.rsc +10 -10
  57. package/.next/server/app/index.segments/__PAGE__.segment.rsc +4 -4
  58. package/.next/server/app/index.segments/_full.segment.rsc +10 -10
  59. package/.next/server/app/index.segments/_head.segment.rsc +4 -4
  60. package/.next/server/app/index.segments/_index.segment.rsc +4 -4
  61. package/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  62. package/.next/server/app/new/page/build-manifest.json +3 -3
  63. package/.next/server/app/new/page/server-reference-manifest.json +141 -36
  64. package/.next/server/app/new/page.js +3 -3
  65. package/.next/server/app/new/page.js.nft.json +1 -1
  66. package/.next/server/app/new/page_client-reference-manifest.js +1 -1
  67. package/.next/server/app/page/build-manifest.json +3 -3
  68. package/.next/server/app/page/server-reference-manifest.json +141 -36
  69. package/.next/server/app/page.js +3 -3
  70. package/.next/server/app/page.js.nft.json +1 -1
  71. package/.next/server/app/page_client-reference-manifest.js +1 -1
  72. package/.next/server/app/session/[sessionId]/page/build-manifest.json +3 -3
  73. package/.next/server/app/session/[sessionId]/page/server-reference-manifest.json +33 -18
  74. package/.next/server/app/session/[sessionId]/page.js +3 -3
  75. package/.next/server/app/session/[sessionId]/page.js.nft.json +1 -1
  76. package/.next/server/app/session/[sessionId]/page_client-reference-manifest.js +1 -1
  77. package/.next/server/app-paths-manifest.json +3 -0
  78. package/.next/server/chunks/[externals]__be7652c1._.js +3 -0
  79. package/.next/server/chunks/[externals]__be7652c1._.js.map +1 -0
  80. package/.next/server/chunks/[root-of-the-server]__2c2fecb1._.js +3 -0
  81. package/.next/server/chunks/[root-of-the-server]__2c2fecb1._.js.map +1 -0
  82. package/.next/server/chunks/[root-of-the-server]__8f5ebbc3._.js +7 -0
  83. package/.next/server/chunks/[root-of-the-server]__8f5ebbc3._.js.map +1 -0
  84. package/.next/server/chunks/[root-of-the-server]__c6a126af._.js +455 -0
  85. package/.next/server/chunks/[root-of-the-server]__c6a126af._.js.map +1 -0
  86. package/.next/server/chunks/[root-of-the-server]__ed7be8e0._.js +3 -0
  87. package/.next/server/chunks/[root-of-the-server]__ed7be8e0._.js.map +1 -0
  88. package/.next/server/chunks/_next-internal_server_app_api_component-source_resolve_route_actions_abcbcdd4.js +3 -0
  89. package/.next/server/chunks/_next-internal_server_app_api_component-source_resolve_route_actions_abcbcdd4.js.map +1 -0
  90. package/.next/server/chunks/_next-internal_server_app_api_file-thumbnail_route_actions_11144642.js +3 -0
  91. package/.next/server/chunks/_next-internal_server_app_api_file-thumbnail_route_actions_11144642.js.map +1 -0
  92. package/.next/server/chunks/_next-internal_server_app_api_preview-proxy_start_route_actions_b18728bd.js +3 -0
  93. package/.next/server/chunks/_next-internal_server_app_api_preview-proxy_start_route_actions_b18728bd.js.map +1 -0
  94. package/.next/server/chunks/node_modules_next_1402a1da._.js +17 -0
  95. package/.next/server/chunks/node_modules_next_1402a1da._.js.map +1 -0
  96. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_97dac613.js +3 -0
  97. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_97dac613.js.map +1 -0
  98. package/.next/server/chunks/ssr/[root-of-the-server]__086c4362._.js +3 -0
  99. package/.next/server/chunks/ssr/{[root-of-the-server]__62036393._.js.map → [root-of-the-server]__086c4362._.js.map} +1 -1
  100. package/.next/server/chunks/ssr/[root-of-the-server]__0f584432._.js +3 -0
  101. package/.next/server/chunks/ssr/{[root-of-the-server]__a5d13d54._.js.map → [root-of-the-server]__0f584432._.js.map} +1 -1
  102. package/.next/server/chunks/ssr/{[root-of-the-server]__f91abafd._.js → [root-of-the-server]__28c55180._.js} +2 -2
  103. package/.next/server/chunks/ssr/[root-of-the-server]__28c55180._.js.map +1 -0
  104. package/.next/server/chunks/ssr/[root-of-the-server]__30652385._.js +1 -1
  105. package/.next/server/chunks/ssr/[root-of-the-server]__30652385._.js.map +1 -1
  106. package/.next/server/chunks/ssr/[root-of-the-server]__41b2f23a._.js +4 -0
  107. package/.next/server/chunks/ssr/[root-of-the-server]__41b2f23a._.js.map +1 -0
  108. package/.next/server/chunks/ssr/{[root-of-the-server]__0092b3d0._.js → [root-of-the-server]__4604db7a._.js} +2 -2
  109. package/.next/server/chunks/ssr/{[root-of-the-server]__0092b3d0._.js.map → [root-of-the-server]__4604db7a._.js.map} +1 -1
  110. package/.next/server/chunks/ssr/{[root-of-the-server]__d7127f3c._.js → [root-of-the-server]__683e716d._.js} +2 -2
  111. package/.next/server/chunks/ssr/{[root-of-the-server]__d7127f3c._.js.map → [root-of-the-server]__683e716d._.js.map} +1 -1
  112. package/.next/server/chunks/ssr/[root-of-the-server]__8174ed94._.js +4 -0
  113. package/.next/server/chunks/ssr/{[root-of-the-server]__78288fbe._.js.map → [root-of-the-server]__8174ed94._.js.map} +1 -1
  114. package/.next/server/chunks/ssr/{[root-of-the-server]__606ef757._.js → [root-of-the-server]__90a96f44._.js} +2 -2
  115. package/.next/server/chunks/ssr/{[root-of-the-server]__606ef757._.js.map → [root-of-the-server]__90a96f44._.js.map} +1 -1
  116. package/.next/server/chunks/ssr/[root-of-the-server]__ca05f4a0._.js +4 -0
  117. package/.next/server/chunks/ssr/{[root-of-the-server]__cb11b5eb._.js.map → [root-of-the-server]__ca05f4a0._.js.map} +1 -1
  118. package/.next/server/chunks/ssr/{[root-of-the-server]__0d3b7eea._.js → [root-of-the-server]__ca21770d._.js} +2 -2
  119. package/.next/server/chunks/ssr/{[root-of-the-server]__0d3b7eea._.js.map → [root-of-the-server]__ca21770d._.js.map} +1 -1
  120. package/.next/server/chunks/ssr/[root-of-the-server]__d050ef76._.js +3 -0
  121. package/.next/server/chunks/ssr/[root-of-the-server]__d050ef76._.js.map +1 -0
  122. package/.next/server/chunks/ssr/[root-of-the-server]__ef9ee460._.js +3 -0
  123. package/.next/server/chunks/ssr/[root-of-the-server]__ef9ee460._.js.map +1 -0
  124. package/.next/server/chunks/ssr/[root-of-the-server]__f56dd853._.js +3 -0
  125. package/.next/server/chunks/ssr/[root-of-the-server]__f56dd853._.js.map +1 -0
  126. package/.next/server/chunks/ssr/[root-of-the-server]__fedccef4._.js +3 -0
  127. package/.next/server/chunks/ssr/[root-of-the-server]__fedccef4._.js.map +1 -0
  128. package/.next/server/chunks/ssr/{_428d8baf._.js → _0d86e805._.js} +5 -3
  129. package/.next/server/chunks/ssr/_0d86e805._.js.map +1 -0
  130. package/.next/server/chunks/ssr/_3bf0a72b._.js +1 -1
  131. package/.next/server/chunks/ssr/_776167a7._.js +8 -0
  132. package/.next/server/chunks/ssr/_776167a7._.js.map +1 -0
  133. package/.next/server/chunks/ssr/_c7edf537._.js +8 -0
  134. package/.next/server/chunks/ssr/_c7edf537._.js.map +1 -0
  135. package/.next/server/chunks/ssr/_eeb65f56._.js +1 -1
  136. package/.next/server/chunks/ssr/_ff04b309._.js +1 -1
  137. package/.next/server/chunks/ssr/node_modules_next_dist_08570d7f._.js +1 -1
  138. package/.next/server/chunks/ssr/node_modules_next_dist_174ae28d._.js +1 -1
  139. package/.next/server/chunks/ssr/node_modules_next_dist_65e60196._.js +1 -1
  140. package/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_02f39477.js +1 -1
  141. package/.next/server/chunks/ssr/node_modules_next_dist_f9713a08._.js +1 -1
  142. package/.next/server/chunks/ssr/src_app_session_[sessionId]_SessionPageClient_tsx_dab490d7._.js +2 -4
  143. package/.next/server/chunks/ssr/src_app_session_[sessionId]_SessionPageClient_tsx_dab490d7._.js.map +1 -1
  144. package/.next/server/chunks/ssr/src_components_GitRepoSelector_tsx_05c81afa._.js +7 -0
  145. package/.next/server/chunks/ssr/src_components_GitRepoSelector_tsx_05c81afa._.js.map +1 -0
  146. package/.next/server/functions-config-manifest.json +4 -1
  147. package/.next/server/middleware-build-manifest.js +3 -3
  148. package/.next/server/pages/404.html +1 -1
  149. package/.next/server/pages/500.html +2 -2
  150. package/.next/server/server-reference-manifest.js +1 -1
  151. package/.next/server/server-reference-manifest.json +247 -70
  152. package/.next/static/chunks/{8906ac8ef3ff98d4.js → 0b5678df432c3623.js} +2 -2
  153. package/.next/static/chunks/{d2be314c3ece3fbe.js → 3fb340759d3f1fa9.js} +1 -1
  154. package/.next/static/chunks/4e6ad003ac2161e9.js +3 -0
  155. package/.next/static/chunks/4f2e69f3f6111714.css +3 -0
  156. package/.next/static/chunks/5d3a8c54685c3cba.js +3 -0
  157. package/.next/static/chunks/63c0f97d9ace5d54.js +3 -0
  158. package/.next/static/chunks/782bb235cdcde1c5.js +5 -0
  159. package/.next/static/chunks/b77fa77a013ad38a.js +1 -0
  160. package/.next/static/chunks/b8c108917282d11f.js +3 -0
  161. package/.next/static/chunks/{turbopack-ad7617b01177e90b.js → turbopack-21e709cd17627354.js} +2 -2
  162. package/README.md +19 -17
  163. package/bin/viba.mjs +162 -1
  164. package/next.config.mjs +11 -0
  165. package/package.json +4 -3
  166. package/public/github.png +0 -0
  167. package/.next/server/chunks/[root-of-the-server]__c8bd587a._.js +0 -21
  168. package/.next/server/chunks/[root-of-the-server]__c8bd587a._.js.map +0 -1
  169. package/.next/server/chunks/ssr/[root-of-the-server]__2c2d9a9f._.js +0 -3
  170. package/.next/server/chunks/ssr/[root-of-the-server]__2c2d9a9f._.js.map +0 -1
  171. package/.next/server/chunks/ssr/[root-of-the-server]__4fb17f1e._.js +0 -3
  172. package/.next/server/chunks/ssr/[root-of-the-server]__4fb17f1e._.js.map +0 -1
  173. package/.next/server/chunks/ssr/[root-of-the-server]__62036393._.js +0 -3
  174. package/.next/server/chunks/ssr/[root-of-the-server]__78288fbe._.js +0 -4
  175. package/.next/server/chunks/ssr/[root-of-the-server]__91c2c151._.js +0 -3
  176. package/.next/server/chunks/ssr/[root-of-the-server]__91c2c151._.js.map +0 -1
  177. package/.next/server/chunks/ssr/[root-of-the-server]__a5d13d54._.js +0 -3
  178. package/.next/server/chunks/ssr/[root-of-the-server]__cb11b5eb._.js +0 -4
  179. package/.next/server/chunks/ssr/[root-of-the-server]__e138fbba._.js +0 -3
  180. package/.next/server/chunks/ssr/[root-of-the-server]__e138fbba._.js.map +0 -1
  181. package/.next/server/chunks/ssr/[root-of-the-server]__f91abafd._.js.map +0 -1
  182. package/.next/server/chunks/ssr/_428d8baf._.js.map +0 -1
  183. package/.next/server/chunks/ssr/_62292aba._.js +0 -9
  184. package/.next/server/chunks/ssr/_62292aba._.js.map +0 -1
  185. package/.next/server/chunks/ssr/_aa5732fe._.js +0 -6
  186. package/.next/server/chunks/ssr/_aa5732fe._.js.map +0 -1
  187. package/.next/static/chunks/12bdbae627ffd6a9.js +0 -1
  188. package/.next/static/chunks/27ca02b59173029b.css +0 -3
  189. package/.next/static/chunks/2821166934dd45eb.js +0 -1
  190. package/.next/static/chunks/6940d9a9bfdc4cce.js +0 -7
  191. package/.next/static/chunks/be321f8738ab63b8.js +0 -5
  192. package/.next/static/chunks/c7d6c67cca916a66.js +0 -1
  193. package/.next/static/chunks/efc46d6b5b55597f.js +0 -1
  194. /package/.next/static/{qKz4bayHWnbP-QHBKWJxn → XTFe2mYilGcKPRrQqw5uW}/_buildManifest.js +0 -0
  195. /package/.next/static/{qKz4bayHWnbP-QHBKWJxn → XTFe2mYilGcKPRrQqw5uW}/_clientMiddlewareManifest.json +0 -0
  196. /package/.next/static/{qKz4bayHWnbP-QHBKWJxn → XTFe2mYilGcKPRrQqw5uW}/_ssgManifest.js +0 -0
@@ -0,0 +1,3 @@
1
+ (globalThis.TURBOPACK||(globalThis.TURBOPACK=[])).push(["object"==typeof document?document.currentScript:void 0,36438,e=>{"use strict";var t=e.i(43476),r=e.i(71645),a=e.i(18566),n=e.i(95187);let s=(0,n.createServerReference)("40f0979d0ae67203d7f0fa141b2d4079a212b66f42",n.callServer,void 0,n.findSourceMapURL,"deleteSessionInBackground"),i=(0,n.createServerReference)("40047744bdae2d0d14309e8cc4c9db8ad121a9691b",n.callServer,void 0,n.findSourceMapURL,"getSessionDivergence"),l=(0,n.createServerReference)("408a0cf806f8e922a0fe9e7448da8cc966d5c62ae4",n.callServer,void 0,n.findSourceMapURL,"getSessionUncommittedFileCount"),o=(0,n.createServerReference)("409b9df630bc4e4a38d8f847dbbad1d187140c73e9",n.callServer,void 0,n.findSourceMapURL,"listSessionBaseBranches"),c=(0,n.createServerReference)("408e1363f4857a24088aec76a39d9b83e4a602216c",n.callServer,void 0,n.findSourceMapURL,"mergeSessionToBase"),d=(0,n.createServerReference)("40ff46a192f0e549c3f1d074fa25a0f8db986c6f41",n.callServer,void 0,n.findSourceMapURL,"rebaseSessionOntoBase"),u=(0,n.createServerReference)("60f93a70e69a2958d1f69615b0efc8134f26e2baa4",n.callServer,void 0,n.findSourceMapURL,"updateSessionBaseBranch"),h=(0,n.createServerReference)("6052582fed9da815bac8a4cc428026b81c86faed10",n.callServer,void 0,n.findSourceMapURL,"writeSessionPromptFile");var m=e.i(29589),p=e.i(25702),f=e.i(27612),b=e.i(75254);let x=(0,b.default)("external-link",[["path",{d:"M15 3h6v6",key:"1q9fwt"}],["path",{d:"M10 14 21 3",key:"gplh6r"}],["path",{d:"M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6",key:"a6xqqp"}]]);var v=e.i(31343);let w=(0,b.default)("git-commit-horizontal",[["circle",{cx:"12",cy:"12",r:"3",key:"1v7zrd"}],["line",{x1:"3",x2:"9",y1:"12",y2:"12",key:"1dyftd"}],["line",{x1:"15",x2:"21",y1:"12",y2:"12",key:"oup4p8"}]]),g=(0,b.default)("git-merge",[["circle",{cx:"18",cy:"18",r:"3",key:"1xkwt0"}],["circle",{cx:"6",cy:"6",r:"3",key:"1lh9wr"}],["path",{d:"M6 21V9a9 9 0 0 0 9 9",key:"7kw0sc"}]]),y=(0,b.default)("git-pull-request-arrow",[["circle",{cx:"5",cy:"6",r:"3",key:"1qnov2"}],["path",{d:"M5 9v12",key:"ih889a"}],["circle",{cx:"19",cy:"18",r:"3",key:"1qljk2"}],["path",{d:"m15 9-3-3 3-3",key:"1lwv8l"}],["path",{d:"M12 6h5a2 2 0 0 1 2 2v7",key:"1yj91y"}]]);var j=e.i(55716);let k=(0,b.default)("arrow-up",[["path",{d:"m5 12 7-7 7 7",key:"hav0vg"}],["path",{d:"M12 19V5",key:"x0mq9r"}]]),N=(0,b.default)("arrow-down",[["path",{d:"M12 5v14",key:"s699le"}],["path",{d:"m19 12-7 7-7-7",key:"1idqje"}]]),S=(0,b.default)("folder-open",[["path",{d:"m6 14 1.5-2.9A2 2 0 0 1 9.24 10H20a2 2 0 0 1 1.94 2.5l-1.54 6a2 2 0 0 1-1.95 1.5H4a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h3.9a2 2 0 0 1 1.69.9l.81 1.2a2 2 0 0 0 1.67.9H18a2 2 0 0 1 2 2v2",key:"usdka0"}]]),C=(0,b.default)("chevron-left",[["path",{d:"m15 18-6-6 6-6",key:"1wnfg3"}]]),$=(0,b.default)("grip",[["circle",{cx:"12",cy:"5",r:"1",key:"gxeob9"}],["circle",{cx:"19",cy:"5",r:"1",key:"w8mnmm"}],["circle",{cx:"5",cy:"5",r:"1",key:"lttvr7"}],["circle",{cx:"12",cy:"12",r:"1",key:"41hilf"}],["circle",{cx:"19",cy:"12",r:"1",key:"1wjl8i"}],["circle",{cx:"5",cy:"12",r:"1",key:"1pcz8c"}],["circle",{cx:"12",cy:"19",r:"1",key:"lyex9k"}],["circle",{cx:"19",cy:"19",r:"1",key:"shf9b7"}],["circle",{cx:"5",cy:"19",r:"1",key:"bfqh0e"}]]),M=(0,b.default)("chevron-down",[["path",{d:"m6 9 6 6 6-6",key:"qrunsl"}]]);var E=e.i(7233);let R=(0,b.default)("globe",[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["path",{d:"M12 2a14.5 14.5 0 0 0 0 20 14.5 14.5 0 0 0 0-20",key:"13o1zl"}],["path",{d:"M2 12h20",key:"9i4pu4"}]]),L=(0,b.default)("mouse-pointer-2",[["path",{d:"M4.037 4.688a.495.495 0 0 1 .651-.651l16 6.5a.5.5 0 0 1-.063.947l-6.124 1.58a2 2 0 0 0-1.438 1.435l-1.579 6.126a.5.5 0 0 1-.947.063z",key:"edeuup"}]]);var P=e.i(71689);let F=(0,b.default)("arrow-right",[["path",{d:"M5 12h14",key:"1ays0h"}],["path",{d:"m12 5 7 7-7 7",key:"xquz4c"}]]),z=(0,b.default)("rotate-cw",[["path",{d:"M21 12a9 9 0 1 1-9-9c2.52 0 4.93 1 6.74 2.74L21 8",key:"1p45f6"}],["path",{d:"M21 3v5h-5",key:"1q7to0"}]]);var D=e.i(57688),q=e.i(15035);let A=(0,n.createServerReference)("40c6cb646022d7e00fd103a8b4f689f351ffac266c",n.callServer,void 0,n.findSourceMapURL,"listPathEntries");var B=e.i(29523);let T=(0,b.default)("clipboard",[["rect",{width:"8",height:"4",x:"8",y:"2",rx:"1",ry:"1",key:"tgr4d6"}],["path",{d:"M16 4h2a2 2 0 0 1 2 2v14a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2h2",key:"116196"}]]),U=(0,b.default)("file-text",[["path",{d:"M6 22a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h8a2.4 2.4 0 0 1 1.704.706l3.588 3.588A2.4 2.4 0 0 1 20 8v12a2 2 0 0 1-2 2z",key:"1oefj6"}],["path",{d:"M14 2v5a1 1 0 0 0 1 1h5",key:"wfsgrz"}],["path",{d:"M10 9H8",key:"b1mrlr"}],["path",{d:"M16 13H8",key:"t4e002"}],["path",{d:"M16 17H8",key:"z1uh3a"}]]);var I=e.i(27025);let W=(0,b.default)("grid-2x2",[["path",{d:"M12 3v18",key:"108xh3"}],["path",{d:"M3 12h18",key:"1i2n21"}],["rect",{x:"3",y:"3",width:"18",height:"18",rx:"2",key:"h1oib"}]]),H=(0,b.default)("house",[["path",{d:"M15 21v-8a1 1 0 0 0-1-1h-4a1 1 0 0 0-1 1v8",key:"5wwlr5"}],["path",{d:"M3 10a2 2 0 0 1 .709-1.528l7-6a2 2 0 0 1 2.582 0l7 6A2 2 0 0 1 21 10v9a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2z",key:"r6nss1"}]]),K=(0,b.default)("list",[["path",{d:"M3 5h.01",key:"18ugdj"}],["path",{d:"M3 12h.01",key:"nlz23k"}],["path",{d:"M3 19h.01",key:"noohij"}],["path",{d:"M8 5h13",key:"1pao27"}],["path",{d:"M8 12h13",key:"1za7za"}],["path",{d:"M8 19h13",key:"m83p4d"}]]),O=(0,b.default)("pin",[["path",{d:"M12 17v5",key:"bb1du9"}],["path",{d:"M9 10.76a2 2 0 0 1-1.11 1.79l-1.78.9A2 2 0 0 0 5 15.24V16a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1v-.76a2 2 0 0 0-1.11-1.79l-1.78-.9A2 2 0 0 1 15 10.76V7a1 1 0 0 1 1-1 2 2 0 0 0 0-4H8a2 2 0 0 0 0 4 1 1 0 0 1 1 1z",key:"1nkz8b"}]]),V=(0,b.default)("pin-off",[["path",{d:"M12 17v5",key:"bb1du9"}],["path",{d:"M15 9.34V7a1 1 0 0 1 1-1 2 2 0 0 0 0-4H7.89",key:"znwnzq"}],["path",{d:"m2 2 20 20",key:"1ooewy"}],["path",{d:"M9 9v1.76a2 2 0 0 1-1.11 1.79l-1.78.9A2 2 0 0 0 5 15.24V16a1 1 0 0 0 1 1h11",key:"c9qhm2"}]]);var _=e.i(81016);let G="viba:session-file-browser:view-mode";function X({initialPath:e,worktreePath:a,onConfirm:n,onCancel:s,onPathChange:i}){let l=(0,r.useMemo)(()=>new Set([".png",".jpg",".jpeg",".gif",".webp",".bmp",".svg",".ico",".avif"]),[]),[o,c]=(0,r.useState)(""),[d,u]=(0,r.useState)([]),[h,f]=(0,r.useState)(!1),[b,x]=(0,r.useState)(null),[v,w]=(0,r.useState)(""),[g,y]=(0,r.useState)([]),[j,k]=(0,r.useState)(null),[N,S]=(0,r.useState)("list"),[C,$]=(0,r.useState)(!1),[M,E]=(0,r.useState)({}),[R,L]=(0,r.useState)([]);(0,r.useEffect)(()=>{let t=!0;return(async()=>{try{let r=await (0,q.getHomeDirectory)();if(!t)return;w(r),e||c(r)}catch(e){console.error("Failed to resolve home directory:",e)}e&&t&&c(e)})(),()=>{t=!1}},[e]),(0,r.useEffect)(()=>{let e=!0;return(async()=>{try{let t=await (0,m.getConfig)();if(!e)return;let r=Array.isArray(t.pinnedFolderShortcuts)?t.pinnedFolderShortcuts.filter(e=>"string"==typeof e&&e.trim().length>0):[];L(Array.from(new Set(r)))}catch(e){console.error("Failed to load pinned folder shortcuts:",e)}})(),()=>{e=!1}},[]),(0,r.useEffect)(()=>{try{let e=localStorage.getItem(G);("list"===e||"grid"===e)&&S(e)}catch{}finally{$(!0)}},[]),(0,r.useEffect)(()=>{if(C)try{localStorage.setItem(G,N)}catch{}},[C,N]),(0,r.useEffect)(()=>{o&&(async()=>{f(!0),x(null);try{let e=await A(o);u(e)}catch(e){console.error("Failed to list files:",e),x("Failed to load directory contents")}finally{f(!1)}})()},[o]),(0,r.useEffect)(()=>{o&&i?.(o)},[o,i]),(0,r.useEffect)(()=>{y([]),k(null),E({})},[o]);let F=(0,r.useMemo)(()=>new Set(g),[g]),z=(e,t,r)=>{if(e.isDirectory)return void c(e.path);let a=r.metaKey||r.ctrlKey;if(r.shiftKey&&null!==j){let e=Math.min(j,t),r=Math.max(j,t);y(d.slice(e,r+1).filter(e=>!e.isDirectory).map(e=>e.path));return}if(a){y(t=>t.includes(e.path)?t.filter(t=>t!==e.path):[...t,e.path]),k(t);return}y([e.path]),k(t)},X=async()=>{if(x(null),!a)return void x("Cannot paste: Session worktree path is missing.");try{if(f(!0),!navigator.clipboard||!navigator.clipboard.read)throw Error("Clipboard API not supported in this browser");let e=await navigator.clipboard.read(),t=new FormData,r=!1;for(let a of e)for(let e of a.types)if(e.startsWith("image/")){let n=await a.getType(e),s=e.split("/")[1]||"png",i=`pasted-image-${Date.now()}.${s}`,l=new File([n],i,{type:e});t.append(i,l),r=!0;break}if(r){let e=await (0,B.saveAttachments)(a,t);if(e&&e.length>0)return void await n(e);x("Failed to save pasted files.")}else try{let e=await navigator.clipboard.readText();e&&e.trim().startsWith("/")?x("No file content found in clipboard. Copy an image or file first."):x("No file content found in clipboard.")}catch{x("No file content found in clipboard.")}}catch(t){let e=t instanceof Error?t.message:String(t);console.error("Paste error:",t),x(`Failed to read from clipboard: ${e}`)}finally{f(!1)}},Y=async e=>{L(e);try{await (0,p.updateConfig)({pinnedFolderShortcuts:e})}catch(e){console.error("Failed to save pinned folder shortcuts:",e),x("Failed to save pinned shortcuts")}},J=async e=>{(x(null),R.includes(e))?await Y(R.filter(t=>t!==e)):await Y([...R,e])},Z=async()=>{0!==g.length&&await n(g)};return(0,t.jsx)("div",{className:"fixed inset-0 z-50 flex items-center justify-center bg-black/50 backdrop-blur-sm p-4",children:(0,t.jsxs)("div",{className:"bg-base-200 rounded-lg shadow-xl w-full max-w-5xl h-[82vh] flex flex-col",children:[(0,t.jsxs)("div",{className:"flex items-center justify-between p-4 border-b border-base-300",children:[(0,t.jsxs)("h2",{className:"text-xl font-bold flex items-center gap-2",children:[(0,t.jsx)(I.Folder,{className:"w-5 h-5"}),"Browse Files"]}),(0,t.jsx)("button",{onClick:s,className:"btn btn-sm btn-ghost btn-circle",title:"Close file browser",children:"✕"})]}),(0,t.jsxs)("div",{className:"flex items-center gap-2 p-3 bg-base-300",children:[(0,t.jsx)("button",{onClick:()=>{let e=(0,_.getDirName)(o);e&&e!==o&&c(e)},className:"btn btn-sm btn-square btn-ghost",title:"Go Up",disabled:"/"===o||!o,children:(0,t.jsx)(P.ArrowLeft,{className:"w-4 h-4"})}),(0,t.jsxs)("button",{onClick:()=>{v&&o!==v&&c(v)},className:"btn btn-sm btn-ghost gap-1",title:v?`Go to Home Folder (${v})`:"Go to Home Folder",disabled:!v||o===v,children:[(0,t.jsx)(H,{className:"w-4 h-4"}),"Home"]}),(0,t.jsx)("div",{className:"flex-1 overflow-x-auto whitespace-nowrap px-2 font-mono text-sm",children:o}),(0,t.jsxs)("div",{className:"join",children:[(0,t.jsx)("button",{type:"button",onClick:()=>S("list"),className:`btn btn-sm join-item ${"list"===N?"btn-active":"btn-ghost"}`,title:"List view",children:(0,t.jsx)(K,{className:"w-4 h-4"})}),(0,t.jsx)("button",{type:"button",onClick:()=>S("grid"),className:`btn btn-sm join-item ${"grid"===N?"btn-active":"btn-ghost"}`,title:"Grid view",children:(0,t.jsx)(W,{className:"w-4 h-4"})})]}),(0,t.jsxs)("button",{onClick:Z,className:"btn btn-sm btn-primary gap-2",disabled:0===g.length,title:"Insert selected absolute paths",children:["Insert (",g.length,")"]}),(0,t.jsx)("div",{className:"w-[1px] h-6 bg-base-content/10 mx-1"}),(0,t.jsxs)("button",{onClick:X,className:"btn btn-sm btn-ghost gap-2",title:"Paste file/image from clipboard",disabled:!a,children:[(0,t.jsx)(T,{className:"w-4 h-4"}),"Paste"]})]}),R.length>0&&(0,t.jsx)("div",{className:"px-3 py-2 border-b border-base-300 bg-base-200/50",children:(0,t.jsx)("div",{className:"flex items-center gap-2 overflow-x-auto",children:R.map(e=>{let r=e===o,a=e.split(/[\\/]/).filter(Boolean).pop()||e;return(0,t.jsxs)("div",{className:"join shrink-0",children:[(0,t.jsxs)("button",{type:"button",className:`btn btn-xs join-item ${r?"btn-primary":"btn-ghost"}`,onClick:()=>c(e),title:e,children:[(0,t.jsx)(I.Folder,{className:"w-3 h-3"}),a]}),(0,t.jsx)("button",{type:"button",className:"btn btn-xs btn-ghost join-item",onClick:()=>void J(e),title:`Unpin ${e}`,children:(0,t.jsx)(V,{className:"w-3 h-3"})})]},e)})})}),(0,t.jsx)("div",{className:"flex-1 overflow-y-auto p-2",children:h?(0,t.jsx)("div",{className:"flex justify-center items-center h-full",children:(0,t.jsx)("span",{className:"loading loading-spinner loading-lg"})}):b?(0,t.jsx)("div",{className:"alert alert-error",children:b}):0===d.length?(0,t.jsx)("div",{className:"text-center text-base-content/50 mt-10",children:"Empty directory"}):"list"===N?(0,t.jsx)("div",{className:"grid grid-cols-1 gap-1",children:d.map((e,r)=>{let a=F.has(e.path);return(0,t.jsxs)("div",{className:`flex items-center justify-between p-2 rounded-md cursor-pointer transition-colors border ${a?"bg-primary text-primary-content border-primary":"hover:bg-base-100 border-transparent"}`,onClick:t=>z(e,r,t),title:e.path,children:[(0,t.jsxs)("div",{className:"flex items-center gap-3 overflow-hidden",children:[e.isDirectory?(0,t.jsx)(I.Folder,{className:"w-5 h-5 shrink-0"}):(0,t.jsx)(U,{className:"w-5 h-5 shrink-0"}),(0,t.jsx)("span",{className:"truncate",children:e.name})]}),(0,t.jsx)("span",{className:"text-[10px] opacity-70 shrink-0",children:e.isDirectory?(0,t.jsx)("button",{type:"button",className:"btn btn-ghost btn-xs h-6 min-h-6",onClick:t=>{t.stopPropagation(),J(e.path)},title:R.includes(e.path)?"Unpin folder":"Pin folder",children:(0,t.jsx)(O,{className:`w-3 h-3 ${R.includes(e.path)?"fill-current":""}`})}):"file"})]},e.path)})}):(0,t.jsx)("div",{className:"grid grid-cols-2 md:grid-cols-4 lg:grid-cols-5 gap-3",children:d.map((e,r)=>{var a;let n,s=F.has(e.path),i=!e.isDirectory&&-1!==(n=(a=e.name).lastIndexOf("."))&&l.has(a.slice(n).toLowerCase()),o=`/api/file-thumbnail?path=${encodeURIComponent(e.path)}`;return(0,t.jsxs)("button",{type:"button",className:`rounded-lg border text-left overflow-hidden transition-colors ${s?"border-primary bg-primary/15":"border-base-300 hover:bg-base-100"}`,onClick:t=>z(e,r,t),title:e.path,children:[(0,t.jsxs)("div",{className:"aspect-square bg-base-300 flex items-center justify-center overflow-hidden relative",children:[i&&!M[e.path]?(0,t.jsx)(D.default,{src:o,alt:e.name,fill:!0,sizes:"(max-width: 768px) 50vw, (max-width: 1024px) 25vw, 20vw",className:"object-cover",unoptimized:!0,onError:()=>E(t=>({...t,[e.path]:!0}))}):e.isDirectory?(0,t.jsx)(I.Folder,{className:"w-10 h-10 opacity-80"}):(0,t.jsx)(U,{className:"w-10 h-10 opacity-80"}),e.isDirectory&&(0,t.jsx)("button",{type:"button",className:`absolute top-1 right-1 btn btn-xs btn-circle ${R.includes(e.path)?"btn-primary":"btn-ghost bg-base-100/70"}`,onClick:t=>{t.stopPropagation(),J(e.path)},title:R.includes(e.path)?"Unpin folder":"Pin folder",children:(0,t.jsx)(O,{className:`w-3 h-3 ${R.includes(e.path)?"fill-current":""}`})})]}),(0,t.jsxs)("div",{className:"px-2 py-2",children:[(0,t.jsx)("div",{className:"truncate text-sm font-medium",title:e.name,children:e.name}),(0,t.jsx)("div",{className:"text-[10px] opacity-70",children:e.isDirectory?"folder":i?"image":"file"})]})]},e.path)})})}),(0,t.jsx)("div",{className:"p-3 border-t border-base-300 text-xs text-base-content/60 text-center",children:"Click: single select. Cmd/Ctrl+Click: multi-select. Shift+Click: range select. Click a folder to open it."})]})})}var Y=e.i(63671);let J=[{id:"vscode",name:"VS Code",protocol:"vscode"},{id:"cursor",name:"Cursor",protocol:"cursor"},{id:"windsurf",name:"Windsurf",protocol:"windsurf"},{id:"antigravity",name:"Antigravity",protocol:"antigravity"}],Z=e=>`'${e.replace(/'/g,"'\\''")}'`,Q="viba-terminal-size",ee="viba-agent-preview-split-ratio",et=e=>Math.max(.2,Math.min(.8,e)),er=e=>{let t=e.trim();return t?/^https?:\/\//i.test(t)?t:/^[a-z][a-z0-9+.-]*:/i.test(t)?null:`http://${t}`:null},ea=(e,t)=>{let r=e.replace(/\\/g,"/").replace(/\/+$/,""),a=t.replace(/\\/g,"/").replace(/^\/+/,"");return`${r}/${a}`},en=(e,t)=>{let r=t.trim().replace(/\\/g,"/").replace(/\/+$/,"");if(!r)return null;let a=(e=>{let t=e.trim();if(!t)return"";if(t=t.replace(/[#?].*$/,""),/^file:\/\//i.test(t))try{let e=new URL(t);t=decodeURIComponent(e.pathname)}catch{}else if(/^https?:\/\//i.test(t))try{let e=new URL(t);t=decodeURIComponent(e.pathname)}catch{}return(t=t.replace(/^webpack(?:-internal)?:\/\/\/?/,"").replace(/^rsc:\/\//,"").replace(/^\(.*?\)\//,"").replace(/^\/\.\//,"/").replace(/^\.\//,"").replace(/\\/g,"/")).trim()})(e);if(!a)return null;if(a.startsWith("/")||/^[a-zA-Z]:[\\/]/.test(a))return a;let n=new Set;n.add(a.replace(/^\.\/+/,""));let s=a.indexOf("/src/");for(let e of(s>=0&&n.add(a.slice(s+1)),a.startsWith("src/")&&n.add(a),n))if(e)return ea(r,e);return null};function es({repo:e,worktree:a,branch:n,baseBranch:b,sessionName:D,agent:q,model:A,startupScript:B,devServerScript:T,initialMessage:U,rawInitialMessage:I,title:W,attachmentNames:H,onExit:K,isResume:O,onSessionStart:V}){let G="hidden min-[1900px]:inline",ea=(0,r.useRef)(null),es=(0,r.useRef)(null),ei=(0,r.useRef)(null),el=(0,r.useRef)(null),eo=(0,r.useRef)(null),ec=(0,r.useRef)({startX:0,startRatio:.5}),ed=(0,r.useRef)(null),eu=(0,r.useRef)(null),[eh,em]=(0,r.useState)("Initializing..."),[ep,ef]=(0,r.useState)("idle"),[eb,ex]=(0,r.useState)(null),[ev,ew]=(0,r.useState)(!1),[eg,ey]=(0,r.useState)(!1),[ej,ek]=(0,r.useState)(!1),[eN,eS]=(0,r.useState)(!1),[eC,e$]=(0,r.useState)(!1),[eM,eE]=(0,r.useState)(a||e),[eR,eL]=(0,r.useState)(!1),[eP,eF]=(0,r.useState)(b?.trim()||""),[ez,eD]=(0,r.useState)([]),[eq,eA]=(0,r.useState)(!1),eB=(0,r.useRef)(!1),[eT,eU]=(0,r.useState)(!1),[eI,eW]=(0,r.useState)({ahead:0,behind:0}),[eH,eK]=(0,r.useState)(0),[eO,eV]=(0,r.useState)(!1),[e_,eG]=(0,r.useState)(""),[eX,eY]=(0,r.useState)(""),[eJ,eZ]=(0,r.useState)(!1),[eQ,e0]=(0,r.useState)(.5),[e1,e2]=(0,r.useState)(!1),[e3,e6]=(0,r.useState)(!0),[e5,e4]=(0,r.useState)({width:460,height:320}),[e9,e8]=(0,r.useState)(!1),[e7,te]=(0,r.useState)(!1),tt=(0,r.useRef)({startX:0,startY:0,startWidth:0,startHeight:0});(0,r.useEffect)(()=>{eE(a||e)},[e,a]),(0,r.useEffect)(()=>{let e=localStorage.getItem(Q);if(e)try{e4(JSON.parse(e))}catch(e){console.error("Failed to parse saved terminal size",e)}let t=localStorage.getItem(ee);if(t){let e=Number.parseFloat(t);Number.isNaN(e)||e0(et(e))}te(!0)},[]),(0,r.useEffect)(()=>{if(!e9)return;let e=e=>{let t=tt.current.startX-e.clientX,r=tt.current.startY-e.clientY;e4({width:Math.max(300,Math.min(window.innerWidth-32,tt.current.startWidth+t)),height:Math.max(100,Math.min(window.innerHeight-32,tt.current.startHeight+r))})},t=()=>{e8(!1)};return window.addEventListener("mousemove",e),window.addEventListener("mouseup",t),()=>{window.removeEventListener("mousemove",e),window.removeEventListener("mouseup",t)}},[e9]),(0,r.useEffect)(()=>{e7&&!e9&&localStorage.setItem(Q,JSON.stringify(e5))},[e7,e9,e5]),(0,r.useEffect)(()=>{e7&&!e1&&localStorage.setItem(ee,String(eQ))},[eQ,e7,e1]),(0,r.useEffect)(()=>{if(!e1)return;let e=e=>{let t=eo.current;if(!t)return;let r=t.getBoundingClientRect();if(r.width<=0)return;let a=e.clientX-ec.current.startX;e0(et((ec.current.startRatio*r.width+a)/r.width))},t=()=>{e2(!1)};return window.addEventListener("mousemove",e),window.addEventListener("mouseup",t),()=>{window.removeEventListener("mousemove",e),window.removeEventListener("mouseup",t)}},[e1]),(0,r.useEffect)(()=>{if(!e3&&es.current){let e=es.current;setTimeout(()=>{try{let t=e.contentWindow;if(t&&t.term){t.term.scrollToBottom(),t.focus();let r=e.contentDocument?.querySelector("textarea.xterm-helper-textarea");r&&r.focus()}}catch(e){console.error("Failed to focus/scroll terminal on restore:",e)}},100)}},[e3]);let[tr,ta]=(0,r.useState)("vscode");(0,r.useEffect)(()=>{let e=W?.trim();if(e)return document.title=`${e} | Viba`,()=>{document.title="Viba"};document.title="Viba"},[W]),(0,r.useEffect)(()=>{(async()=>{let e=await (0,m.getConfig)();e.selectedIde&&J.some(t=>t.id===e.selectedIde)&&ta(e.selectedIde)})()},[]),(0,r.useEffect)(()=>{eF(b?.trim()||""),eD([])},[b,D]);let tn=async e=>{let t=e.target.value;ta(t),await (0,p.updateConfig)({selectedIde:t})},ts=async(t=!0)=>!!e&&!!a&&!!n&&(!t||!!confirm("Are you sure you want to delete this session? This will remove the branch and worktree."))&&(ex(null),ef("idle"),em("Purging session in background..."),s(D).then(e=>{e.success?(0,Y.notifySessionsUpdated)():console.error("Background cleanup failed:",e.error||"Unknown error")}).catch(e=>{console.error("Background cleanup request failed:",e)}),K(),!0),ti=async()=>{await ts(!0)},tl=(0,r.useCallback)((e,t)=>new Promise(r=>{let a=ea.current;if(!a)return void r(!1);let s=(i=0)=>{if(i>30)return void r(!1);try{let l=a.contentWindow;if(!l||(l.postMessage({type:"viba:agent-request",action:t,prompt:e,sessionName:D,branch:n,baseBranch:eP||void 0,timestamp:Date.now()},"*"),!l.term))return void setTimeout(()=>s(i+1),300);l.term.paste(e);let o=a.contentDocument?.querySelector("textarea.xterm-helper-textarea");o?(o.dispatchEvent(new KeyboardEvent("keypress",{bubbles:!0,cancelable:!0,charCode:13,keyCode:13,key:"Enter",view:l})),o.focus()):l.term.paste("\r"),l.focus(),r(!0)}catch(e){console.error("Failed to send prompt to agent iframe:",e),setTimeout(()=>s(i+1),300)}};s()}),[n,eP,D]),to=async()=>{ey(!0),em("Requesting commit from agent..."),em(await tl("Please create a git commit with the current changes in this worktree.","commit")?"Commit request sent to agent":"Failed to send commit request to agent"),ey(!1)},tc=(0,r.useCallback)(e=>new Promise(t=>{let r=ea.current;if(!r)return void t(!1);let a=(n=0)=>{if(n>30)return void t(!1);try{let s=r.contentWindow;if(!s||!s.term)return void setTimeout(()=>a(n+1),300);s.term.paste(e);let i=r.contentDocument?.querySelector("textarea.xterm-helper-textarea");i&&i.focus(),s.focus(),t(!0)}catch(e){console.error("Failed to paste into agent iframe:",e),setTimeout(()=>a(n+1),300)}};a()}),[]),td=(0,r.useCallback)(async e=>{if(0===e.length)return;eL(!0);let t=`${e.join(" ")} `;em(await tc(t)?`Inserted ${e.length} file path${1===e.length?"":"s"} into agent input`:"Failed to insert file paths into agent input"),eL(!1)},[tc]),tu=(0,r.useCallback)(async t=>{let r=(e=>{let t=e.trim();if(!t)return"";let r=t.match(/[A-Za-z_$][\w$]*/);return r?r[0]:""})(t);if(!r)return null;let n=Array.from(new Set([e,a].map(e=>(e||"").trim()).filter(Boolean)));if(0===n.length)return null;for(let e of n)try{let t=await fetch("/api/component-source/resolve",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({componentName:r,workspaceRoot:e})}),a=await t.json().catch(()=>null);if(!t.ok){console.warn("Component source resolve miss",{componentName:r,workspaceRoot:e,error:a?.error||t.statusText});continue}let n="string"==typeof a?.sourcePath?a.sourcePath.trim():"";if(n)return n}catch(e){console.error("Failed to resolve component source path:",e)}return null},[e,a]),th=(0,r.useCallback)(async()=>{if(D&&!eB.current){eB.current=!0,eA(!0);try{let e=await o(D);e.success?(eD(e.branches??[]),eF(e.baseBranch?.trim()||"")):e.error&&em(`Failed to load branches: ${e.error}`)}catch(e){console.error("Failed to load base branches:",e)}finally{eB.current=!1,eA(!1)}}},[D]);(0,r.useEffect)(()=>{D&&th()},[th,D]);let tm=(0,r.useCallback)(async()=>{if(D)try{let e=await i(D);e.success&&"number"==typeof e.ahead&&"number"==typeof e.behind&&eW({ahead:e.ahead,behind:e.behind})}catch(e){console.error("Failed to load branch divergence:",e)}},[D]);(0,r.useEffect)(()=>{if(!D||!eP)return void eW({ahead:0,behind:0});tm();let e=window.setInterval(()=>{tm()},6e4);return()=>window.clearInterval(e)},[eP,tm,D]);let tp=(0,r.useCallback)(async()=>{if(D)try{let e=await l(D);e.success&&"number"==typeof e.count&&eK(e.count)}catch(e){console.error("Failed to load uncommitted file count:",e)}},[D]);(0,r.useEffect)(()=>{if(!D)return;tp();let e=window.setInterval(()=>{tp()},1e4);return()=>window.clearInterval(e)},[tp,D]);let tf=async(e=!0)=>{if(!D||!eP||e&&!confirm(`Merge ${n} into ${eP}?`))return!1;ek(!0),em("Merging session branch...");try{let e=await c(D);if(e.success)return em(`Merged ${e.branchName} into ${e.baseBranch}`),tm(),!0;return em(`Merge failed: ${e.error}`),!1}catch(e){return console.error("Merge request failed:",e),em("Merge failed"),!1}finally{ek(!1)}},tb=async()=>{await tf(!0)},[tx,tv]=(0,r.useState)(!1),tw=(0,r.useRef)(null);(0,r.useEffect)(()=>{let e=e=>{tw.current&&!tw.current.contains(e.target)&&tv(!1)};return document.addEventListener("mousedown",e),()=>document.removeEventListener("mousedown",e)},[]);let tg=async e=>{if(tv(!1),!D)return;let t=e!==eP;if(confirm(`Rebase ${n} onto ${e}?`)){eS(!0),em(t?`Updating base to ${e} and rebasing...`:"Rebasing session branch...");try{if(t){let t=await u(D,e);if(!t.success){em(`Failed to update base branch: ${t.error}`),eS(!1);return}eF(t.baseBranch),await th()}let r=await d(D);r.success?(em(`Rebased ${r.branchName} onto ${r.baseBranch}`),tm()):em(`Rebase failed: ${r.error}`)}catch(e){console.error("Rebase request failed:",e),em("Rebase failed")}finally{eS(!1)}}},ty=async()=>{a&&eP&&confirm(`Merge ${n} into ${eP}, then clean up and exit?`)&&await tf(!1)&&await ts(!1)},tj=(0,r.useCallback)(async(e,t)=>{let r=er(e);if(!r)return em("Please enter a preview URL"),!1;eG(r),eZ(!1),em(`Loading preview: ${r}`);try{let e=await fetch("/api/preview-proxy/start",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({target:r})}),a=await e.json().catch(()=>null);if(!e.ok||!a?.proxyUrl)throw Error(a?.error||"Failed to start preview proxy");return eY(a.proxyUrl),t&&eV(!0),em(`Loaded preview: ${r}`),!0}catch(t){let e=t instanceof Error?t.message:"Failed to load preview";return console.error("Failed to load preview via proxy:",t),em(`Failed to load preview: ${e}`),!1}},[]),tk=(0,r.useCallback)(()=>{if(!eX)return void em("Load a preview before picking elements");let e=ei.current?.contentWindow;if(!e)return void em("Preview is not ready yet");let t=!eJ;e.postMessage({type:"viba:preview-picker-toggle",active:t},"*"),eZ(t),em(t?"Picker enabled: click an element in the preview":"Picker disabled")},[eJ,eX]),tN=(0,r.useCallback)(e=>{let t=ei.current?.contentWindow;return t?(t.postMessage(e,"*"),!0):(em("Preview is not ready yet"),!1)},[]),tS=(0,r.useCallback)(e=>{eX?tN({type:"viba:preview-navigation",action:e})&&"reload"===e&&em("Reloading preview..."):em("Load a preview before using navigation controls")},[tN,eX]),tC=(0,r.useCallback)(()=>{tN({type:"viba:preview-location-request"})},[tN]),t$=(0,r.useCallback)((e,t)=>{let r=er(e);return!!r&&(t?window.open(r,"_blank","noopener,noreferrer"):tj(r,!0),!0)},[tj]),tM=(0,r.useCallback)((e,t,r)=>{t.current?.();let a=e.contentWindow,n=a?.term;if(!a||!n)return;let s=r?.onLinkActivated,i=[],l=e.contentDocument,o={metaKey:!1,ctrlKey:!1,at:0};if(l){let e=e=>{o={metaKey:e.metaKey,ctrlKey:e.ctrlKey,at:Date.now()}};l.addEventListener("mousedown",e,!0),l.addEventListener("click",e,!0),i.push(()=>{l.removeEventListener("mousedown",e,!0),l.removeEventListener("click",e,!0)})}let c=a.open.bind(a);a.open=(...e)=>{let t=Date.now()-o.at<1e3&&(o.metaKey||o.ctrlKey);if("string"==typeof e[0]&&e[0].trim())return(s?.(),t$(e[0],t))?null:c(...e);if(0===e.length){let e=null;return{opener:null,location:{set href(url){if(s?.(),!t$(url,t)&&(e=c())){try{e.opener=null}catch{}e.location.href=url}},get href(){return""}}}}return c(...e)},i.push(()=>{a.open=c});let d=n._core?._linkProviderService?.linkProviders;if(d instanceof Map){for(let e of d.values())if(e&&"object"==typeof e){if("function"==typeof e._handler){let t=e._handler;e._handler=(e,r)=>{s?.(),t$(r,!!(e?.metaKey||e?.ctrlKey))||t(e,r)},i.push(()=>{e._handler=t})}if("function"==typeof e.provideLinks){let t=e.provideLinks.bind(e);e.provideLinks=(e,r)=>{t(e,e=>{if(Array.isArray(e))for(let t of e){if(!t||"object"!=typeof t||"function"!=typeof t.activate)continue;let e=t.activate.bind(t);t.activate=(t,r)=>{s?.(),t$(r,!!(t?.metaKey||t?.ctrlKey))||e(t,r)}}r(e)})},i.push(()=>{e.provideLinks=t})}}}let u=n.options.linkHandler,h={allowNonHttpProtocols:u?.allowNonHttpProtocols??!1,activate:(e,t,r)=>{s?.(),t$(t,!!(e?.metaKey||e?.ctrlKey))||u?.activate?.(e,t,r)},hover:(e,t,r)=>{u?.hover?.(e,t,r)},leave:(e,t,r)=>{u?.leave?.(e,t,r)}};n.options.linkHandler=h,i.push(()=>{n.options.linkHandler=u??null}),t.current=()=>{for(let e of i)e();t.current=null}},[t$]);if((0,r.useEffect)(()=>{if(!eO||e_.trim())return;let e=window.setTimeout(()=>{el.current?.focus()},0);return()=>{window.clearTimeout(e)}},[eO,e_]),(0,r.useEffect)(()=>{let t=t=>{if(!ei.current||t.source!==ei.current.contentWindow)return;let r=t.data;if(r&&"object"==typeof r){if("viba:preview-picker-state"===r.type)return void eZ(!!r.active);if("viba:preview-picker-ready"===r.type){let e=ei.current?.contentWindow;e&&e.postMessage({type:"viba:preview-location-request"},"*");return}if("viba:preview-location-change"===r.type){"string"==typeof r.url&&r.url.trim().length>0&&eG(r.url);return}if("viba:preview-element-selected"===r.type){let t=r.element&&"object"==typeof r.element?r.element:null,n=Array.isArray(t?.reactComponentStack)?t.reactComponentStack:[],s=((e,t)=>{for(let r of e){if(!r||"object"!=typeof r)continue;let e="string"==typeof r.name?r.name.trim():"";if(!e)continue;let a="string"==typeof r.source?.fileName?r.source.fileName.trim():"",n=a?en(a,t):null;if(n)return`${e} (${n})`}return null})(n,a||e),i=n[0]&&"object"==typeof n[0]?n[0].name:void 0,l="string"==typeof i&&i.trim().length>0?i.trim():"",o=Array.from(new Set(n.map(e=>{if(!e||"object"!=typeof e)return"";let t=e.name;return"string"==typeof t?t.trim():""}).filter(Boolean))),c=s||l||("string"==typeof t?.selector?t.selector:"");if(console.log("Preview selected element:",t),console.log("Preview selected reactComponentStack:",n),console.log("Preview selected identifier:",c),eZ(!1),!c)return void em("Element selected. No identifier was resolved.");(async()=>{let e=s||"";if(!e&&o.length>0)for(let t of o){let r=await tu(t);if(r){e=`${t} (${r})`;break}}if(!e){if(o.length>0)return em("Element selected, but source file path could not be resolved for the component");e=c}em(await tc(`${e} `)?`Element identifier sent to agent: ${e}`:"Element selected, but failed to send identifier to agent input")})()}}};return window.addEventListener("message",t),()=>{window.removeEventListener("message",t)}},[tc,e,tu,a]),(0,r.useEffect)(()=>{eZ(!1)},[eX]),!e)return(0,t.jsx)("div",{className:"p-4 text-error",children:"No repository specified"});if("error"===ep)return(0,t.jsx)("div",{className:"flex h-screen w-full items-center justify-center bg-base-100",children:(0,t.jsx)("div",{className:"card w-96 bg-base-200 shadow-xl",children:(0,t.jsxs)("div",{className:"card-body items-center text-center",children:[(0,t.jsx)("h2",{className:"card-title text-error",children:"Cleanup failed"}),(0,t.jsx)("p",{children:eb||"An unknown error occurred while cleaning up this session."}),(0,t.jsx)("div",{className:"card-actions justify-end",children:(0,t.jsx)("button",{className:"btn btn-primary",onClick:()=>K(),children:"Back to Home"})})]})})});let tE=Array.from(new Set([...eP?[eP]:[],...ez])).filter(e=>e!==n||e===eP),tR=e3?`calc(40px - min(${e5.width}px, calc(100vw - 2rem)))`:16;return(0,t.jsxs)("div",{className:`flex flex-col h-screen w-full overflow-hidden bg-base-100 ${e9||e1?"select-none":""}`,children:[(e9||e1)&&(0,t.jsx)("div",{className:`fixed inset-0 z-[9999] ${e9?"cursor-nwse-resize":"cursor-col-resize"}`}),(0,t.jsxs)("div",{className:"z-20 bg-base-300/95 p-2 text-xs flex justify-between px-4 font-mono select-none items-center shadow-md backdrop-blur-sm border-b border-base-content/10",children:[(0,t.jsxs)("div",{className:"flex items-center gap-4",children:[(0,t.jsx)("button",{className:"btn btn-ghost btn-xs h-6 min-h-6 px-1 hover:bg-base-content/10",onClick:()=>K(),title:"Back to Home",children:(0,t.jsx)(C,{className:"w-4 h-4"})}),(0,t.jsxs)("div",{className:"flex flex-col",children:[(0,t.jsxs)("div",{className:"flex items-center gap-2",children:[(0,t.jsx)("span",{className:"opacity-50",children:"Repo:"}),(0,t.jsx)("span",{className:"font-bold",children:(0,_.getBaseName)(e)})]}),D&&(0,t.jsxs)("div",{className:"hidden min-[1200px]:flex min-w-0 items-center gap-2 text-[10px] opacity-70",children:[(0,t.jsx)("span",{children:"Session:"}),(0,t.jsx)("span",{className:"truncate max-w-[220px]",title:D,children:D})]})]})]}),(0,t.jsxs)("div",{className:"flex items-center gap-4",children:[(0,t.jsxs)("div",{className:"flex items-center border border-base-content/20 rounded overflow-hidden",children:[(0,t.jsx)("select",{className:"select select-xs h-6 min-h-6 bg-base-200 border-none focus:outline-none rounded-none pr-7",value:tr,onChange:tn,children:J.map(e=>(0,t.jsx)("option",{value:e.id,children:e.name},e.id))}),(0,t.jsx)("div",{className:"w-[1px] h-4 bg-base-content/20"}),(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs rounded-none h-6 min-h-6 border-none hover:bg-base-content/10",onClick:()=>{if(!a)return;let e=J.find(e=>e.id===tr);if(!e)return;let t=`${e.protocol}://file/${encodeURI(a)}`;window.open(t,"_blank")},title:`Open in ${J.find(e=>e.id===tr)?.name}`,children:[(0,t.jsx)(x,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:G,children:"Open"})]})]}),(0,t.jsxs)("div",{className:"flex items-center border border-base-content/20 rounded overflow-hidden bg-base-100",children:[(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs rounded-none h-6 min-h-6 border-none px-2 hover:bg-base-content/10",onClick:()=>{if(!a||!n)return;let e=new URLSearchParams({path:a,branch:n});window.open(`http://localhost:3100/workspace?${e.toString()}`,"_blank","noopener,noreferrer")},disabled:!a||!n,title:"Open this worktree and branch in Trident",children:[(0,t.jsx)(j.GitBranch,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:G,children:"Diff"})]}),(0,t.jsx)("div",{className:"w-[1px] h-4 bg-base-content/10"}),(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs rounded-none h-6 min-h-6 border-none px-2 hover:bg-base-content/10",onClick:to,disabled:eg,title:"Ask agent to create a commit with current changes",children:[eg?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(w,{className:"w-3 h-3"}),(0,t.jsxs)("span",{className:G,children:["Commit (",eH,")"]})]})]}),(0,t.jsxs)("div",{className:"flex items-center border border-base-content/20 rounded overflow-hidden bg-base-100",children:[(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs rounded-none h-6 min-h-6 border-none px-2 hover:bg-base-content/10",onClick:()=>e$(!0),disabled:eR,title:"Browse files and insert absolute paths into the agent input",children:[eR?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(S,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:G,children:"Add Files"})]}),(0,t.jsx)("div",{className:"w-[1px] h-4 bg-base-content/10"}),(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs rounded-none h-6 min-h-6 border-none px-2 hover:bg-base-content/10",onClick:()=>{if(!e||!D)return;let t=`/new?repo=${encodeURIComponent(e)}&prefillFromSession=${encodeURIComponent(D)}`;window.open(t,"_blank","noopener,noreferrer")},title:"Start a new attempt in a new tab with this session context",children:[(0,t.jsx)(E.Plus,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:G,children:"New Attempt"})]})]}),(0,t.jsxs)("div",{className:"flex items-center border border-base-content/20 rounded overflow-hidden bg-base-100",children:[T?.trim()&&(0,t.jsxs)(t.Fragment,{children:[(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs rounded-none h-6 min-h-6 border-none px-2 hover:bg-base-content/10",onClick:()=>{let e=T?.trim();if(!e||!es.current)return;e6(!1);let t=es.current;ew(!0),em("Starting dev server...");let r=(a=0)=>{if(a>30){em("Failed to start dev server: terminal is not ready"),ew(!1);return}try{let n=t.contentWindow;if(n&&n.term){n.term.paste(e);let r=t.contentDocument?.querySelector("textarea.xterm-helper-textarea");r?r.dispatchEvent(new KeyboardEvent("keypress",{bubbles:!0,cancelable:!0,charCode:13,keyCode:13,key:"Enter",view:n})):n.term.paste("\r"),n.focus(),r&&r.focus(),em("Dev server start command sent"),ew(!1)}else setTimeout(()=>r(a+1),300)}catch(e){console.error("Dev server injection error",e),em("Failed to start dev server"),ew(!1)}};r()},disabled:ev,title:"Run dev server script in terminal",children:[ev?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(v.Play,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:G,children:"Dev"})]}),(0,t.jsx)("div",{className:"w-[1px] h-4 bg-base-content/10"})]}),(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs rounded-none h-6 min-h-6 border-none px-2 hover:bg-base-content/10",onClick:()=>eV(e=>!e),title:eO?"Hide preview panel":"Show preview panel",children:[(0,t.jsx)(R,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:G,children:eO?"Close":"Preview"})]})]}),(0,t.jsxs)("div",{className:"flex items-center border border-base-content/20 rounded relative bg-base-100",ref:tw,children:[(0,t.jsxs)("div",{className:"relative",children:[(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs rounded-none rounded-l h-6 min-h-6 border-none px-2 hover:bg-base-content/10",onClick:()=>{tv(!tx)},disabled:eN||ej||eT,title:"Select base branch and rebase",children:[eN?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(y,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:G,children:"Rebase"}),(0,t.jsx)(M,{className:"w-3 h-3 opacity-50 ml-0.5"})]}),tx&&(0,t.jsxs)("div",{className:"absolute top-full left-0 z-50 mt-1 w-64 p-0 shadow-xl dropdown-content bg-base-200 rounded-box border border-base-content/20 flex flex-col max-h-80 overflow-hidden",children:[(0,t.jsxs)("div",{className:"px-4 py-2 text-[10px] uppercase font-bold tracking-wider opacity-50 border-b border-base-content/10 bg-base-200 flex justify-between items-center shrink-0",children:[(0,t.jsx)("span",{children:"Select Base Branch"}),(eq||eT)&&(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"})]}),(0,t.jsxs)("ul",{className:"menu p-0 overflow-y-auto flex-nowrap custom-scrollbar overflow-x-hidden w-full",children:[tE.length>0?tE.map(e=>(0,t.jsx)("li",{children:(0,t.jsxs)("button",{onClick:()=>tg(e),className:`flex justify-between items-center text-xs py-2 truncate max-w-full rounded-none ${e===eP?"active font-bold":""}`,title:e,children:[(0,t.jsx)("span",{className:"truncate",children:e}),e===eP&&(0,t.jsx)("span",{className:"opacity-70 text-[10px] ml-2 shrink-0",children:"(Current)"})]})},e)):(0,t.jsx)("li",{className:"text-xs px-4 py-2 opacity-50 italic text-center",children:"No other branches found"}),(0,t.jsx)("div",{className:"divider my-1 opacity-50"}),(0,t.jsx)("li",{children:(0,t.jsx)("button",{onClick:()=>void th(),className:"text-[10px] justify-center opacity-70 hover:opacity-100",children:"Refresh Branches"})})]})]})]}),(0,t.jsx)("div",{className:"w-[1px] h-4 bg-base-content/10"}),(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs btn-success rounded-none h-6 min-h-6 border-none px-2 hover:bg-success/20 hover:border-transparent",onClick:tb,disabled:ej||eN||eT||!eP,title:eP?`Merge current branch (${n}) into target branch (${eP})`:"Target branch unavailable for this session",children:[ej?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(g,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:G,children:"Merge"})]}),(0,t.jsx)("div",{className:"w-[1px] h-4 bg-base-content/10"}),(0,t.jsxs)("button",{className:"btn btn-ghost btn-xs btn-warning rounded-none h-6 min-h-6 border-none px-2 hover:bg-warning/20 hover:border-transparent",onClick:ty,disabled:ej||eN||eT||!eP||!a,title:eP?`Merge current branch (${n}) into target branch (${eP}), then clean up and exit`:"Target branch unavailable for this session",children:[ej?(0,t.jsx)("span",{className:"loading loading-spinner loading-xs"}):(0,t.jsx)(g,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:G,children:"Merge & Purge"})]}),(0,t.jsx)("div",{className:"w-[1px] h-4 bg-base-content/10"}),(0,t.jsxs)("button",{className:"btn btn-ghost btn-error btn-xs rounded-none rounded-r h-6 min-h-6 border-none px-2 hover:bg-error/20 hover:border-transparent",onClick:ti,disabled:ej||eN||!a,title:"Clean up and exit",children:[(0,t.jsx)(f.Trash2,{className:"w-3 h-3"}),(0,t.jsx)("span",{className:G,children:"Purge"})]})]}),eP&&(0,t.jsxs)("div",{className:"flex items-center gap-2 text-xs opacity-80",title:`Divergence against ${eP}`,children:[(0,t.jsxs)("span",{className:"inline-flex items-center gap-1",children:[(0,t.jsx)(k,{className:"w-3 h-3"}),eI.ahead]}),(0,t.jsxs)("span",{className:"inline-flex items-center gap-1",children:[(0,t.jsx)(N,{className:"w-3 h-3"}),eI.behind]})]}),(0,t.jsx)("div",{className:"hidden min-[1200px]:block w-[1px] h-4 bg-base-content/20 mx-2"}),(0,t.jsxs)("div",{className:"hidden min-[1200px]:flex min-w-0 max-w-[280px] items-center gap-2",children:[(0,t.jsx)("span",{className:`w-2 h-2 rounded-full ${eh.includes("Error")||eh.includes("failed")?"bg-error":eh.includes("started")||eh.includes("Merged")||eh.includes("Rebased")||eh.includes("sent")?"bg-success":"bg-warning"}`}),(0,t.jsx)("span",{className:"truncate",title:eh,children:eh})]})]})]}),(0,t.jsxs)("div",{ref:eo,className:"flex min-h-0 flex-1 w-full",children:[(0,t.jsx)("div",{className:"h-full min-w-0",style:{width:eO?`${100*eQ}%`:"100%"},children:(0,t.jsx)("iframe",{ref:ea,src:"/terminal",className:`h-full w-full border-none dark:invert dark:brightness-90 ${e9||e1?"pointer-events-none":""}`,allow:"clipboard-read; clipboard-write",onLoad:()=>{if(!ea.current)return;let t=ea.current;try{t.contentWindow}catch(e){em("Error: Cross-Origin access blocked. Ensure proxy is working.");return}t.contentWindow&&(t.contentWindow.onbeforeunload=null,t.contentWindow.addEventListener("beforeunload",e=>{e.stopImmediatePropagation()},!0)),em("Connecting to terminal...");let r=(n=0)=>{if(n>30)return void em("Timeout waiting for terminal to be ready");try{let s=t.contentWindow;if(s&&s.term){let r=s.term;tM(t,ed);try{r.options.theme={...r.options.theme||{},selectionBackground:"rgba(59, 130, 246, 0.4)"}}catch{}let n=a||e,i=`cd ${Z(n)}`;r.paste(i);let l=()=>{let e=t.contentDocument?.querySelector("textarea.xterm-helper-textarea");e?e.dispatchEvent(new KeyboardEvent("keypress",{bubbles:!0,cancelable:!0,charCode:13,keyCode:13,key:"Enter",view:s})):r.paste("\r")};if(l(),q){let t=async()=>{let t="";if(O)t=q.toLowerCase().includes("gemini")?"gemini --resume latest --yolo":q.toLowerCase().includes("codex")?"codex resume --last --sandbox danger-full-access --ask-for-approval on-request --search":"agent"===q.toLowerCase()||q.toLowerCase().includes("cursor")?"agent resume":`${Z(q)} resume`;else{let r=W?.trim()||"",n=[];r&&n.push(r),U&&n.push(U);let s=n.join("\n\n");if(H&&H.length>0){let t=`${a||e}-attachments`,r=["Attachments:",...H.map(e=>`- ${t}/${e}`)].join("\n");s=s?`${s}
2
+
3
+ ${r}`:r}let i="";if(s)if(I&&I.trim().length>0||H&&H.length>0)try{let e=await h(D,s);e.success&&e.filePath?i=` "$(cat ${Z(e.filePath)})"`:(console.error("Failed to write prompt file, falling back to inline prompt",e.error),i=` ${Z(s)}`)}catch(e){console.error("Exception writing prompt file",e),i=` ${Z(s)}`}else i=` ${Z(s)}`;let l=A&&"auto"!==A.toLowerCase()?` --model ${Z(A)}`:"";t=q.toLowerCase().includes("codex")?`codex${l} --sandbox danger-full-access --ask-for-approval on-request --search${i}`:q.toLowerCase().includes("gemini")?`gemini${l} --yolo${i}`:"agent"===q.toLowerCase()||q.toLowerCase().includes("cursor")?`agent${l}${i}`:`${Z(q)}${l}${i}`}t&&(r.paste(t),l(),em(O?`Resumed session with ${q}`:`Session started with ${q}`),!O&&V&&V())};setTimeout(()=>t(),500)}else em(`Session started ${a?"(Worktree)":""}`),!O&&V&&V();s.focus();let o=t.contentDocument?.querySelector("textarea.xterm-helper-textarea");o&&o.focus()}else setTimeout(()=>r(n+1),500)}catch(e){console.error("Access error during injection:",e),em("Error accessing terminal: "+String(e))}};setTimeout(()=>r(),1e3)}})}),eO&&(0,t.jsxs)(t.Fragment,{children:[(0,t.jsx)("div",{className:"relative h-full w-2 shrink-0 cursor-col-resize bg-base-300/40 hover:bg-base-content/20",onMouseDown:e=>{e.preventDefault(),e2(!0),ec.current={startX:e.clientX,startRatio:eQ}},role:"separator","aria-orientation":"vertical","aria-label":"Resize preview panel",title:"Drag to resize preview panel",children:(0,t.jsx)("div",{className:"absolute left-1/2 top-1/2 h-12 w-[2px] -translate-x-1/2 -translate-y-1/2 rounded-full bg-base-content/30"})}),(0,t.jsxs)("div",{className:"flex h-full min-w-0 flex-1 flex-col border-l border-base-content/10 bg-base-200/50",children:[(0,t.jsxs)("form",{className:"flex items-center gap-2 border-b border-base-content/10 bg-base-200 px-3 py-2",onSubmit:e=>{e.preventDefault(),tj(e_,!0)},children:[(0,t.jsx)("button",{className:"btn btn-ghost btn-xs h-7 min-h-7 w-7 p-0",type:"button",onClick:()=>tS("back"),disabled:!eX,title:"Go back","aria-label":"Go back",children:(0,t.jsx)(P.ArrowLeft,{className:"h-3.5 w-3.5"})}),(0,t.jsx)("button",{className:"btn btn-ghost btn-xs h-7 min-h-7 w-7 p-0",type:"button",onClick:()=>tS("forward"),disabled:!eX,title:"Go forward","aria-label":"Go forward",children:(0,t.jsx)(F,{className:"h-3.5 w-3.5"})}),(0,t.jsx)("button",{className:"btn btn-ghost btn-xs h-7 min-h-7 w-7 p-0",type:"button",onClick:()=>tS("reload"),disabled:!eX,title:"Reload preview","aria-label":"Reload preview",children:(0,t.jsx)(z,{className:"h-3.5 w-3.5"})}),(0,t.jsx)("input",{ref:el,type:"text",className:"input input-xs input-bordered w-full font-mono",value:e_,onChange:e=>eG(e.target.value),placeholder:"http://127.0.0.1:3000",spellCheck:!1}),(0,t.jsx)("button",{className:`btn btn-ghost btn-xs ${eJ?"btn-active text-success":""}`,type:"button",onClick:tk,disabled:!eX,title:eJ?"Disable picker":"Pick element from preview",children:(0,t.jsx)(L,{className:"h-3 w-3"})}),(0,t.jsx)("button",{className:"btn btn-xs",type:"submit",children:"Go"})]}),(0,t.jsx)("div",{className:"min-h-0 flex-1",children:eX?(0,t.jsx)("iframe",{ref:ei,src:eX,className:`h-full w-full border-none ${e9||e1?"pointer-events-none":""}`,title:"Dev server preview",onLoad:tC,sandbox:"allow-forms allow-modals allow-pointer-lock allow-popups allow-same-origin allow-scripts allow-downloads"}):(0,t.jsx)("div",{className:"flex h-full items-center justify-center px-6 text-center text-xs opacity-70",children:"Run the dev server, or enter a URL above to load a preview."})})]})]})]}),(0,t.jsxs)("div",{className:`absolute z-30 overflow-hidden rounded-lg border border-base-content/20 bg-base-200/95 shadow-2xl backdrop-blur-sm ${e9||e1?"":"transition-all"}`,style:{bottom:80,right:tR,width:e5.width,height:e3?40:e5.height,maxWidth:"calc(100vw - 2rem)",maxHeight:"calc(100vh - 2rem)"},children:[(0,t.jsx)("button",{className:`absolute left-0 top-0 z-50 flex h-10 w-10 items-center justify-center text-base-content/30 hover:text-base-content/60 ${e3?"cursor-pointer":"cursor-nwse-resize"}`,onMouseDown:e3?void 0:e=>{e.preventDefault(),e.stopPropagation(),e8(!0),tt.current={startX:e.clientX,startY:e.clientY,startWidth:e5.width,startHeight:e5.height}},onClick:e3?()=>e6(!1):void 0,title:e3?"Expand terminal":"Drag to resize",type:"button",children:(0,t.jsx)($,{size:14})}),!e3&&(0,t.jsxs)("button",{className:"flex h-10 w-full items-center justify-between px-3 pl-10 text-xs font-mono hover:bg-base-content/10",onClick:()=>e6(e=>!e),title:"Minimize terminal",type:"button",children:[(0,t.jsx)("span",{children:"Terminal"}),(0,t.jsx)("span",{className:"opacity-70",children:"Hide"})]}),(0,t.jsx)("div",{className:e3?"h-0 overflow-hidden":"h-[calc(100%-2.5rem)]",children:(0,t.jsx)("iframe",{ref:es,src:"/terminal",className:`h-full w-full border-none dark:invert dark:brightness-90 ${e9||e1?"pointer-events-none":""}`,allow:"clipboard-read; clipboard-write",onLoad:()=>{if(!es.current)return;let t=es.current;try{t.contentWindow}catch(e){console.error("Secondary terminal: Cross-Origin access blocked.");return}t.contentWindow&&(t.contentWindow.onbeforeunload=null,t.contentWindow.addEventListener("beforeunload",e=>{e.stopImmediatePropagation()},!0));let r=(n=0)=>{if(!(n>30))try{let s=t.contentWindow;if(s&&s.term){let r=s.term;tM(t,eu,{onLinkActivated:()=>e6(!0)});try{r.options.theme={...r.options.theme||{},selectionBackground:"rgba(59, 130, 246, 0.4)"}}catch{}try{let e=()=>{r.buffer?.active&&(r.buffer.active.baseY,r.buffer.active.viewportY),r.scrollToBottom()};if(r.onWriteParsed)r.onWriteParsed(e);else{let r=t.contentDocument?.querySelector(".xterm-screen")||t.contentDocument?.body;r&&new MutationObserver(e).observe(r,{childList:!0,subtree:!0,characterData:!0})}}catch(e){console.error("Failed to setup auto-scroll:",e)}let n=a||e,i=`cd ${Z(n)}`;r.paste(i);let l=()=>{let e=t.contentDocument?.querySelector("textarea.xterm-helper-textarea");e?e.dispatchEvent(new KeyboardEvent("keypress",{bubbles:!0,cancelable:!0,charCode:13,keyCode:13,key:"Enter",view:s})):r.paste("\r")};l(),B&&!O&&setTimeout(()=>{r.paste(B),l()},500),s.focus();let o=t.contentDocument?.querySelector("textarea.xterm-helper-textarea");o&&o.focus()}else setTimeout(()=>r(n+1),500)}catch(e){console.error("Secondary terminal injection error",e)}};setTimeout(()=>r(),1e3)}})})]}),eC&&(0,t.jsx)(X,{initialPath:eM,worktreePath:a,onPathChange:eE,onConfirm:e=>{e$(!1),td(e)},onCancel:()=>e$(!1)})]})}let ei=(0,n.createServerReference)("40c6dead606ab80a408b355a16996786ced252a1f0",n.callServer,void 0,n.findSourceMapURL,"consumeSessionLaunchContext"),el=(0,n.createServerReference)("405389e656ec32bedde3c7865f5fb6ac6af06610b2",n.callServer,void 0,n.findSourceMapURL,"getSessionMetadata"),eo=(0,n.createServerReference)("40d5021b06f161551f499cc3328abaa73f1e59cc91",n.callServer,void 0,n.findSourceMapURL,"markSessionInitialized");var ec=e.i(15588);function ed(){let e=(0,a.useParams)().sessionId,n=Array.isArray(e)?e[0]:e,s=(0,a.useRouter)(),[i,l]=(0,r.useState)(null),[o,c]=(0,r.useState)(!0),[d,u]=(0,r.useState)(null),[h,m]=(0,r.useState)(void 0),[p,f]=(0,r.useState)(void 0),[b,x]=(0,r.useState)(void 0),[v,w]=(0,r.useState)([]),[g,y]=(0,r.useState)(void 0),[j,k]=(0,r.useState)(void 0),[N,S]=(0,r.useState)(void 0),[C,$]=(0,r.useState)(!0);(0,r.useEffect)(()=>(document.documentElement.classList.add("session-page"),()=>{document.documentElement.classList.remove("session-page")}),[]),(0,r.useEffect)(()=>{n&&(async()=>{try{if(!(await (0,ec.startTtydProcess)()).success){u("Failed to start terminal service"),c(!1);return}let e=await el(n);if(!e){u("Session not found"),c(!1);return}if(l(e),!1===e.initialized){let e=await ei(n);if(e.success&&e.context){let t=e.context;m(t.initialMessage),f(t.rawInitialMessage),x(t.startupScript),w(t.attachmentNames||[]),y(t.title),k(t.agentProvider),S(t.model)}$(!1)}else $(!0);c(!1)}catch(e){console.error("Failed to load session:",e),u("Failed to load session"),c(!1)}})()},[n]);let M=e=>{e?window.location.href="/":s.push("/")},E=async()=>{n&&await eo(n)};return o?(0,t.jsx)("div",{className:"flex h-screen w-full items-center justify-center bg-base-100",children:(0,t.jsxs)("div",{className:"flex flex-col items-center gap-4",children:[(0,t.jsx)("span",{className:"loading loading-spinner loading-lg text-primary"}),(0,t.jsx)("p",{className:"opacity-60",children:"Loading session..."})]})}):d||!i?(0,t.jsx)("div",{className:"flex h-screen w-full items-center justify-center bg-base-100",children:(0,t.jsx)("div",{className:"card w-96 bg-base-200 shadow-xl",children:(0,t.jsxs)("div",{className:"card-body items-center text-center",children:[(0,t.jsx)("h2",{className:"card-title text-error",children:"Error"}),(0,t.jsx)("p",{children:d||"Session not found"}),(0,t.jsx)("div",{className:"card-actions justify-end",children:(0,t.jsx)("button",{className:"btn btn-primary",onClick:()=>M(),children:"Back to Home"})})]})})}):(0,t.jsx)(es,{repo:i.repoPath,worktree:i.worktreePath,branch:i.branchName,baseBranch:i.baseBranch,sessionName:i.sessionName,agent:j||i.agent,model:N||i.model,startupScript:b,devServerScript:i.devServerScript,initialMessage:h,rawInitialMessage:p,title:g||i.title,attachmentNames:v,onExit:M,isResume:C,onSessionStart:E})}e.s(["default",()=>ed],36438)}]);
@@ -1,4 +1,4 @@
1
- (globalThis.TURBOPACK||(globalThis.TURBOPACK=[])).push(["object"==typeof document?document.currentScript:void 0,{otherChunks:["static/chunks/2821166934dd45eb.js","static/chunks/8906ac8ef3ff98d4.js","static/chunks/b106d846f2574e10.js","static/chunks/455f6c3030f7e6e2.js"],runtimeModuleIds:[94553]}]),(()=>{let e;if(!Array.isArray(globalThis.TURBOPACK))return;let t="/_next/",r=(self.TURBOPACK_CHUNK_SUFFIX??document?.currentScript?.getAttribute?.("src")?.replace(/^(.*(?=\?)|^.*$)/,""))||"",n=new WeakMap;function o(e,t){this.m=e,this.e=t}let l=o.prototype,i=Object.prototype.hasOwnProperty,s="u">typeof Symbol&&Symbol.toStringTag;function u(e,t,r){i.call(e,t)||Object.defineProperty(e,t,r)}function c(e,t){let r=e[t];return r||(r=a(t),e[t]=r),r}function a(e){return{exports:{},error:void 0,id:e,namespaceObject:void 0}}function f(e,t){u(e,"__esModule",{value:!0}),s&&u(e,s,{value:"Module"});let r=0;for(;r<t.length;){let n=t[r++],o=t[r++];if("number"==typeof o)if(0===o)u(e,n,{value:t[r++],enumerable:!0,writable:!1});else throw Error(`unexpected tag: ${o}`);else"function"==typeof t[r]?u(e,n,{get:o,set:t[r++],enumerable:!0}):u(e,n,{get:o,enumerable:!0})}Object.seal(e)}l.s=function(e,t){let r,n;null!=t?n=(r=c(this.c,t)).exports:(r=this.m,n=this.e),r.namespaceObject=n,f(n,e)},l.j=function(e,t){var r,o;let l,s,u;null!=t?s=(l=c(this.c,t)).exports:(l=this.m,s=this.e);let a=(r=l,o=s,(u=n.get(r))||(n.set(r,u=[]),r.exports=r.namespaceObject=new Proxy(o,{get(e,t){if(i.call(e,t)||"default"===t||"__esModule"===t)return Reflect.get(e,t);for(let e of u){let r=Reflect.get(e,t);if(void 0!==r)return r}},ownKeys(e){let t=Reflect.ownKeys(e);for(let e of u)for(let r of Reflect.ownKeys(e))"default"===r||t.includes(r)||t.push(r);return t}})),u);"object"==typeof e&&null!==e&&a.push(e)},l.v=function(e,t){(null!=t?c(this.c,t):this.m).exports=e},l.n=function(e,t){let r;(r=null!=t?c(this.c,t):this.m).exports=r.namespaceObject=e};let p=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__,h=[null,p({}),p([]),p(p)];function d(e,t,r){let n=[],o=-1;for(let t=e;("object"==typeof t||"function"==typeof t)&&!h.includes(t);t=p(t))for(let r of Object.getOwnPropertyNames(t))n.push(r,function(e,t){return()=>e[t]}(e,r)),-1===o&&"default"===r&&(o=n.length-1);return r&&o>=0||(o>=0?n.splice(o,1,0,e):n.push("default",0,e)),f(t,n),t}function m(e){let t=B(e,this.m);if(t.namespaceObject)return t.namespaceObject;let r=t.exports;return t.namespaceObject=d(r,"function"==typeof r?function(...e){return r.apply(this,e)}:Object.create(null),r&&r.__esModule)}function b(e){let t=e.indexOf("#");-1!==t&&(e=e.substring(0,t));let r=e.indexOf("?");return -1!==r&&(e=e.substring(0,r)),e}function y(){let e,t;return{promise:new Promise((r,n)=>{t=n,e=r}),resolve:e,reject:t}}l.i=m,l.A=function(e){return this.r(e)(m.bind(this))},l.t="function"==typeof require?require:function(){throw Error("Unexpected use of runtime require")},l.r=function(e){return B(e,this.m).exports},l.f=function(e){function t(t){if(t=b(t),i.call(e,t))return e[t].module();let r=Error(`Cannot find module '${t}'`);throw r.code="MODULE_NOT_FOUND",r}return t.keys=()=>Object.keys(e),t.resolve=t=>{if(t=b(t),i.call(e,t))return e[t].id();let r=Error(`Cannot find module '${t}'`);throw r.code="MODULE_NOT_FOUND",r},t.import=async e=>await t(e),t};let O=Symbol("turbopack queues"),g=Symbol("turbopack exports"),w=Symbol("turbopack error");function C(e){e&&1!==e.status&&(e.status=1,e.forEach(e=>e.queueCount--),e.forEach(e=>e.queueCount--?e.queueCount++:e()))}l.a=function(e,t){let r=this.m,n=t?Object.assign([],{status:-1}):void 0,o=new Set,{resolve:l,reject:i,promise:s}=y(),u=Object.assign(s,{[g]:r.exports,[O]:e=>{n&&e(n),o.forEach(e),u.catch(()=>{})}}),c={get:()=>u,set(e){e!==u&&(u[g]=e)}};Object.defineProperty(r,"exports",c),Object.defineProperty(r,"namespaceObject",c),e(function(e){let t=e.map(e=>{if(null!==e&&"object"==typeof e){if(O in e)return e;if(null!=e&&"object"==typeof e&&"then"in e&&"function"==typeof e.then){let t=Object.assign([],{status:0}),r={[g]:{},[O]:e=>e(t)};return e.then(e=>{r[g]=e,C(t)},e=>{r[w]=e,C(t)}),r}}return{[g]:e,[O]:()=>{}}}),r=()=>t.map(e=>{if(e[w])throw e[w];return e[g]}),{promise:l,resolve:i}=y(),s=Object.assign(()=>i(r),{queueCount:0});function u(e){e!==n&&!o.has(e)&&(o.add(e),e&&0===e.status&&(s.queueCount++,e.push(s)))}return t.map(e=>e[O](u)),s.queueCount?l:r()},function(e){e?i(u[w]=e):l(u[g]),C(n)}),n&&-1===n.status&&(n.status=0)};let U=function(e){let t=new URL(e,"x:/"),r={};for(let e in t)r[e]=t[e];for(let t in r.href=e,r.pathname=e.replace(/[?#].*/,""),r.origin=r.protocol="",r.toString=r.toJSON=(...t)=>e,r)Object.defineProperty(this,t,{enumerable:!0,configurable:!0,value:r[t]})};function R(e,t){throw Error(`Invariant: ${t(e)}`)}U.prototype=URL.prototype,l.U=U,l.z=function(e){throw Error("dynamic usage of require is not supported")},l.g=globalThis;let j=o.prototype;var k,_=((k=_||{})[k.Runtime=0]="Runtime",k[k.Parent=1]="Parent",k[k.Update=2]="Update",k);let v=new Map;l.M=v;let $=new Map,P=new Map;async function S(e,t,r){let n;if("string"==typeof r)return E(e,t,K(r));let o=r.included||[],l=o.map(e=>!!v.has(e)||$.get(e));if(l.length>0&&l.every(e=>e))return void await Promise.all(l);let i=r.moduleChunks||[],s=i.map(e=>P.get(e)).filter(e=>e);if(s.length>0){if(s.length===i.length)return void await Promise.all(s);let r=new Set;for(let e of i)P.has(e)||r.add(e);for(let n of r){let r=E(e,t,K(n));P.set(n,r),s.push(r)}n=Promise.all(s)}else{for(let o of(n=E(e,t,K(r.path)),i))P.has(o)||P.set(o,n)}for(let e of o)$.has(e)||$.set(e,n);await n}j.l=function(e){return S(1,this.m.id,e)};let T=Promise.resolve(void 0),A=new WeakMap;function E(t,r,n){let o=e.loadChunkCached(t,n),l=A.get(o);if(void 0===l){let e=A.set.bind(A,o,T);l=o.then(e).catch(e=>{let o;switch(t){case 0:o=`as a runtime dependency of chunk ${r}`;break;case 1:o=`from module ${r}`;break;case 2:o="from an HMR update";break;default:R(t,e=>`Unknown source type: ${e}`)}let l=Error(`Failed to load chunk ${n} ${o}${e?`: ${e}`:""}`,e?{cause:e}:void 0);throw l.name="ChunkLoadError",l}),A.set(o,l)}return l}function K(e){return`${t}${e.split("/").map(e=>encodeURIComponent(e)).join("/")}${r}`}j.L=function(e){return E(1,this.m.id,e)},j.R=function(e){let t=this.r(e);return t?.default??t},j.P=function(e){return`/ROOT/${e??""}`},j.b=function(e){let t=new Blob([`self.TURBOPACK_WORKER_LOCATION = ${JSON.stringify(location.origin)};
1
+ (globalThis.TURBOPACK||(globalThis.TURBOPACK=[])).push(["object"==typeof document?document.currentScript:void 0,{otherChunks:["static/chunks/b77fa77a013ad38a.js","static/chunks/0b5678df432c3623.js","static/chunks/b106d846f2574e10.js","static/chunks/455f6c3030f7e6e2.js"],runtimeModuleIds:[94553]}]),(()=>{let e;if(!Array.isArray(globalThis.TURBOPACK))return;let t="/_next/",r=(self.TURBOPACK_CHUNK_SUFFIX??document?.currentScript?.getAttribute?.("src")?.replace(/^(.*(?=\?)|^.*$)/,""))||"",n=new WeakMap;function o(e,t){this.m=e,this.e=t}let l=o.prototype,i=Object.prototype.hasOwnProperty,s="u">typeof Symbol&&Symbol.toStringTag;function u(e,t,r){i.call(e,t)||Object.defineProperty(e,t,r)}function a(e,t){let r=e[t];return r||(r=c(t),e[t]=r),r}function c(e){return{exports:{},error:void 0,id:e,namespaceObject:void 0}}function f(e,t){u(e,"__esModule",{value:!0}),s&&u(e,s,{value:"Module"});let r=0;for(;r<t.length;){let n=t[r++],o=t[r++];if("number"==typeof o)if(0===o)u(e,n,{value:t[r++],enumerable:!0,writable:!1});else throw Error(`unexpected tag: ${o}`);else"function"==typeof t[r]?u(e,n,{get:o,set:t[r++],enumerable:!0}):u(e,n,{get:o,enumerable:!0})}Object.seal(e)}l.s=function(e,t){let r,n;null!=t?n=(r=a(this.c,t)).exports:(r=this.m,n=this.e),r.namespaceObject=n,f(n,e)},l.j=function(e,t){var r,o;let l,s,u;null!=t?s=(l=a(this.c,t)).exports:(l=this.m,s=this.e);let c=(r=l,o=s,(u=n.get(r))||(n.set(r,u=[]),r.exports=r.namespaceObject=new Proxy(o,{get(e,t){if(i.call(e,t)||"default"===t||"__esModule"===t)return Reflect.get(e,t);for(let e of u){let r=Reflect.get(e,t);if(void 0!==r)return r}},ownKeys(e){let t=Reflect.ownKeys(e);for(let e of u)for(let r of Reflect.ownKeys(e))"default"===r||t.includes(r)||t.push(r);return t}})),u);"object"==typeof e&&null!==e&&c.push(e)},l.v=function(e,t){(null!=t?a(this.c,t):this.m).exports=e},l.n=function(e,t){let r;(r=null!=t?a(this.c,t):this.m).exports=r.namespaceObject=e};let p=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__,h=[null,p({}),p([]),p(p)];function d(e,t,r){let n=[],o=-1;for(let t=e;("object"==typeof t||"function"==typeof t)&&!h.includes(t);t=p(t))for(let r of Object.getOwnPropertyNames(t))n.push(r,function(e,t){return()=>e[t]}(e,r)),-1===o&&"default"===r&&(o=n.length-1);return r&&o>=0||(o>=0?n.splice(o,1,0,e):n.push("default",0,e)),f(t,n),t}function m(e){let t=B(e,this.m);if(t.namespaceObject)return t.namespaceObject;let r=t.exports;return t.namespaceObject=d(r,"function"==typeof r?function(...e){return r.apply(this,e)}:Object.create(null),r&&r.__esModule)}function b(e){let t=e.indexOf("#");-1!==t&&(e=e.substring(0,t));let r=e.indexOf("?");return -1!==r&&(e=e.substring(0,r)),e}function y(){let e,t;return{promise:new Promise((r,n)=>{t=n,e=r}),resolve:e,reject:t}}l.i=m,l.A=function(e){return this.r(e)(m.bind(this))},l.t="function"==typeof require?require:function(){throw Error("Unexpected use of runtime require")},l.r=function(e){return B(e,this.m).exports},l.f=function(e){function t(t){if(t=b(t),i.call(e,t))return e[t].module();let r=Error(`Cannot find module '${t}'`);throw r.code="MODULE_NOT_FOUND",r}return t.keys=()=>Object.keys(e),t.resolve=t=>{if(t=b(t),i.call(e,t))return e[t].id();let r=Error(`Cannot find module '${t}'`);throw r.code="MODULE_NOT_FOUND",r},t.import=async e=>await t(e),t};let O=Symbol("turbopack queues"),g=Symbol("turbopack exports"),w=Symbol("turbopack error");function C(e){e&&1!==e.status&&(e.status=1,e.forEach(e=>e.queueCount--),e.forEach(e=>e.queueCount--?e.queueCount++:e()))}l.a=function(e,t){let r=this.m,n=t?Object.assign([],{status:-1}):void 0,o=new Set,{resolve:l,reject:i,promise:s}=y(),u=Object.assign(s,{[g]:r.exports,[O]:e=>{n&&e(n),o.forEach(e),u.catch(()=>{})}}),a={get:()=>u,set(e){e!==u&&(u[g]=e)}};Object.defineProperty(r,"exports",a),Object.defineProperty(r,"namespaceObject",a),e(function(e){let t=e.map(e=>{if(null!==e&&"object"==typeof e){if(O in e)return e;if(null!=e&&"object"==typeof e&&"then"in e&&"function"==typeof e.then){let t=Object.assign([],{status:0}),r={[g]:{},[O]:e=>e(t)};return e.then(e=>{r[g]=e,C(t)},e=>{r[w]=e,C(t)}),r}}return{[g]:e,[O]:()=>{}}}),r=()=>t.map(e=>{if(e[w])throw e[w];return e[g]}),{promise:l,resolve:i}=y(),s=Object.assign(()=>i(r),{queueCount:0});function u(e){e!==n&&!o.has(e)&&(o.add(e),e&&0===e.status&&(s.queueCount++,e.push(s)))}return t.map(e=>e[O](u)),s.queueCount?l:r()},function(e){e?i(u[w]=e):l(u[g]),C(n)}),n&&-1===n.status&&(n.status=0)};let U=function(e){let t=new URL(e,"x:/"),r={};for(let e in t)r[e]=t[e];for(let t in r.href=e,r.pathname=e.replace(/[?#].*/,""),r.origin=r.protocol="",r.toString=r.toJSON=(...t)=>e,r)Object.defineProperty(this,t,{enumerable:!0,configurable:!0,value:r[t]})};function R(e,t){throw Error(`Invariant: ${t(e)}`)}U.prototype=URL.prototype,l.U=U,l.z=function(e){throw Error("dynamic usage of require is not supported")},l.g=globalThis;let j=o.prototype;var k,_=((k=_||{})[k.Runtime=0]="Runtime",k[k.Parent=1]="Parent",k[k.Update=2]="Update",k);let v=new Map;l.M=v;let $=new Map,P=new Map;async function S(e,t,r){let n;if("string"==typeof r)return E(e,t,K(r));let o=r.included||[],l=o.map(e=>!!v.has(e)||$.get(e));if(l.length>0&&l.every(e=>e))return void await Promise.all(l);let i=r.moduleChunks||[],s=i.map(e=>P.get(e)).filter(e=>e);if(s.length>0){if(s.length===i.length)return void await Promise.all(s);let r=new Set;for(let e of i)P.has(e)||r.add(e);for(let n of r){let r=E(e,t,K(n));P.set(n,r),s.push(r)}n=Promise.all(s)}else{for(let o of(n=E(e,t,K(r.path)),i))P.has(o)||P.set(o,n)}for(let e of o)$.has(e)||$.set(e,n);await n}j.l=function(e){return S(1,this.m.id,e)};let T=Promise.resolve(void 0),A=new WeakMap;function E(t,r,n){let o=e.loadChunkCached(t,n),l=A.get(o);if(void 0===l){let e=A.set.bind(A,o,T);l=o.then(e).catch(e=>{let o;switch(t){case 0:o=`as a runtime dependency of chunk ${r}`;break;case 1:o=`from module ${r}`;break;case 2:o="from an HMR update";break;default:R(t,e=>`Unknown source type: ${e}`)}let l=Error(`Failed to load chunk ${n} ${o}${e?`: ${e}`:""}`,e?{cause:e}:void 0);throw l.name="ChunkLoadError",l}),A.set(o,l)}return l}function K(e){return`${t}${e.split("/").map(e=>encodeURIComponent(e)).join("/")}${r}`}j.L=function(e){return E(1,this.m.id,e)},j.R=function(e){let t=this.r(e);return t?.default??t},j.P=function(e){return`/ROOT/${e??""}`},j.b=function(e){let t=new Blob([`self.TURBOPACK_WORKER_LOCATION = ${JSON.stringify(location.origin)};
2
2
  self.TURBOPACK_CHUNK_SUFFIX = ${JSON.stringify(r)};
3
3
  self.TURBOPACK_NEXT_CHUNK_URLS = ${JSON.stringify(e.reverse().map(K),null,2)};
4
- importScripts(...self.TURBOPACK_NEXT_CHUNK_URLS.map(c => self.TURBOPACK_WORKER_LOCATION + c).reverse());`],{type:"text/javascript"});return URL.createObjectURL(t)};let x=/\.js(?:\?[^#]*)?(?:#.*)?$/,N=/\.css(?:\?[^#]*)?(?:#.*)?$/;function M(e){return N.test(e)}l.w=function(t,r,n){return e.loadWebAssembly(1,this.m.id,t,r,n)},l.u=function(t,r){return e.loadWebAssemblyModule(1,this.m.id,t,r)};let L={};l.c=L;let B=(e,t)=>{let r=L[e];if(r){if(r.error)throw r.error;return r}return q(e,_.Parent,t.id)};function q(e,t,r){let n=v.get(e);if("function"!=typeof n)throw Error(function(e,t,r){let n;switch(t){case 0:n=`as a runtime entry of chunk ${r}`;break;case 1:n=`because it was required from module ${r}`;break;case 2:n="because of an HMR update";break;default:R(t,e=>`Unknown source type: ${e}`)}return`Module ${e} was instantiated ${n}, but the module factory is not available.`}(e,t,r));let l=a(e),i=l.exports;L[e]=l;let s=new o(l,i);try{n(s,l,i)}catch(e){throw l.error=e,e}return l.namespaceObject&&l.exports!==l.namespaceObject&&d(l.exports,l.namespaceObject),l}function I(r){let n,o=function(e){if("string"==typeof e)return e;let r=decodeURIComponent(("u">typeof TURBOPACK_NEXT_CHUNK_URLS?TURBOPACK_NEXT_CHUNK_URLS.pop():e.getAttribute("src")).replace(/[?#].*$/,""));return r.startsWith(t)?r.slice(t.length):r}(r[0]);return 2===r.length?n=r[1]:(n=void 0,!function(e,t,r,n){let o=1;for(;o<e.length;){let t=e[o],n=o+1;for(;n<e.length&&"function"!=typeof e[n];)n++;if(n===e.length)throw Error("malformed chunk format, expected a factory function");if(!r.has(t)){let l=e[n];for(Object.defineProperty(l,"name",{value:"module evaluation"});o<n;o++)t=e[o],r.set(t,l)}o=n+1}}(r,0,v)),e.registerChunk(o,n)}let W=new Map;function H(e){let t=W.get(e);if(!t){let r,n;t={resolved:!1,loadingStarted:!1,promise:new Promise((e,t)=>{r=e,n=t}),resolve:()=>{t.resolved=!0,r()},reject:n},W.set(e,t)}return t}e={async registerChunk(e,t){if(H(K(e)).resolve(),null!=t){for(let e of t.otherChunks)H(K("string"==typeof e?e:e.path));if(await Promise.all(t.otherChunks.map(t=>S(0,e,t))),t.runtimeModuleIds.length>0)for(let r of t.runtimeModuleIds)!function(e,t){let r=L[t];if(r){if(r.error)throw r.error;return}q(t,_.Runtime,e)}(e,r)}},loadChunkCached:(e,t)=>(function(e,t){let r=H(t);if(r.loadingStarted)return r.promise;if(e===_.Runtime)return r.loadingStarted=!0,M(t)&&r.resolve(),r.promise;if("function"==typeof importScripts)if(M(t));else if(x.test(t))self.TURBOPACK_NEXT_CHUNK_URLS.push(t),importScripts(TURBOPACK_WORKER_LOCATION+t);else throw Error(`can't infer type of chunk from URL ${t} in worker`);else{let e=decodeURI(t);if(M(t))if(document.querySelectorAll(`link[rel=stylesheet][href="${t}"],link[rel=stylesheet][href^="${t}?"],link[rel=stylesheet][href="${e}"],link[rel=stylesheet][href^="${e}?"]`).length>0)r.resolve();else{let e=document.createElement("link");e.rel="stylesheet",e.href=t,e.onerror=()=>{r.reject()},e.onload=()=>{r.resolve()},document.head.appendChild(e)}else if(x.test(t)){let n=document.querySelectorAll(`script[src="${t}"],script[src^="${t}?"],script[src="${e}"],script[src^="${e}?"]`);if(n.length>0)for(let e of Array.from(n))e.addEventListener("error",()=>{r.reject()});else{let e=document.createElement("script");e.src=t,e.onerror=()=>{r.reject()},document.head.appendChild(e)}}else throw Error(`can't infer type of chunk from URL ${t}`)}return r.loadingStarted=!0,r.promise})(e,t),async loadWebAssembly(e,t,r,n,o){let l=fetch(K(r)),{instance:i}=await WebAssembly.instantiateStreaming(l,o);return i.exports},async loadWebAssemblyModule(e,t,r,n){let o=fetch(K(r));return await WebAssembly.compileStreaming(o)}};let F=globalThis.TURBOPACK;globalThis.TURBOPACK={push:I},F.forEach(I)})();
4
+ importScripts(...self.TURBOPACK_NEXT_CHUNK_URLS.map(c => self.TURBOPACK_WORKER_LOCATION + c).reverse());`],{type:"text/javascript"});return URL.createObjectURL(t)};let x=/\.js(?:\?[^#]*)?(?:#.*)?$/,N=/\.css(?:\?[^#]*)?(?:#.*)?$/;function M(e){return N.test(e)}l.w=function(t,r,n){return e.loadWebAssembly(1,this.m.id,t,r,n)},l.u=function(t,r){return e.loadWebAssemblyModule(1,this.m.id,t,r)};let L={};l.c=L;let B=(e,t)=>{let r=L[e];if(r){if(r.error)throw r.error;return r}return q(e,_.Parent,t.id)};function q(e,t,r){let n=v.get(e);if("function"!=typeof n)throw Error(function(e,t,r){let n;switch(t){case 0:n=`as a runtime entry of chunk ${r}`;break;case 1:n=`because it was required from module ${r}`;break;case 2:n="because of an HMR update";break;default:R(t,e=>`Unknown source type: ${e}`)}return`Module ${e} was instantiated ${n}, but the module factory is not available.`}(e,t,r));let l=c(e),i=l.exports;L[e]=l;let s=new o(l,i);try{n(s,l,i)}catch(e){throw l.error=e,e}return l.namespaceObject&&l.exports!==l.namespaceObject&&d(l.exports,l.namespaceObject),l}function I(r){let n,o=function(e){if("string"==typeof e)return e;let r=decodeURIComponent(("u">typeof TURBOPACK_NEXT_CHUNK_URLS?TURBOPACK_NEXT_CHUNK_URLS.pop():e.getAttribute("src")).replace(/[?#].*$/,""));return r.startsWith(t)?r.slice(t.length):r}(r[0]);return 2===r.length?n=r[1]:(n=void 0,!function(e,t,r,n){let o=1;for(;o<e.length;){let t=e[o],n=o+1;for(;n<e.length&&"function"!=typeof e[n];)n++;if(n===e.length)throw Error("malformed chunk format, expected a factory function");if(!r.has(t)){let l=e[n];for(Object.defineProperty(l,"name",{value:"module evaluation"});o<n;o++)t=e[o],r.set(t,l)}o=n+1}}(r,0,v)),e.registerChunk(o,n)}let W=new Map;function H(e){let t=W.get(e);if(!t){let r,n;t={resolved:!1,loadingStarted:!1,promise:new Promise((e,t)=>{r=e,n=t}),resolve:()=>{t.resolved=!0,r()},reject:n},W.set(e,t)}return t}e={async registerChunk(e,t){if(H(K(e)).resolve(),null!=t){for(let e of t.otherChunks)H(K("string"==typeof e?e:e.path));if(await Promise.all(t.otherChunks.map(t=>S(0,e,t))),t.runtimeModuleIds.length>0)for(let r of t.runtimeModuleIds)!function(e,t){let r=L[t];if(r){if(r.error)throw r.error;return}q(t,_.Runtime,e)}(e,r)}},loadChunkCached:(e,t)=>(function(e,t){let r=H(t);if(r.loadingStarted)return r.promise;if(e===_.Runtime)return r.loadingStarted=!0,M(t)&&r.resolve(),r.promise;if("function"==typeof importScripts)if(M(t));else if(x.test(t))self.TURBOPACK_NEXT_CHUNK_URLS.push(t),importScripts(TURBOPACK_WORKER_LOCATION+t);else throw Error(`can't infer type of chunk from URL ${t} in worker`);else{let e=decodeURI(t);if(M(t))if(document.querySelectorAll(`link[rel=stylesheet][href="${t}"],link[rel=stylesheet][href^="${t}?"],link[rel=stylesheet][href="${e}"],link[rel=stylesheet][href^="${e}?"]`).length>0)r.resolve();else{let e=document.createElement("link");e.rel="stylesheet",e.href=t,e.onerror=()=>{r.reject()},e.onload=()=>{r.resolve()},document.head.appendChild(e)}else if(x.test(t)){let n=document.querySelectorAll(`script[src="${t}"],script[src^="${t}?"],script[src="${e}"],script[src^="${e}?"]`);if(n.length>0)for(let e of Array.from(n))e.addEventListener("error",()=>{r.reject()});else{let e=document.createElement("script");e.src=t,e.onerror=()=>{r.reject()},document.head.appendChild(e)}}else throw Error(`can't infer type of chunk from URL ${t}`)}return r.loadingStarted=!0,r.promise})(e,t),async loadWebAssembly(e,t,r,n,o){let l=fetch(K(r)),{instance:i}=await WebAssembly.instantiateStreaming(l,o);return i.exports},async loadWebAssemblyModule(e,t,r,n){let o=fetch(K(r));return await WebAssembly.compileStreaming(o)}};let F=globalThis.TURBOPACK;globalThis.TURBOPACK={push:I},F.forEach(I)})();
package/README.md CHANGED
@@ -2,26 +2,28 @@
2
2
 
3
3
  Viba is a local session manager for AI coding agents. It lets you pick a Git repository, start an isolated worktree session, launch an agent CLI in a browser terminal, and manage the session lifecycle from one UI.
4
4
 
5
+ ![](./docs/poster.jpeg)
6
+
5
7
  ## Major Features
6
8
 
7
- - Repository picker with local filesystem browsing and Git repo validation.
8
- - Isolated session worktrees using `git worktree`, with per-session branch naming (`viba/<session>`).
9
- - Start new sessions or resume existing sessions for a repository.
10
- - Multi-agent setup with provider/model selection (Codex, Gemini, Cursor Agent data included).
11
- - Dual terminal workspace:
9
+ - **Isolated Sessions**: Uses `git worktree` to create clean, isolated environments for every task, with automatic per-session branch naming (`viba/<session>`).
10
+ - **New Attempt Flow**: Start new sessions pre-filled with context (title, model, prompt, attachments) from any previous session to iterate quickly.
11
+ - **Enhanced File Browser**:
12
+ - **Grid & List Views**: Browse files with rich thumbnails or a compact list.
13
+ - **Pinned Shortcuts**: Pin frequently used directories for quick navigation across session restarts.
14
+ - **Clipboard Paste**: Quickly add attachments by pasting files or images directly into the browser.
15
+ - **@ Mention Suggestions**: Intelligent file path suggestions from your tracked repository files.
16
+ - **Dual Terminal Workspace**:
12
17
  - Left terminal for agent execution.
13
18
  - Right terminal for startup/dev scripts.
14
- - Session prompt tooling:
15
- - Optional title and initial message.
16
- - `@` file suggestions from tracked repo files.
17
- - File attachments saved per session.
18
- - Session operations in the active view:
19
- - Ask agent to create a commit.
20
- - Merge session branch into base branch.
21
- - Rebase session branch onto base branch.
22
- - Live ahead/behind divergence and uncommitted file count.
23
- - IDE deep-links for opening the session worktree (VS Code, Cursor, Windsurf, Antigravity).
24
- - Persistent local config and session metadata under `~/.viba`.
19
+ - **Session Lifecycle Management**:
20
+ - Real-time Git status (ahead/behind counts, uncommitted changes).
21
+ - One-click **Commit**, **Merge**, and **Rebase** operations.
22
+ - **IDE Deep-links**: Open session worktrees directly in VS Code, Cursor, Windsurf, or Antigravity.
23
+ - **Robust Session Resume**: Resume any session with full context, preserving original startup flags and model overrides.
24
+ - **Async Operations**: Performance-optimized background tasks like session purging to keep the UI responsive.
25
+ - **Multi-Agent Support**: Out-of-the-box support for Codex, Gemini, and Cursor Agent, with a customizable provider/model selector.
26
+ - **Persistent Metadata**: All session data and configurations are stored locally under `~/.viba`.
25
27
 
26
28
  ## Tech Stack
27
29
 
@@ -33,7 +35,7 @@ Viba is a local session manager for AI coding agents. It lets you pick a Git rep
33
35
  ## Prerequisites
34
36
 
35
37
  - Node.js and npm
36
- - `ttyd` installed and available in `PATH`
38
+ - A system package manager (`viba-cli` auto-installs `ttyd` when missing)
37
39
  - At least one supported agent CLI installed (for example `codex`, `gemini`, or `agent`)
38
40
 
39
41
  ## Getting Started
package/bin/viba.mjs CHANGED
@@ -1,6 +1,6 @@
1
1
  #!/usr/bin/env node
2
2
 
3
- import { spawn } from "node:child_process";
3
+ import { spawn, spawnSync } from "node:child_process";
4
4
  import fs from "node:fs";
5
5
  import { createRequire } from "node:module";
6
6
  import net from "node:net";
@@ -14,6 +14,165 @@ const require = createRequire(import.meta.url);
14
14
  const NEXT_BIN = require.resolve("next/dist/bin/next");
15
15
  const DEFAULT_PORT = 3200;
16
16
 
17
+ function isCommandAvailable(command) {
18
+ const probe = process.platform === "win32" ? "where" : "which";
19
+ const result = spawnSync(probe, [command], {
20
+ stdio: "ignore",
21
+ env: process.env,
22
+ });
23
+ return result.status === 0;
24
+ }
25
+
26
+ function runCommand(command, args) {
27
+ const result = spawnSync(command, args, {
28
+ cwd: APP_ROOT,
29
+ env: process.env,
30
+ stdio: "inherit",
31
+ });
32
+ return result.status === 0;
33
+ }
34
+
35
+ function getInstallStrategies() {
36
+ if (process.platform === "darwin") {
37
+ return [
38
+ {
39
+ label: "Homebrew",
40
+ requiredCommands: ["brew"],
41
+ command: "brew",
42
+ args: ["install", "ttyd"],
43
+ },
44
+ {
45
+ label: "MacPorts",
46
+ requiredCommands: ["sudo", "port"],
47
+ command: "sudo",
48
+ args: ["port", "install", "ttyd"],
49
+ },
50
+ ];
51
+ }
52
+
53
+ if (process.platform === "linux") {
54
+ return [
55
+ {
56
+ label: "apt-get",
57
+ requiredCommands: ["apt-get"],
58
+ command: "apt-get",
59
+ args: ["install", "-y", "ttyd"],
60
+ },
61
+ {
62
+ label: "sudo apt-get",
63
+ requiredCommands: ["sudo", "apt-get"],
64
+ command: "sudo",
65
+ args: ["apt-get", "install", "-y", "ttyd"],
66
+ },
67
+ {
68
+ label: "dnf",
69
+ requiredCommands: ["dnf"],
70
+ command: "dnf",
71
+ args: ["install", "-y", "ttyd"],
72
+ },
73
+ {
74
+ label: "sudo dnf",
75
+ requiredCommands: ["sudo", "dnf"],
76
+ command: "sudo",
77
+ args: ["dnf", "install", "-y", "ttyd"],
78
+ },
79
+ {
80
+ label: "yum",
81
+ requiredCommands: ["yum"],
82
+ command: "yum",
83
+ args: ["install", "-y", "ttyd"],
84
+ },
85
+ {
86
+ label: "sudo yum",
87
+ requiredCommands: ["sudo", "yum"],
88
+ command: "sudo",
89
+ args: ["yum", "install", "-y", "ttyd"],
90
+ },
91
+ {
92
+ label: "pacman",
93
+ requiredCommands: ["pacman"],
94
+ command: "pacman",
95
+ args: ["-S", "--noconfirm", "ttyd"],
96
+ },
97
+ {
98
+ label: "sudo pacman",
99
+ requiredCommands: ["sudo", "pacman"],
100
+ command: "sudo",
101
+ args: ["pacman", "-S", "--noconfirm", "ttyd"],
102
+ },
103
+ {
104
+ label: "zypper",
105
+ requiredCommands: ["zypper"],
106
+ command: "zypper",
107
+ args: ["--non-interactive", "install", "ttyd"],
108
+ },
109
+ {
110
+ label: "sudo zypper",
111
+ requiredCommands: ["sudo", "zypper"],
112
+ command: "sudo",
113
+ args: ["zypper", "--non-interactive", "install", "ttyd"],
114
+ },
115
+ ];
116
+ }
117
+
118
+ if (process.platform === "win32") {
119
+ return [
120
+ {
121
+ label: "winget",
122
+ requiredCommands: ["winget"],
123
+ command: "winget",
124
+ args: ["install", "tsl0922.ttyd"],
125
+ },
126
+ {
127
+ label: "scoop",
128
+ requiredCommands: ["scoop"],
129
+ command: "scoop",
130
+ args: ["install", "ttyd"],
131
+ },
132
+ ];
133
+ }
134
+
135
+ return [];
136
+ }
137
+
138
+ function ensureTtydInstalled() {
139
+ if (isCommandAvailable("ttyd")) {
140
+ return;
141
+ }
142
+
143
+ console.log("ttyd is not installed. Attempting automatic installation...");
144
+
145
+ const installStrategies = getInstallStrategies();
146
+ const availableManagers = installStrategies
147
+ .map((strategy) => strategy.label)
148
+ .join(", ");
149
+
150
+ let attempted = false;
151
+
152
+ for (const strategy of installStrategies) {
153
+ const canUseStrategy = strategy.requiredCommands.every((command) => isCommandAvailable(command));
154
+ if (!canUseStrategy) {
155
+ continue;
156
+ }
157
+
158
+ attempted = true;
159
+ console.log(`Trying to install ttyd via ${strategy.label}...`);
160
+
161
+ if (runCommand(strategy.command, strategy.args) && isCommandAvailable("ttyd")) {
162
+ console.log("ttyd installed successfully.");
163
+ return;
164
+ }
165
+ }
166
+
167
+ if (!attempted) {
168
+ throw new Error(
169
+ `ttyd is required, but no supported package manager was found on this machine. Checked: ${availableManagers || "none"}. Install ttyd manually and restart.`,
170
+ );
171
+ }
172
+
173
+ throw new Error("ttyd is required, but automatic installation failed. Install ttyd manually and restart.");
174
+ }
175
+
17
176
  function printHelp() {
18
177
  console.log(`Usage: viba-cli [options]
19
178
 
@@ -120,6 +279,8 @@ function ensureBuildExists() {
120
279
  async function main() {
121
280
  try {
122
281
  const options = parseArgs(process.argv.slice(2));
282
+ ensureTtydInstalled();
283
+
123
284
  const envPort = Number.parseInt(process.env.PORT || "", 10);
124
285
  const preferredPort =
125
286
  options.port ??
package/next.config.mjs CHANGED
@@ -1,5 +1,16 @@
1
1
  /** @type {import("next").NextConfig} */
2
2
  const nextConfig = {
3
+ allowedDevOrigins: ["localhost", "*.localhost", "127.0.0.1"],
4
+ devIndicators: {
5
+ position: "top-right",
6
+ },
7
+ experimental: {
8
+ serverActions: {
9
+ // Allow loopback iframe/proxy origins in local development previews.
10
+ // Example host values: 127.0.0.1:55700
11
+ allowedOrigins: ["127.0.0.*"],
12
+ },
13
+ },
3
14
  async rewrites() {
4
15
  return [
5
16
  {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "viba-cli",
3
- "version": "0.2.0",
3
+ "version": "0.4.0",
4
4
  "private": false,
5
5
  "description": "Local session manager for AI coding agents.",
6
6
  "bin": {
@@ -18,10 +18,10 @@
18
18
  "README.md"
19
19
  ],
20
20
  "scripts": {
21
- "dev": "npx gfport 3200 -- next dev --webpack -p {PORT}",
21
+ "dev": "npx gfport 3200 -- node ./bin/viba.mjs --dev --port {PORT}",
22
22
  "build": "next build",
23
23
  "prepack": "rm -rf .next && npm run build",
24
- "start": "next start -p 3200",
24
+ "start": "node ./bin/viba.mjs",
25
25
  "lint": "eslint",
26
26
  "cli": "node ./bin/viba.mjs",
27
27
  "pack:preview": "npm pack --dry-run"
@@ -37,6 +37,7 @@
37
37
  "@types/uuid": "^10.0.0",
38
38
  "clsx": "^2.1.1",
39
39
  "daisyui": "^5.5.18",
40
+ "http-proxy-middleware": "^3.0.5",
40
41
  "lucide-react": "^0.563.0",
41
42
  "next": "16.1.6",
42
43
  "react": "19.2.3",
Binary file