neural-loom 0.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (368) hide show
  1. package/.next/BUILD_ID +1 -0
  2. package/.next/app-path-routes-manifest.json +18 -0
  3. package/.next/build-manifest.json +20 -0
  4. package/.next/cache/.previewinfo +1 -0
  5. package/.next/cache/.rscinfo +1 -0
  6. package/.next/cache/.tsbuildinfo +1 -0
  7. package/.next/diagnostics/build-diagnostics.json +6 -0
  8. package/.next/diagnostics/framework.json +1 -0
  9. package/.next/diagnostics/route-bundle-stats.json +25 -0
  10. package/.next/export-marker.json +6 -0
  11. package/.next/fallback-build-manifest.json +13 -0
  12. package/.next/images-manifest.json +68 -0
  13. package/.next/next-minimal-server.js.nft.json +1 -0
  14. package/.next/next-server.js.nft.json +1 -0
  15. package/.next/package.json +1 -0
  16. package/.next/prerender-manifest.json +114 -0
  17. package/.next/required-server-files.js +332 -0
  18. package/.next/required-server-files.json +332 -0
  19. package/.next/routes-manifest.json +141 -0
  20. package/.next/server/app/_global-error/page/app-paths-manifest.json +3 -0
  21. package/.next/server/app/_global-error/page/build-manifest.json +16 -0
  22. package/.next/server/app/_global-error/page/next-font-manifest.json +6 -0
  23. package/.next/server/app/_global-error/page/react-loadable-manifest.json +1 -0
  24. package/.next/server/app/_global-error/page/server-reference-manifest.json +4 -0
  25. package/.next/server/app/_global-error/page.js +10 -0
  26. package/.next/server/app/_global-error/page.js.map +5 -0
  27. package/.next/server/app/_global-error/page.js.nft.json +1 -0
  28. package/.next/server/app/_global-error/page_client-reference-manifest.js +3 -0
  29. package/.next/server/app/_global-error.html +1 -0
  30. package/.next/server/app/_global-error.meta +15 -0
  31. package/.next/server/app/_global-error.rsc +15 -0
  32. package/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +5 -0
  33. package/.next/server/app/_global-error.segments/_full.segment.rsc +15 -0
  34. package/.next/server/app/_global-error.segments/_head.segment.rsc +6 -0
  35. package/.next/server/app/_global-error.segments/_index.segment.rsc +5 -0
  36. package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -0
  37. package/.next/server/app/_not-found/page/app-paths-manifest.json +3 -0
  38. package/.next/server/app/_not-found/page/build-manifest.json +16 -0
  39. package/.next/server/app/_not-found/page/next-font-manifest.json +11 -0
  40. package/.next/server/app/_not-found/page/react-loadable-manifest.json +1 -0
  41. package/.next/server/app/_not-found/page/server-reference-manifest.json +4 -0
  42. package/.next/server/app/_not-found/page.js +13 -0
  43. package/.next/server/app/_not-found/page.js.map +5 -0
  44. package/.next/server/app/_not-found/page.js.nft.json +1 -0
  45. package/.next/server/app/_not-found/page_client-reference-manifest.js +3 -0
  46. package/.next/server/app/_not-found.html +1 -0
  47. package/.next/server/app/_not-found.meta +16 -0
  48. package/.next/server/app/_not-found.rsc +16 -0
  49. package/.next/server/app/_not-found.segments/_full.segment.rsc +16 -0
  50. package/.next/server/app/_not-found.segments/_head.segment.rsc +6 -0
  51. package/.next/server/app/_not-found.segments/_index.segment.rsc +5 -0
  52. package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +5 -0
  53. package/.next/server/app/_not-found.segments/_not-found.segment.rsc +5 -0
  54. package/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -0
  55. package/.next/server/app/api/context/aider/route/app-paths-manifest.json +3 -0
  56. package/.next/server/app/api/context/aider/route/build-manifest.json +9 -0
  57. package/.next/server/app/api/context/aider/route/server-reference-manifest.json +4 -0
  58. package/.next/server/app/api/context/aider/route.js +6 -0
  59. package/.next/server/app/api/context/aider/route.js.map +5 -0
  60. package/.next/server/app/api/context/aider/route.js.nft.json +1 -0
  61. package/.next/server/app/api/context/aider/route_client-reference-manifest.js +3 -0
  62. package/.next/server/app/api/context/claude/route/app-paths-manifest.json +3 -0
  63. package/.next/server/app/api/context/claude/route/build-manifest.json +9 -0
  64. package/.next/server/app/api/context/claude/route/server-reference-manifest.json +4 -0
  65. package/.next/server/app/api/context/claude/route.js +6 -0
  66. package/.next/server/app/api/context/claude/route.js.map +5 -0
  67. package/.next/server/app/api/context/claude/route.js.nft.json +1 -0
  68. package/.next/server/app/api/context/claude/route_client-reference-manifest.js +3 -0
  69. package/.next/server/app/api/context/route/app-paths-manifest.json +3 -0
  70. package/.next/server/app/api/context/route/build-manifest.json +9 -0
  71. package/.next/server/app/api/context/route/server-reference-manifest.json +4 -0
  72. package/.next/server/app/api/context/route.js +6 -0
  73. package/.next/server/app/api/context/route.js.map +5 -0
  74. package/.next/server/app/api/context/route.js.nft.json +1 -0
  75. package/.next/server/app/api/context/route_client-reference-manifest.js +3 -0
  76. package/.next/server/app/api/context/ssh/route/app-paths-manifest.json +3 -0
  77. package/.next/server/app/api/context/ssh/route/build-manifest.json +9 -0
  78. package/.next/server/app/api/context/ssh/route/server-reference-manifest.json +4 -0
  79. package/.next/server/app/api/context/ssh/route.js +6 -0
  80. package/.next/server/app/api/context/ssh/route.js.map +5 -0
  81. package/.next/server/app/api/context/ssh/route.js.nft.json +1 -0
  82. package/.next/server/app/api/context/ssh/route_client-reference-manifest.js +3 -0
  83. package/.next/server/app/api/files/route/app-paths-manifest.json +3 -0
  84. package/.next/server/app/api/files/route/build-manifest.json +9 -0
  85. package/.next/server/app/api/files/route/server-reference-manifest.json +4 -0
  86. package/.next/server/app/api/files/route.js +7 -0
  87. package/.next/server/app/api/files/route.js.map +5 -0
  88. package/.next/server/app/api/files/route.js.nft.json +1 -0
  89. package/.next/server/app/api/files/route_client-reference-manifest.js +3 -0
  90. package/.next/server/app/api/git/route/app-paths-manifest.json +3 -0
  91. package/.next/server/app/api/git/route/build-manifest.json +9 -0
  92. package/.next/server/app/api/git/route/server-reference-manifest.json +4 -0
  93. package/.next/server/app/api/git/route.js +6 -0
  94. package/.next/server/app/api/git/route.js.map +5 -0
  95. package/.next/server/app/api/git/route.js.nft.json +1 -0
  96. package/.next/server/app/api/git/route_client-reference-manifest.js +3 -0
  97. package/.next/server/app/api/sessions/inject/route/app-paths-manifest.json +3 -0
  98. package/.next/server/app/api/sessions/inject/route/build-manifest.json +9 -0
  99. package/.next/server/app/api/sessions/inject/route/server-reference-manifest.json +4 -0
  100. package/.next/server/app/api/sessions/inject/route.js +7 -0
  101. package/.next/server/app/api/sessions/inject/route.js.map +5 -0
  102. package/.next/server/app/api/sessions/inject/route.js.nft.json +1 -0
  103. package/.next/server/app/api/sessions/inject/route_client-reference-manifest.js +3 -0
  104. package/.next/server/app/api/sessions/input/route/app-paths-manifest.json +3 -0
  105. package/.next/server/app/api/sessions/input/route/build-manifest.json +9 -0
  106. package/.next/server/app/api/sessions/input/route/server-reference-manifest.json +4 -0
  107. package/.next/server/app/api/sessions/input/route.js +7 -0
  108. package/.next/server/app/api/sessions/input/route.js.map +5 -0
  109. package/.next/server/app/api/sessions/input/route.js.nft.json +1 -0
  110. package/.next/server/app/api/sessions/input/route_client-reference-manifest.js +3 -0
  111. package/.next/server/app/api/sessions/launch/route/app-paths-manifest.json +3 -0
  112. package/.next/server/app/api/sessions/launch/route/build-manifest.json +9 -0
  113. package/.next/server/app/api/sessions/launch/route/server-reference-manifest.json +4 -0
  114. package/.next/server/app/api/sessions/launch/route.js +7 -0
  115. package/.next/server/app/api/sessions/launch/route.js.map +5 -0
  116. package/.next/server/app/api/sessions/launch/route.js.nft.json +1 -0
  117. package/.next/server/app/api/sessions/launch/route_client-reference-manifest.js +3 -0
  118. package/.next/server/app/api/sessions/route/app-paths-manifest.json +3 -0
  119. package/.next/server/app/api/sessions/route/build-manifest.json +9 -0
  120. package/.next/server/app/api/sessions/route/server-reference-manifest.json +4 -0
  121. package/.next/server/app/api/sessions/route.js +7 -0
  122. package/.next/server/app/api/sessions/route.js.map +5 -0
  123. package/.next/server/app/api/sessions/route.js.nft.json +1 -0
  124. package/.next/server/app/api/sessions/route_client-reference-manifest.js +3 -0
  125. package/.next/server/app/api/sessions/stats/route/app-paths-manifest.json +3 -0
  126. package/.next/server/app/api/sessions/stats/route/build-manifest.json +9 -0
  127. package/.next/server/app/api/sessions/stats/route/server-reference-manifest.json +4 -0
  128. package/.next/server/app/api/sessions/stats/route.js +7 -0
  129. package/.next/server/app/api/sessions/stats/route.js.map +5 -0
  130. package/.next/server/app/api/sessions/stats/route.js.nft.json +1 -0
  131. package/.next/server/app/api/sessions/stats/route_client-reference-manifest.js +3 -0
  132. package/.next/server/app/api/sessions/stop/route/app-paths-manifest.json +3 -0
  133. package/.next/server/app/api/sessions/stop/route/build-manifest.json +9 -0
  134. package/.next/server/app/api/sessions/stop/route/server-reference-manifest.json +4 -0
  135. package/.next/server/app/api/sessions/stop/route.js +7 -0
  136. package/.next/server/app/api/sessions/stop/route.js.map +5 -0
  137. package/.next/server/app/api/sessions/stop/route.js.nft.json +1 -0
  138. package/.next/server/app/api/sessions/stop/route_client-reference-manifest.js +3 -0
  139. package/.next/server/app/favicon.ico/route/app-paths-manifest.json +3 -0
  140. package/.next/server/app/favicon.ico/route/build-manifest.json +9 -0
  141. package/.next/server/app/favicon.ico/route.js +7 -0
  142. package/.next/server/app/favicon.ico/route.js.map +5 -0
  143. package/.next/server/app/favicon.ico/route.js.nft.json +1 -0
  144. package/.next/server/app/favicon.ico.body +0 -0
  145. package/.next/server/app/favicon.ico.meta +1 -0
  146. package/.next/server/app/index.html +1 -0
  147. package/.next/server/app/index.meta +14 -0
  148. package/.next/server/app/index.rsc +21 -0
  149. package/.next/server/app/index.segments/__PAGE__.segment.rsc +10 -0
  150. package/.next/server/app/index.segments/_full.segment.rsc +21 -0
  151. package/.next/server/app/index.segments/_head.segment.rsc +6 -0
  152. package/.next/server/app/index.segments/_index.segment.rsc +5 -0
  153. package/.next/server/app/index.segments/_tree.segment.rsc +5 -0
  154. package/.next/server/app/page/app-paths-manifest.json +3 -0
  155. package/.next/server/app/page/build-manifest.json +16 -0
  156. package/.next/server/app/page/next-font-manifest.json +11 -0
  157. package/.next/server/app/page/react-loadable-manifest.json +42 -0
  158. package/.next/server/app/page/server-reference-manifest.json +4 -0
  159. package/.next/server/app/page.js +14 -0
  160. package/.next/server/app/page.js.map +5 -0
  161. package/.next/server/app/page.js.nft.json +1 -0
  162. package/.next/server/app/page_client-reference-manifest.js +3 -0
  163. package/.next/server/app-paths-manifest.json +18 -0
  164. package/.next/server/chunks/[externals]__0shxiss._.js +3 -0
  165. package/.next/server/chunks/[externals]__0shxiss._.js.map +1 -0
  166. package/.next/server/chunks/[externals]_next_dist_0arv.vj._.js +3 -0
  167. package/.next/server/chunks/[externals]_next_dist_0arv.vj._.js.map +1 -0
  168. package/.next/server/chunks/[externals]_node-pty_12c-8pf._.js +3 -0
  169. package/.next/server/chunks/[externals]_node-pty_12c-8pf._.js.map +1 -0
  170. package/.next/server/chunks/[root-of-the-server]__0-k9zyi._.js +15 -0
  171. package/.next/server/chunks/[root-of-the-server]__0-k9zyi._.js.map +1 -0
  172. package/.next/server/chunks/[root-of-the-server]__04kdofw._.js +15 -0
  173. package/.next/server/chunks/[root-of-the-server]__04kdofw._.js.map +1 -0
  174. package/.next/server/chunks/[root-of-the-server]__0c.5qbe._.js +15 -0
  175. package/.next/server/chunks/[root-of-the-server]__0c.5qbe._.js.map +1 -0
  176. package/.next/server/chunks/[root-of-the-server]__0d0pykb._.js +28 -0
  177. package/.next/server/chunks/[root-of-the-server]__0d0pykb._.js.map +1 -0
  178. package/.next/server/chunks/[root-of-the-server]__0e5cwnx._.js +3 -0
  179. package/.next/server/chunks/[root-of-the-server]__0e5cwnx._.js.map +1 -0
  180. package/.next/server/chunks/[root-of-the-server]__0efi5cr._.js +3 -0
  181. package/.next/server/chunks/[root-of-the-server]__0efi5cr._.js.map +1 -0
  182. package/.next/server/chunks/[root-of-the-server]__0j8-xkl._.js +13 -0
  183. package/.next/server/chunks/[root-of-the-server]__0j8-xkl._.js.map +1 -0
  184. package/.next/server/chunks/[root-of-the-server]__0k6w___._.js +15 -0
  185. package/.next/server/chunks/[root-of-the-server]__0k6w___._.js.map +1 -0
  186. package/.next/server/chunks/[root-of-the-server]__0l7c-gn._.js +3 -0
  187. package/.next/server/chunks/[root-of-the-server]__0l7c-gn._.js.map +1 -0
  188. package/.next/server/chunks/[root-of-the-server]__0l_q72g._.js +15 -0
  189. package/.next/server/chunks/[root-of-the-server]__0l_q72g._.js.map +1 -0
  190. package/.next/server/chunks/[root-of-the-server]__0m7-xfc._.js +15 -0
  191. package/.next/server/chunks/[root-of-the-server]__0m7-xfc._.js.map +1 -0
  192. package/.next/server/chunks/[root-of-the-server]__0m_~dan._.js +15 -0
  193. package/.next/server/chunks/[root-of-the-server]__0m_~dan._.js.map +1 -0
  194. package/.next/server/chunks/[root-of-the-server]__0ntt3om._.js +3 -0
  195. package/.next/server/chunks/[root-of-the-server]__0ntt3om._.js.map +1 -0
  196. package/.next/server/chunks/[turbopack]_runtime.js +903 -0
  197. package/.next/server/chunks/[turbopack]_runtime.js.map +11 -0
  198. package/.next/server/chunks/_next-internal_server_app_api_context_aider_route_actions_0dszia..js +3 -0
  199. package/.next/server/chunks/_next-internal_server_app_api_context_aider_route_actions_0dszia..js.map +1 -0
  200. package/.next/server/chunks/_next-internal_server_app_api_context_claude_route_actions_12srkdn.js +3 -0
  201. package/.next/server/chunks/_next-internal_server_app_api_context_claude_route_actions_12srkdn.js.map +1 -0
  202. package/.next/server/chunks/_next-internal_server_app_api_context_route_actions_03ko8ta.js +3 -0
  203. package/.next/server/chunks/_next-internal_server_app_api_context_route_actions_03ko8ta.js.map +1 -0
  204. package/.next/server/chunks/_next-internal_server_app_api_context_ssh_route_actions_0~0~96d.js +3 -0
  205. package/.next/server/chunks/_next-internal_server_app_api_context_ssh_route_actions_0~0~96d.js.map +1 -0
  206. package/.next/server/chunks/_next-internal_server_app_api_files_route_actions_0x8kqqx.js +3 -0
  207. package/.next/server/chunks/_next-internal_server_app_api_files_route_actions_0x8kqqx.js.map +1 -0
  208. package/.next/server/chunks/_next-internal_server_app_api_git_route_actions_0xetuf~.js +3 -0
  209. package/.next/server/chunks/_next-internal_server_app_api_git_route_actions_0xetuf~.js.map +1 -0
  210. package/.next/server/chunks/_next-internal_server_app_api_sessions_inject_route_actions_0y2_m1_.js +3 -0
  211. package/.next/server/chunks/_next-internal_server_app_api_sessions_inject_route_actions_0y2_m1_.js.map +1 -0
  212. package/.next/server/chunks/_next-internal_server_app_api_sessions_input_route_actions_032sdjp.js +3 -0
  213. package/.next/server/chunks/_next-internal_server_app_api_sessions_input_route_actions_032sdjp.js.map +1 -0
  214. package/.next/server/chunks/_next-internal_server_app_api_sessions_launch_route_actions_0_qrmsm.js +3 -0
  215. package/.next/server/chunks/_next-internal_server_app_api_sessions_launch_route_actions_0_qrmsm.js.map +1 -0
  216. package/.next/server/chunks/_next-internal_server_app_api_sessions_route_actions_0y1t9w0.js +3 -0
  217. package/.next/server/chunks/_next-internal_server_app_api_sessions_route_actions_0y1t9w0.js.map +1 -0
  218. package/.next/server/chunks/_next-internal_server_app_api_sessions_stats_route_actions_0gc_vw-.js +3 -0
  219. package/.next/server/chunks/_next-internal_server_app_api_sessions_stats_route_actions_0gc_vw-.js.map +1 -0
  220. package/.next/server/chunks/_next-internal_server_app_api_sessions_stop_route_actions_0xg1t9k.js +3 -0
  221. package/.next/server/chunks/_next-internal_server_app_api_sessions_stop_route_actions_0xg1t9k.js.map +1 -0
  222. package/.next/server/chunks/_next-internal_server_app_favicon_ico_route_actions_095lj93.js +3 -0
  223. package/.next/server/chunks/_next-internal_server_app_favicon_ico_route_actions_095lj93.js.map +1 -0
  224. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_0ev3h.z.js +3 -0
  225. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_0ev3h.z.js.map +1 -0
  226. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_0m.429v.js +3 -0
  227. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_0m.429v.js.map +1 -0
  228. package/.next/server/chunks/ssr/[root-of-the-server]__0.kd7dh._.js +33 -0
  229. package/.next/server/chunks/ssr/[root-of-the-server]__0.kd7dh._.js.map +1 -0
  230. package/.next/server/chunks/ssr/[root-of-the-server]__089dc4i._.js +33 -0
  231. package/.next/server/chunks/ssr/[root-of-the-server]__089dc4i._.js.map +1 -0
  232. package/.next/server/chunks/ssr/[root-of-the-server]__0_7i5h0._.js +3 -0
  233. package/.next/server/chunks/ssr/[root-of-the-server]__0_7i5h0._.js.map +1 -0
  234. package/.next/server/chunks/ssr/[root-of-the-server]__0hw~y-4._.js +3 -0
  235. package/.next/server/chunks/ssr/[root-of-the-server]__0hw~y-4._.js.map +1 -0
  236. package/.next/server/chunks/ssr/[root-of-the-server]__0uk0awy._.js +3 -0
  237. package/.next/server/chunks/ssr/[root-of-the-server]__0uk0awy._.js.map +1 -0
  238. package/.next/server/chunks/ssr/[root-of-the-server]__0v73tbn._.js +3 -0
  239. package/.next/server/chunks/ssr/[root-of-the-server]__0v73tbn._.js.map +1 -0
  240. package/.next/server/chunks/ssr/[root-of-the-server]__0~y8ue.._.js +3 -0
  241. package/.next/server/chunks/ssr/[root-of-the-server]__0~y8ue.._.js.map +1 -0
  242. package/.next/server/chunks/ssr/[turbopack]_runtime.js +903 -0
  243. package/.next/server/chunks/ssr/[turbopack]_runtime.js.map +11 -0
  244. package/.next/server/chunks/ssr/_0t7oqy6._.js +3 -0
  245. package/.next/server/chunks/ssr/_0t7oqy6._.js.map +1 -0
  246. package/.next/server/chunks/ssr/_next-internal_server_app__global-error_page_actions_0k77kol.js +3 -0
  247. package/.next/server/chunks/ssr/_next-internal_server_app__global-error_page_actions_0k77kol.js.map +1 -0
  248. package/.next/server/chunks/ssr/_next-internal_server_app__not-found_page_actions_0eq97pa.js +3 -0
  249. package/.next/server/chunks/ssr/_next-internal_server_app__not-found_page_actions_0eq97pa.js.map +1 -0
  250. package/.next/server/chunks/ssr/_next-internal_server_app_page_actions_09-gtaw.js +3 -0
  251. package/.next/server/chunks/ssr/_next-internal_server_app_page_actions_09-gtaw.js.map +1 -0
  252. package/.next/server/chunks/ssr/node_modules_05l396c._.js +3 -0
  253. package/.next/server/chunks/ssr/node_modules_05l396c._.js.map +1 -0
  254. package/.next/server/chunks/ssr/node_modules_09w7yel._.js +33 -0
  255. package/.next/server/chunks/ssr/node_modules_09w7yel._.js.map +1 -0
  256. package/.next/server/chunks/ssr/node_modules_@swc_helpers_cjs__interop_require_default_cjs_11~q6fv._.js +3 -0
  257. package/.next/server/chunks/ssr/node_modules_@swc_helpers_cjs__interop_require_default_cjs_11~q6fv._.js.map +1 -0
  258. package/.next/server/chunks/ssr/node_modules_next_dist_0ppctuh._.js +19 -0
  259. package/.next/server/chunks/ssr/node_modules_next_dist_0ppctuh._.js.map +1 -0
  260. package/.next/server/chunks/ssr/node_modules_next_dist_0qoh8ry._.js +6 -0
  261. package/.next/server/chunks/ssr/node_modules_next_dist_0qoh8ry._.js.map +1 -0
  262. package/.next/server/chunks/ssr/node_modules_next_dist_client_components_0inhx6q._.js +3 -0
  263. package/.next/server/chunks/ssr/node_modules_next_dist_client_components_0inhx6q._.js.map +1 -0
  264. package/.next/server/chunks/ssr/node_modules_next_dist_client_components_builtin_forbidden_0ghu-f7.js +3 -0
  265. package/.next/server/chunks/ssr/node_modules_next_dist_client_components_builtin_forbidden_0ghu-f7.js.map +1 -0
  266. package/.next/server/chunks/ssr/node_modules_next_dist_client_components_builtin_global-error_0lgvd_..js +3 -0
  267. package/.next/server/chunks/ssr/node_modules_next_dist_client_components_builtin_global-error_0lgvd_..js.map +1 -0
  268. package/.next/server/chunks/ssr/node_modules_next_dist_client_components_builtin_unauthorized_0cjv-23.js +3 -0
  269. package/.next/server/chunks/ssr/node_modules_next_dist_client_components_builtin_unauthorized_0cjv-23.js.map +1 -0
  270. package/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_03-z2qq.js +4 -0
  271. package/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_03-z2qq.js.map +1 -0
  272. package/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_07vh7rm.js +4 -0
  273. package/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_07vh7rm.js.map +1 -0
  274. package/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0qp4u6g.js +4 -0
  275. package/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0qp4u6g.js.map +1 -0
  276. package/.next/server/functions-config-manifest.json +4 -0
  277. package/.next/server/interception-route-rewrite-manifest.js +1 -0
  278. package/.next/server/middleware-build-manifest.js +20 -0
  279. package/.next/server/middleware-manifest.json +6 -0
  280. package/.next/server/next-font-manifest.js +1 -0
  281. package/.next/server/next-font-manifest.json +15 -0
  282. package/.next/server/pages/404.html +1 -0
  283. package/.next/server/pages/500.html +1 -0
  284. package/.next/server/pages-manifest.json +4 -0
  285. package/.next/server/prefetch-hints.json +1 -0
  286. package/.next/server/server-reference-manifest.js +1 -0
  287. package/.next/server/server-reference-manifest.json +5 -0
  288. package/.next/static/chunks/03g6xpslyid3~.js +1 -0
  289. package/.next/static/chunks/03~yq9q893hmn.js +1 -0
  290. package/.next/static/chunks/07b7-dl8gh17u.js +5 -0
  291. package/.next/static/chunks/07lhk_q6pmm3r.js +1 -0
  292. package/.next/static/chunks/0dbhjjzl8qfwv.js +1 -0
  293. package/.next/static/chunks/0ewdhgxsa_h.q.js +1 -0
  294. package/.next/static/chunks/0f4at4_v-tkgj.js +1 -0
  295. package/.next/static/chunks/0fpki3y6aj230.js +31 -0
  296. package/.next/static/chunks/0ga14ztvrhau2.css +1 -0
  297. package/.next/static/chunks/0lnobx4eh3~-_.js +1 -0
  298. package/.next/static/chunks/0mej.ad_ddvf1.js +1 -0
  299. package/.next/static/chunks/0q4suv6uexpud.css +1 -0
  300. package/.next/static/chunks/0xq6bhmghl02_.js +1 -0
  301. package/.next/static/chunks/139c54uo1w7.4.css +3 -0
  302. package/.next/static/chunks/140ovxvjat1ch.js +5 -0
  303. package/.next/static/chunks/16w4~t4h7gk13.js +1 -0
  304. package/.next/static/chunks/turbopack-08fpdsd.-ns2y.js +1 -0
  305. package/.next/static/media/4fa387ec64143e14-s.0wkzw~je483f-.woff2 +0 -0
  306. package/.next/static/media/53b9e256198e5412-s.0-wfv7uh4i7h9.woff2 +0 -0
  307. package/.next/static/media/5ce348bf30bf5439-s.0zgw-jeven.3w.woff2 +0 -0
  308. package/.next/static/media/6306c77e7c8268e4-s.0rhz0arwfsn~5.woff2 +0 -0
  309. package/.next/static/media/7178b3e590c64307-s.0nx0ww8fni_q3.woff2 +0 -0
  310. package/.next/static/media/797e433ab948586e-s.p.08e28id.o-okb.woff2 +0 -0
  311. package/.next/static/media/7d817b4c03b0c5f1-s.0l76wvqk9d84w.woff2 +0 -0
  312. package/.next/static/media/8a480f0b521d4e75-s.0jzbimsg8vl84.woff2 +0 -0
  313. package/.next/static/media/bbc41e54d2fcbd21-s.0k4k9394f2q-k.woff2 +0 -0
  314. package/.next/static/media/caa3a2e1cccd8315-s.p.09~u27dqhyhd6.woff2 +0 -0
  315. package/.next/static/media/favicon.0x3dzn~oxb6tn.ico +0 -0
  316. package/.next/static/media/fef07dbb0973bf53-s.12tyk43_3sh9u.woff2 +0 -0
  317. package/.next/static/r-T5V6BKLiZ32Ai9Boe1d/_buildManifest.js +11 -0
  318. package/.next/static/r-T5V6BKLiZ32Ai9Boe1d/_clientMiddlewareManifest.js +1 -0
  319. package/.next/static/r-T5V6BKLiZ32Ai9Boe1d/_ssgManifest.js +1 -0
  320. package/.next/trace +1 -0
  321. package/.next/trace-build +1 -0
  322. package/.next/turbopack +0 -0
  323. package/.next/types/cache-life.d.ts +145 -0
  324. package/.next/types/routes.d.ts +84 -0
  325. package/.next/types/validator.ts +178 -0
  326. package/README.md +125 -0
  327. package/bin/cli.js +36 -0
  328. package/next.config.ts +7 -0
  329. package/package.json +40 -0
  330. package/public/file.svg +1 -0
  331. package/public/globe.svg +1 -0
  332. package/public/next.svg +1 -0
  333. package/public/vercel.svg +1 -0
  334. package/public/window.svg +1 -0
  335. package/src/app/api/context/aider/route.ts +113 -0
  336. package/src/app/api/context/claude/route.ts +64 -0
  337. package/src/app/api/context/route.ts +37 -0
  338. package/src/app/api/context/ssh/route.ts +88 -0
  339. package/src/app/api/files/route.ts +276 -0
  340. package/src/app/api/git/route.ts +81 -0
  341. package/src/app/api/sessions/inject/route.ts +21 -0
  342. package/src/app/api/sessions/input/route.ts +30 -0
  343. package/src/app/api/sessions/launch/route.ts +25 -0
  344. package/src/app/api/sessions/route.ts +27 -0
  345. package/src/app/api/sessions/stats/route.ts +76 -0
  346. package/src/app/api/sessions/stop/route.ts +26 -0
  347. package/src/app/components/AiderWizard.tsx +412 -0
  348. package/src/app/components/ClaudeWizard.tsx +335 -0
  349. package/src/app/components/ContextEditor.tsx +169 -0
  350. package/src/app/components/IdeLayout.tsx +2095 -0
  351. package/src/app/components/SshWizard.tsx +379 -0
  352. package/src/app/components/TerminalConsole.tsx +228 -0
  353. package/src/app/favicon.ico +0 -0
  354. package/src/app/globals.css +81 -0
  355. package/src/app/layout.tsx +30 -0
  356. package/src/app/page.module.css +330 -0
  357. package/src/app/page.tsx +581 -0
  358. package/src/lib/agents/AgentRunner.ts +86 -0
  359. package/src/lib/agents/AiderRunner.ts +261 -0
  360. package/src/lib/agents/ClaudeRunner.ts +148 -0
  361. package/src/lib/agents/ContextManager.ts +142 -0
  362. package/src/lib/agents/DockerRunner.ts +182 -0
  363. package/src/lib/agents/MockRunner.ts +126 -0
  364. package/src/lib/agents/SSHRunner.ts +180 -0
  365. package/src/lib/agents/SessionManager.ts +147 -0
  366. package/src/lib/agents/SessionPersister.ts +85 -0
  367. package/src/lib/agents/WebSocketServer.ts +118 -0
  368. package/tsconfig.json +34 -0
@@ -0,0 +1,581 @@
1
+ "use client";
2
+
3
+ import { useEffect, useState } from "react";
4
+ import dynamic from "next/dynamic";
5
+ import styles from "./page.module.css";
6
+
7
+ interface RunnerStatus {
8
+ id: string;
9
+ name: string;
10
+ type: 'mock' | 'claude' | 'claude-docker' | 'claude-ssh' | 'aider' | 'aider-docker';
11
+ status: 'idle' | 'running' | 'stopped';
12
+ createdAt: string;
13
+ logsCount: number;
14
+ workspaceRoot?: string;
15
+ scopedDirs?: string[];
16
+ }
17
+
18
+ // Dynamically import TerminalConsole to bypass SSR errors
19
+ const TerminalConsole = dynamic(() => import("./components/TerminalConsole"), {
20
+ ssr: false,
21
+ loading: () => (
22
+ <div
23
+ style={{
24
+ height: "400px",
25
+ display: "flex",
26
+ alignItems: "center",
27
+ justifyContent: "center",
28
+ backgroundColor: "#05070a",
29
+ color: "var(--muted)",
30
+ border: "1px solid var(--border)",
31
+ borderBottomLeftRadius: "12px",
32
+ borderBottomRightRadius: "12px"
33
+ }}
34
+ >
35
+ <span>Initializing terminal emulator...</span>
36
+ </div>
37
+ ),
38
+ });
39
+
40
+ // Dynamically import ContextEditor to bypass SSR errors
41
+ const ContextEditor = dynamic(() => import("./components/ContextEditor"), {
42
+ ssr: false,
43
+ loading: () => (
44
+ <div
45
+ style={{
46
+ height: "280px",
47
+ display: "flex",
48
+ alignItems: "center",
49
+ justifyContent: "center",
50
+ backgroundColor: "var(--card)",
51
+ border: "1px solid var(--border)",
52
+ borderRadius: "12px",
53
+ marginTop: "1.5rem"
54
+ }}
55
+ >
56
+ <span style={{ color: "var(--muted)" }}>Initializing prompt editor...</span>
57
+ </div>
58
+ ),
59
+ });
60
+
61
+ // Dynamically import SshWizard to bypass SSR errors
62
+ const SshWizard = dynamic(() => import("./components/SshWizard"), {
63
+ ssr: false,
64
+ });
65
+
66
+ // Dynamically import AiderWizard to bypass SSR errors
67
+ const AiderWizard = dynamic(() => import("./components/AiderWizard"), {
68
+ ssr: false,
69
+ });
70
+
71
+ // Dynamically import ClaudeWizard to bypass SSR errors
72
+ const ClaudeWizard = dynamic(() => import("./components/ClaudeWizard"), {
73
+ ssr: false,
74
+ });
75
+
76
+ // Dynamically import IdeLayout to bypass SSR errors
77
+ const IdeLayout = dynamic(() => import("./components/IdeLayout"), {
78
+ ssr: false,
79
+ });
80
+
81
+ export default function Home() {
82
+ const [sessions, setSessions] = useState<RunnerStatus[]>([]);
83
+ const [activeSessionId, setActiveSessionId] = useState<string | null>(null);
84
+ const [isLoading, setIsLoading] = useState<boolean>(false);
85
+ const [isSshWizardOpen, setIsSshWizardOpen] = useState<boolean>(false);
86
+ const [isAiderWizardOpen, setIsAiderWizardOpen] = useState<boolean>(false);
87
+ const [isAiderDockerLaunch, setIsAiderDockerLaunch] = useState<boolean>(false);
88
+ const [isClaudeWizardOpen, setIsClaudeWizardOpen] = useState<boolean>(false);
89
+ const [isClaudeDockerLaunch, setIsClaudeDockerLaunch] = useState<boolean>(false);
90
+
91
+ const activeSession = sessions.find(s => s.id === activeSessionId);
92
+ const isDockerActive = sessions.some(s => (s.type === 'claude-docker' || s.type === 'aider-docker') && s.status === 'running');
93
+ const isSshActive = sessions.some(s => s.type === 'claude-ssh' && s.status === 'running');
94
+
95
+ // Fetch all sessions on mount & periodically
96
+ const fetchSessions = async () => {
97
+ try {
98
+ const res = await fetch("/api/sessions");
99
+ const data = await res.json();
100
+ if (data.sessions) {
101
+ setSessions(data.sessions);
102
+ }
103
+ } catch (err) {
104
+ console.error("Failed to fetch sessions:", err);
105
+ }
106
+ };
107
+
108
+ useEffect(() => {
109
+ const initFetch = async () => {
110
+ await fetchSessions();
111
+ };
112
+ initFetch();
113
+ const interval = setInterval(fetchSessions, 4000);
114
+ return () => clearInterval(interval);
115
+ }, []);
116
+
117
+ // Launch a new Session
118
+ const handleLaunchSession = async (
119
+ type: 'mock' | 'claude' | 'claude-docker' | 'claude-ssh' | 'aider' | 'aider-docker',
120
+ customName?: string,
121
+ customWorkspaceRoot?: string,
122
+ customScopedDirs?: string[]
123
+ ) => {
124
+ setIsLoading(true);
125
+ try {
126
+ let sessionName = customName;
127
+ if (!sessionName) {
128
+ if (type === 'claude') sessionName = "Claude Local";
129
+ else if (type === 'claude-docker') sessionName = "Claude Docker";
130
+ else if (type === 'claude-ssh') sessionName = "Claude SSH";
131
+ else if (type === 'aider') sessionName = "Aider Local";
132
+ else if (type === 'aider-docker') sessionName = "Aider Docker";
133
+ else if (type === 'mock') sessionName = "Mock Session";
134
+ }
135
+
136
+ const launchBody: {
137
+ type: string;
138
+ name?: string;
139
+ workspaceRoot?: string;
140
+ scopedDirs?: string[];
141
+ } = {
142
+ type,
143
+ name: sessionName,
144
+ workspaceRoot: customWorkspaceRoot,
145
+ scopedDirs: customScopedDirs
146
+ };
147
+
148
+ if ((type === 'aider' || type === 'aider-docker') && !customWorkspaceRoot) {
149
+ try {
150
+ const configRes = await fetch("/api/context/aider");
151
+ if (configRes.ok) {
152
+ const configData = await configRes.json();
153
+ if (configData.success && configData.config) {
154
+ launchBody.workspaceRoot = configData.config.workspaceRoot;
155
+ launchBody.scopedDirs = configData.config.scopedDirs;
156
+ }
157
+ }
158
+ } catch (err) {
159
+ console.error("Failed to load aider configuration before launch:", err);
160
+ }
161
+ }
162
+
163
+ const res = await fetch("/api/sessions/launch", {
164
+ method: "POST",
165
+ headers: { "Content-Type": "application/json" },
166
+ body: JSON.stringify(launchBody)
167
+ });
168
+ const data = await res.json();
169
+ if (data.success) {
170
+ await fetchSessions();
171
+ setActiveSessionId(data.session.id);
172
+ }
173
+ } catch (err) {
174
+ console.error("Failed to launch session:", err);
175
+ } finally {
176
+ setIsLoading(false);
177
+ }
178
+ };
179
+
180
+ // Stop/Disconnect Session
181
+ const handleStopSession = async (id: string, deletePermanently = false) => {
182
+ try {
183
+ const res = await fetch("/api/sessions/stop", {
184
+ method: "POST",
185
+ headers: { "Content-Type": "application/json" },
186
+ body: JSON.stringify({ id, delete: deletePermanently })
187
+ });
188
+ const data = await res.json();
189
+ if (data.success) {
190
+ if (deletePermanently && activeSessionId === id) {
191
+ setActiveSessionId(null);
192
+ }
193
+ await fetchSessions();
194
+ }
195
+ } catch (err) {
196
+ console.error("Failed to stop session:", err);
197
+ }
198
+ };
199
+
200
+ return (
201
+ <div className={styles.container}>
202
+ {/* Header */}
203
+ <header className={styles.header}>
204
+ <div className={styles.logoArea}>
205
+ <h1 className={styles.title}>NeuralLoom</h1>
206
+ <span className={styles.subtitle}>Unified AI Orchestrator & Context Bridge</span>
207
+ </div>
208
+ <div className={styles.statusIndicator}>
209
+ <span className={styles.pulseDot}></span>
210
+ <span>Orchestrator Online</span>
211
+ </div>
212
+ </header>
213
+
214
+ {/* Main Dashboard Grid or Active Session IDE */}
215
+ {activeSession ? (
216
+ <div style={{ padding: "0 2rem", marginBottom: "2rem" }}>
217
+ <IdeLayout
218
+ sessionId={activeSession.id}
219
+ workspaceRoot={activeSession.workspaceRoot || ""}
220
+ scopedDirs={activeSession.scopedDirs || []}
221
+ onClose={() => setActiveSessionId(null)}
222
+ sessions={sessions}
223
+ onSwitchSession={(id) => setActiveSessionId(id)}
224
+ />
225
+ </div>
226
+ ) : (
227
+ <div className={styles.dashboardGrid}>
228
+
229
+ {/* Left Panel: Active Agents & Interactive Terminal */}
230
+ <main className={styles.mainPanel}>
231
+ <section>
232
+ <h2 className={styles.sectionTitle}>Active AI Agents</h2>
233
+
234
+ {sessions.length === 0 ? (
235
+ <div className="card" style={{ padding: "3rem 1.5rem", textAlign: "center" }}>
236
+ <p style={{ color: "var(--muted)", marginBottom: "1.5rem" }}>
237
+ No active agent sessions in this workspace. Launch a simulated session to verify the control bridge.
238
+ </p>
239
+ <button
240
+ className={styles.quickLaunchBtn}
241
+ onClick={() => handleLaunchSession('mock')}
242
+ disabled={isLoading}
243
+ style={{ maxWidth: "240px", margin: "0 auto" }}
244
+ >
245
+ {isLoading ? "Launching..." : "⚡ Launch Simulated Session"}
246
+ </button>
247
+ </div>
248
+ ) : (
249
+ <div className={styles.agentGrid}>
250
+ {sessions.map(session => (
251
+ <div key={session.id} className={`${styles.agentCard} card ${activeSessionId === session.id ? styles.activeBorder : ""}`}>
252
+ <div className={styles.agentHeader}>
253
+ <span className={styles.agentName}>{session.name}</span>
254
+ <span className={`${styles.agentBadge} ${session.status === 'stopped' ? styles.stoppedBadge : ""}`}>
255
+ {session.status}
256
+ </span>
257
+ </div>
258
+ <div className={styles.cardBody}>
259
+ <p style={{ fontSize: "0.825rem", color: "var(--muted)" }}>
260
+ ID: <code style={{ fontSize: "0.75rem" }}>{session.id.substring(0, 8)}</code><br />
261
+ Type: {
262
+ session.type === 'claude' ? "Claude Local PTY" :
263
+ session.type === 'claude-docker' ? "Claude Docker PTY" :
264
+ session.type === 'claude-ssh' ? "Claude SSH PTY" :
265
+ session.type === 'aider' ? "Aider Local PTY" :
266
+ session.type === 'aider-docker' ? "Aider Docker PTY" :
267
+ session.type === 'mock' ? "Simulated Mock PTY" : "Unknown PTY"
268
+ }<br />
269
+ Logs: {session.logsCount} captured lines
270
+ </p>
271
+
272
+ <div style={{ display: "flex", gap: "0.5rem", marginTop: "1rem" }}>
273
+ {session.status === 'running' ? (
274
+ <button
275
+ onClick={() => handleStopSession(session.id, false)}
276
+ style={{
277
+ flex: 1,
278
+ padding: "0.4rem 0.6rem",
279
+ borderRadius: "6px",
280
+ border: "1px solid var(--danger)",
281
+ backgroundColor: "transparent",
282
+ fontSize: "0.75rem",
283
+ fontWeight: 600,
284
+ color: "var(--danger)"
285
+ }}
286
+ >Stop</button>
287
+ ) : (
288
+ <button
289
+ onClick={() => handleStopSession(session.id, true)}
290
+ style={{
291
+ flex: 1,
292
+ padding: "0.4rem 0.6rem",
293
+ borderRadius: "6px",
294
+ border: "1px solid var(--border)",
295
+ backgroundColor: "transparent",
296
+ fontSize: "0.75rem",
297
+ fontWeight: 600,
298
+ color: "var(--muted)"
299
+ }}
300
+ >Delete</button>
301
+ )}
302
+ <button
303
+ onClick={() => setActiveSessionId(session.id)}
304
+ style={{
305
+ flex: 2,
306
+ padding: "0.4rem 0.6rem",
307
+ borderRadius: "6px",
308
+ border: "none",
309
+ backgroundColor: activeSessionId === session.id ? "var(--border-focus)" : "var(--primary)",
310
+ fontSize: "0.75rem",
311
+ fontWeight: 600,
312
+ color: "#fff"
313
+ }}
314
+ >
315
+ {activeSessionId === session.id ? "Connected" : "Open Session"}
316
+ </button>
317
+ </div>
318
+ </div>
319
+ </div>
320
+ ))}
321
+ </div>
322
+ )}
323
+ </section>
324
+
325
+ {/* Interactive Session Terminal Display */}
326
+ {activeSessionId && (
327
+ <section className="card" style={{ display: "flex", flexDirection: "column", border: "1px solid var(--border-focus)" }}>
328
+ <div className={styles.agentHeader} style={{ justifyContent: "space-between", background: "rgba(109, 40, 217, 0.08)" }}>
329
+ <span style={{ fontWeight: 600, display: "flex", alignItems: "center", gap: "0.5rem" }}>
330
+ 🖥️ Console Bridge — {sessions.find(s => s.id === activeSessionId)?.name}
331
+ </span>
332
+ <button
333
+ onClick={() => setActiveSessionId(null)}
334
+ style={{
335
+ border: "none",
336
+ background: "none",
337
+ color: "var(--muted)",
338
+ cursor: "pointer",
339
+ fontSize: "0.75rem"
340
+ }}
341
+ >Close Panel ✖</button>
342
+ </div>
343
+ <TerminalConsole sessionId={activeSessionId} />
344
+ </section>
345
+ )}
346
+
347
+ {/* Context Hub Staging section */}
348
+ <section>
349
+ <h2 className={styles.sectionTitle}>Shared Context Hub & Slash Commands</h2>
350
+ <div className={styles.contextList}>
351
+ <div className={`${styles.contextItem} card`}>
352
+ <div className={styles.contextMeta}>
353
+ <span className={styles.contextTitle}>Staged Context & System Rules (/ccc)</span>
354
+ <span className={styles.contextDetails}>Compiles AGENTS.md guidelines and project files folder hierarchy map.</span>
355
+ </div>
356
+ <button
357
+ onClick={async () => {
358
+ if (!activeSessionId) return;
359
+ await fetch("/api/sessions/inject", {
360
+ method: "POST",
361
+ headers: { "Content-Type": "application/json" },
362
+ body: JSON.stringify({ id: activeSessionId, command: "/ccc" })
363
+ });
364
+ }}
365
+ disabled={!activeSessionId}
366
+ style={{
367
+ padding: "0.4rem 0.8rem",
368
+ borderRadius: "6px",
369
+ border: "1px solid var(--primary)",
370
+ backgroundColor: "transparent",
371
+ color: "var(--primary)",
372
+ fontSize: "0.75rem",
373
+ fontWeight: 600,
374
+ opacity: activeSessionId ? 1 : 0.5,
375
+ cursor: activeSessionId ? "pointer" : "not-allowed"
376
+ }}
377
+ >
378
+ 🚀 Mount Context (/ccc)
379
+ </button>
380
+ </div>
381
+
382
+ <div className={`${styles.contextItem} card`}>
383
+ <div className={styles.contextMeta}>
384
+ <span className={styles.contextTitle}>Staged Developer Prompt (/ccp)</span>
385
+ <span className={styles.contextDetails}>Executes instructions written in .ai/neural-loom/cprompt.md.</span>
386
+ </div>
387
+ <button
388
+ onClick={async () => {
389
+ if (!activeSessionId) return;
390
+ await fetch("/api/sessions/inject", {
391
+ method: "POST",
392
+ headers: { "Content-Type": "application/json" },
393
+ body: JSON.stringify({ id: activeSessionId, command: "/ccp" })
394
+ });
395
+ }}
396
+ disabled={!activeSessionId}
397
+ style={{
398
+ padding: "0.4rem 0.8rem",
399
+ borderRadius: "6px",
400
+ border: "1px solid var(--success)",
401
+ backgroundColor: "transparent",
402
+ color: "var(--success)",
403
+ fontSize: "0.75rem",
404
+ fontWeight: 600,
405
+ opacity: activeSessionId ? 1 : 0.5,
406
+ cursor: activeSessionId ? "pointer" : "not-allowed"
407
+ }}
408
+ >
409
+ ⚡ Trigger Prompt (/ccp)
410
+ </button>
411
+ </div>
412
+ </div>
413
+ <ContextEditor />
414
+ </section>
415
+ </main>
416
+
417
+ {/* Right Panel: Environments & Actions */}
418
+ <aside className={styles.sidePanel}>
419
+ <section>
420
+ <h2 className={styles.sectionTitle}>Execution Environments</h2>
421
+ <div className={styles.envGrid}>
422
+ <div className={styles.envRow}>
423
+ <span className={styles.envName}>💻 Local host OS</span>
424
+ <span className={styles.envStatus} style={{ color: "var(--success)" }}>Active</span>
425
+ </div>
426
+ <div className={styles.envRow} style={{ opacity: isDockerActive ? 1 : 0.6 }}>
427
+ <span className={styles.envName}>🐳 Docker Sandbox</span>
428
+ <span className={styles.envStatus} style={{ color: isDockerActive ? "var(--success)" : "var(--muted)" }}>
429
+ {isDockerActive ? "Active" : "Not Mounted"}
430
+ </span>
431
+ </div>
432
+ <div className={styles.envRow} style={{ opacity: isSshActive ? 1 : 0.6 }}>
433
+ <span className={styles.envName}>🌐 Remote VM (SSH)</span>
434
+ <span className={styles.envStatus} style={{ color: isSshActive ? "var(--success)" : "var(--muted)" }}>
435
+ {isSshActive ? "Active" : "Disconnected"}
436
+ </span>
437
+ </div>
438
+ </div>
439
+ </section>
440
+
441
+ <section style={{ display: "flex", flexDirection: "column", gap: "0.75rem" }}>
442
+ <button className={styles.quickLaunchBtn} onClick={() => handleLaunchSession('mock')} disabled={isLoading}>
443
+ <span>⚡</span>
444
+ <span>Launch Mock Agent</span>
445
+ </button>
446
+ <button
447
+ className={styles.quickLaunchBtn}
448
+ onClick={() => {
449
+ setIsClaudeDockerLaunch(false);
450
+ setIsClaudeWizardOpen(true);
451
+ }}
452
+ disabled={isLoading}
453
+ style={{
454
+ background: "linear-gradient(135deg, hsl(262, 83%, 60%) 0%, hsl(195, 100%, 45%) 100%)",
455
+ border: "none"
456
+ }}
457
+ >
458
+ <span>🤖</span>
459
+ <span>Launch Claude PTY</span>
460
+ </button>
461
+ <button
462
+ className={styles.quickLaunchBtn}
463
+ onClick={() => {
464
+ setIsClaudeDockerLaunch(true);
465
+ setIsClaudeWizardOpen(true);
466
+ }}
467
+ disabled={isLoading}
468
+ style={{
469
+ background: "linear-gradient(135deg, hsl(170, 72%, 40%) 0%, hsl(195, 100%, 40%) 100%)",
470
+ border: "none"
471
+ }}
472
+ >
473
+ <span>🐳</span>
474
+ <span>Launch Docker PTY</span>
475
+ </button>
476
+ <button
477
+ className={styles.quickLaunchBtn}
478
+ onClick={() => setIsSshWizardOpen(true)}
479
+ disabled={isLoading}
480
+ style={{
481
+ background: "linear-gradient(135deg, hsl(38, 92%, 50%) 0%, hsl(0, 84%, 60%) 100%)",
482
+ border: "none"
483
+ }}
484
+ >
485
+ <span>🌐</span>
486
+ <span>Launch SSH PTY</span>
487
+ </button>
488
+ <button
489
+ className={styles.quickLaunchBtn}
490
+ onClick={() => {
491
+ setIsAiderDockerLaunch(false);
492
+ setIsAiderWizardOpen(true);
493
+ }}
494
+ disabled={isLoading}
495
+ style={{
496
+ background: "linear-gradient(135deg, hsl(210, 80%, 45%) 0%, hsl(262, 80%, 55%) 100%)",
497
+ border: "none"
498
+ }}
499
+ >
500
+ <span>🐍</span>
501
+ <span>Launch Aider PTY</span>
502
+ </button>
503
+ <button
504
+ className={styles.quickLaunchBtn}
505
+ onClick={() => {
506
+ setIsAiderDockerLaunch(true);
507
+ setIsAiderWizardOpen(true);
508
+ }}
509
+ disabled={isLoading}
510
+ style={{
511
+ background: "linear-gradient(135deg, hsl(195, 100%, 40%) 0%, hsl(262, 80%, 55%) 100%)",
512
+ border: "none"
513
+ }}
514
+ >
515
+ <span>🐳</span>
516
+ <span>Launch Aider Docker</span>
517
+ </button>
518
+ </section>
519
+
520
+ <section className="card" style={{ padding: "1.5rem", display: "flex", flexDirection: "column", gap: "0.75rem" }}>
521
+ <h3 style={{ fontSize: "1rem", fontWeight: 700 }}>Quick Actions</h3>
522
+ <ul style={{ listStyle: "none", fontSize: "0.875rem", display: "flex", flexDirection: "column", gap: "0.5rem", color: "var(--muted)" }}>
523
+ <li style={{ display: "flex", justifyContent: "space-between" }}>
524
+ <span>Configure global API Keys</span>
525
+ <span style={{ color: "var(--primary)", cursor: "pointer" }}>→</span>
526
+ </li>
527
+ <li style={{ display: "flex", justifyContent: "space-between" }}>
528
+ <span>Edit rules templates</span>
529
+ <span style={{ color: "var(--primary)", cursor: "pointer" }}>→</span>
530
+ </li>
531
+ <li style={{ display: "flex", justifyContent: "space-between" }}>
532
+ <span>Inspect process locks</span>
533
+ <span style={{ color: "var(--primary)", cursor: "pointer" }}>→</span>
534
+ </li>
535
+ </ul>
536
+ </section>
537
+ </aside>
538
+
539
+ </div>
540
+ )}
541
+
542
+ {/* Footer */}
543
+ <footer className={styles.footer}>
544
+ <span>NeuralLoom v0.1.0 — Experimental AI Orchestrator Bridge</span>
545
+ <span>Directory: C:\Users\Dave\OneDrive\Projects\JS\neural-loom</span>
546
+ </footer>
547
+
548
+ {isSshWizardOpen && (
549
+ <SshWizard
550
+ onClose={() => setIsSshWizardOpen(false)}
551
+ onConfirmLaunch={() => {
552
+ setIsSshWizardOpen(false);
553
+ handleLaunchSession('claude-ssh');
554
+ }}
555
+ />
556
+ )}
557
+
558
+ {isAiderWizardOpen && (
559
+ <AiderWizard
560
+ onClose={() => setIsAiderWizardOpen(false)}
561
+ isDocker={isAiderDockerLaunch}
562
+ onConfirmLaunch={() => {
563
+ setIsAiderWizardOpen(false);
564
+ handleLaunchSession(isAiderDockerLaunch ? 'aider-docker' : 'aider');
565
+ }}
566
+ />
567
+ )}
568
+
569
+ {isClaudeWizardOpen && (
570
+ <ClaudeWizard
571
+ onClose={() => setIsClaudeWizardOpen(false)}
572
+ isDocker={isClaudeDockerLaunch}
573
+ onConfirmLaunch={(name, workspaceRoot, scopedDirs) => {
574
+ setIsClaudeWizardOpen(false);
575
+ handleLaunchSession(isClaudeDockerLaunch ? 'claude-docker' : 'claude', name, workspaceRoot, scopedDirs);
576
+ }}
577
+ />
578
+ )}
579
+ </div>
580
+ );
581
+ }
@@ -0,0 +1,86 @@
1
+ export interface RunnerStatus {
2
+ id: string;
3
+ name: string;
4
+ type: 'mock' | 'claude' | 'claude-docker' | 'claude-ssh' | 'aider' | 'aider-docker';
5
+ status: 'idle' | 'running' | 'stopped';
6
+ createdAt: string;
7
+ logsCount: number;
8
+ workspaceRoot?: string;
9
+ scopedDirs?: string[];
10
+ tokenUsage?: { input: number; output: number; cost: number };
11
+ }
12
+
13
+ export abstract class AgentRunner {
14
+ abstract id: string;
15
+ abstract name: string;
16
+ abstract type: 'mock' | 'claude' | 'claude-docker' | 'claude-ssh' | 'aider' | 'aider-docker';
17
+ abstract status: 'idle' | 'running' | 'stopped';
18
+ abstract createdAt: string;
19
+ abstract logs: string[];
20
+ workspaceRoot?: string;
21
+ scopedDirs?: string[];
22
+ tokenUsage: { input: number; output: number; cost: number } = { input: 0, output: 0, cost: 0 };
23
+
24
+ protected parseTokenUsage(data: string): void {
25
+ const cleanData = data.replace(/\x1b\[[0-9;]*m/g, ""); // Strip ANSI colors
26
+
27
+ // Regex for cost
28
+ const costMatch = cleanData.match(/(?:cost|estimated cost)[:\s]*\$([0-9.]+)/i);
29
+ if (costMatch) {
30
+ this.tokenUsage.cost = parseFloat(costMatch[1]);
31
+ }
32
+
33
+ const parseNum = (str: string): number => {
34
+ str = str.replace(/,/g, '').toLowerCase().trim();
35
+ if (str.endsWith('k')) {
36
+ return parseFloat(str.slice(0, -1)) * 1000;
37
+ }
38
+ if (str.endsWith('m')) {
39
+ return parseFloat(str.slice(0, -1)) * 1000000;
40
+ }
41
+ return parseInt(str, 10) || 0;
42
+ };
43
+
44
+ // Tokens pattern: "Tokens: 1,500 sent, 300 received" or "1.5k sent, 0.3k received"
45
+ const tokensPattern1 = /tokens?[:\s]*([0-9,.]+[km]?)\s*(?:sent|input|prompt)[^a-zA-Z0-9]+([0-9,.]+[km]?)\s*(?:received|output|completion)/i;
46
+ const match1 = cleanData.match(tokensPattern1);
47
+ if (match1) {
48
+ this.tokenUsage.input = parseNum(match1[1]);
49
+ this.tokenUsage.output = parseNum(match1[2]);
50
+ } else {
51
+ // Try separate matches
52
+ const inputMatch = cleanData.match(/([0-9,.]+[km]?)\s*(?:sent|input|prompt)\s*tokens?/i) || cleanData.match(/tokens?\s*(?:sent|input|prompt)[:\s]*([0-9,.]+[km]?)/i);
53
+ if (inputMatch) {
54
+ this.tokenUsage.input = parseNum(inputMatch[1]);
55
+ }
56
+ const outputMatch = cleanData.match(/([0-9,.]+[km]?)\s*(?:received|output|completion)\s*tokens?/i) || cleanData.match(/tokens?\s*(?:received|output|completion)[:\s]*([0-9,.]+[km]?)/i);
57
+ if (outputMatch) {
58
+ this.tokenUsage.output = parseNum(outputMatch[1]);
59
+ }
60
+ }
61
+
62
+ // Fallback cost estimation if input/output is updated but cost is 0/unmatched
63
+ if (this.tokenUsage.cost === 0 && (this.tokenUsage.input > 0 || this.tokenUsage.output > 0)) {
64
+ this.tokenUsage.cost = (this.tokenUsage.input * 0.000003) + (this.tokenUsage.output * 0.000015);
65
+ }
66
+ }
67
+
68
+ abstract start(): Promise<void>;
69
+ abstract stop(): Promise<void>;
70
+ abstract sendInput(text: string, isRaw?: boolean): Promise<void>;
71
+ abstract getStatus(): RunnerStatus;
72
+
73
+ protected listeners: ((data: string) => void)[] = [];
74
+
75
+ public onOutput(callback: (data: string) => void): void {
76
+ this.listeners.push(callback);
77
+ }
78
+
79
+ public offOutput(callback: (data: string) => void): void {
80
+ this.listeners = this.listeners.filter(cb => cb !== callback);
81
+ }
82
+
83
+ protected emitOutput(data: string): void {
84
+ this.listeners.forEach(cb => cb(data));
85
+ }
86
+ }