neural-loom 0.2.6 → 0.2.8
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.
- package/.next/BUILD_ID +1 -1
- package/.next/build-manifest.json +3 -3
- package/.next/cache/.previewinfo +1 -1
- package/.next/cache/.rscinfo +1 -1
- package/.next/cache/.tsbuildinfo +1 -1
- package/.next/diagnostics/route-bundle-stats.json +1 -1
- package/.next/fallback-build-manifest.json +3 -3
- package/.next/prerender-manifest.json +3 -3
- package/.next/server/app/_global-error.html +1 -1
- package/.next/server/app/_global-error.rsc +1 -1
- package/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/_not-found.html +1 -1
- package/.next/server/app/_not-found.rsc +1 -1
- package/.next/server/app/_not-found.segments/_full.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_index.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
- package/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/index.html +1 -1
- package/.next/server/app/index.rsc +2 -2
- package/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
- package/.next/server/app/index.segments/_full.segment.rsc +2 -2
- package/.next/server/app/index.segments/_head.segment.rsc +1 -1
- package/.next/server/app/index.segments/_index.segment.rsc +1 -1
- package/.next/server/app/index.segments/_tree.segment.rsc +1 -1
- package/.next/server/app/page/react-loadable-manifest.json +1 -1
- package/.next/server/app/page_client-reference-manifest.js +1 -1
- package/.next/server/chunks/[root-of-the-server]__0d0pykb._.js +3 -3
- package/.next/server/chunks/[root-of-the-server]__0d0pykb._.js.map +1 -1
- package/.next/server/chunks/ssr/_0t7oqy6._.js +1 -1
- package/.next/server/chunks/ssr/_0t7oqy6._.js.map +1 -1
- package/.next/server/middleware-build-manifest.js +3 -3
- package/.next/server/pages/404.html +1 -1
- package/.next/server/pages/500.html +1 -1
- package/.next/server/server-reference-manifest.js +1 -1
- package/.next/server/server-reference-manifest.json +1 -1
- package/.next/static/chunks/{0di.tbc4b33wc.js → 04bx58jfb9n1..js} +1 -1
- package/.next/static/chunks/0knhkxhhzli15.js +1 -0
- package/.next/trace +1 -1
- package/.next/trace-build +1 -1
- package/package.json +1 -1
- package/src/app/components/IdeLayout.tsx +1 -1
- package/src/app/page.tsx +1 -1
- package/src/lib/agents/AiderRunner.ts +1 -1
- package/src/lib/agents/ClaudeRunner.ts +2 -2
- package/src/lib/agents/DockerRunner.ts +2 -2
- package/src/lib/agents/SSHRunner.ts +2 -2
- package/.next/static/chunks/0xq6bhmghl02_.js +0 -1
- /package/.next/static/{U91_fFFoX1whyhgd-SHaG → 2HGCuinlX_PNFgwkjIVKe}/_buildManifest.js +0 -0
- /package/.next/static/{U91_fFFoX1whyhgd-SHaG → 2HGCuinlX_PNFgwkjIVKe}/_clientMiddlewareManifest.js +0 -0
- /package/.next/static/{U91_fFFoX1whyhgd-SHaG → 2HGCuinlX_PNFgwkjIVKe}/_ssgManifest.js +0 -0
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
module.exports=[41997,(a,b,c)=>{"use strict";Object.defineProperty(c,"__esModule",{value:!0});var d={BailoutToCSRError:function(){return g},isBailoutToCSRError:function(){return h}};for(var e in d)Object.defineProperty(c,e,{enumerable:!0,get:d[e]});let f="BAILOUT_TO_CLIENT_SIDE_RENDERING";class g extends Error{constructor(a){super(`Bail out to client-side rendering: ${a}`),this.reason=a,this.digest=f}}function h(a){return"object"==typeof a&&null!==a&&"digest"in a&&a.digest===f}},32245,(a,b,c)=>{"use strict";Object.defineProperty(c,"__esModule",{value:!0}),Object.defineProperty(c,"BailoutToCSR",{enumerable:!0,get:function(){return e}});let d=a.r(41997);function e({reason:a,children:b}){throw Object.defineProperty(new d.BailoutToCSRError(a),"__NEXT_ERROR_CODE",{value:"E394",enumerable:!1,configurable:!0})}},7773,(a,b,c)=>{"use strict";function d(a){return a.split("/").map(a=>encodeURIComponent(a)).join("/")}Object.defineProperty(c,"__esModule",{value:!0}),Object.defineProperty(c,"encodeURIPath",{enumerable:!0,get:function(){return d}})},68063,(a,b,c)=>{"use strict";let d;Object.defineProperty(c,"__esModule",{value:!0});var e={getAssetToken:function(){return i},getAssetTokenQuery:function(){return j},getDeploymentId:function(){return g},getDeploymentIdQuery:function(){return h}};for(var f in e)Object.defineProperty(c,f,{enumerable:!0,get:e[f]});function g(){return d}function h(a=!1){return d?`${a?"&":"?"}dpl=${d}`:""}function i(){return!1}function j(a=!1){return""}d=void 0},97458,(a,b,c)=>{"use strict";Object.defineProperty(c,"__esModule",{value:!0}),Object.defineProperty(c,"PreloadChunks",{enumerable:!0,get:function(){return i}});let d=a.r(87924),e=a.r(35112),f=a.r(56704),g=a.r(7773),h=a.r(68063);function i({moduleIds:a}){let b=f.workAsyncStorage.getStore();if(void 0===b)return null;let c=[];if(b.reactLoadableManifest&&a){let d=b.reactLoadableManifest;for(let b of a){if(!d[b])continue;let a=d[b].files;c.push(...a)}}if(0===c.length)return null;let j=(0,h.getAssetTokenQuery)();return(0,d.jsx)(d.Fragment,{children:c.map(a=>{let c=`${b.assetPrefix}/_next/${(0,g.encodeURIPath)(a)}${j}`;return a.endsWith(".css")?(0,d.jsx)("link",{precedence:"dynamic",href:c,rel:"stylesheet",as:"style",nonce:b.nonce},a):((0,e.preload)(c,{as:"script",fetchPriority:"low",nonce:b.nonce}),null)})})}},69853,(a,b,c)=>{"use strict";Object.defineProperty(c,"__esModule",{value:!0}),Object.defineProperty(c,"default",{enumerable:!0,get:function(){return j}});let d=a.r(87924),e=a.r(72131),f=a.r(32245),g=a.r(97458);function h(a){return{default:a&&"default"in a?a.default:a}}let i={loader:()=>Promise.resolve(h(()=>null)),loading:null,ssr:!0},j=function(a){let b={...i,...a},c=(0,e.lazy)(()=>b.loader().then(h)),j=b.loading;function k(a){let h=j?(0,d.jsx)(j,{isLoading:!0,pastDelay:!0,error:null}):null,i=!b.ssr||!!b.loading,k=i?e.Suspense:e.Fragment,l=b.ssr?(0,d.jsxs)(d.Fragment,{children:[(0,d.jsx)(g.PreloadChunks,{moduleIds:b.modules}),(0,d.jsx)(c,{...a})]}):(0,d.jsx)(f.BailoutToCSR,{reason:"next/dynamic",children:(0,d.jsx)(c,{...a})});return(0,d.jsx)(k,{...i?{fallback:h}:{},children:l})}return k.displayName="LoadableComponent",k}},19721,(a,b,c)=>{"use strict";Object.defineProperty(c,"__esModule",{value:!0}),Object.defineProperty(c,"default",{enumerable:!0,get:function(){return e}});let d=a.r(33354)._(a.r(69853));function e(a,b){let c={};"function"==typeof a&&(c.loader=a);let e={...c,...b};return(0,d.default)({...e,modules:e.loadableGenerated?.modules})}("function"==typeof c.default||"object"==typeof c.default&&null!==c.default)&&void 0===c.default.__esModule&&(Object.defineProperty(c.default,"__esModule",{value:!0}),Object.assign(c.default,c),b.exports=c.default)},46845,a=>{a.v({activeBorder:"page-module___8aEwW__activeBorder",agentBadge:"page-module___8aEwW__agentBadge",agentCard:"page-module___8aEwW__agentCard",agentGrid:"page-module___8aEwW__agentGrid",agentHeader:"page-module___8aEwW__agentHeader",agentName:"page-module___8aEwW__agentName",ansiCyan:"page-module___8aEwW__ansiCyan",ansiGreen:"page-module___8aEwW__ansiGreen",ansiMagenta:"page-module___8aEwW__ansiMagenta",ansiRed:"page-module___8aEwW__ansiRed",ansiYellow:"page-module___8aEwW__ansiYellow",cardBody:"page-module___8aEwW__cardBody",container:"page-module___8aEwW__container",contextDetails:"page-module___8aEwW__contextDetails",contextItem:"page-module___8aEwW__contextItem",contextList:"page-module___8aEwW__contextList",contextMeta:"page-module___8aEwW__contextMeta",contextTitle:"page-module___8aEwW__contextTitle",dashboardGrid:"page-module___8aEwW__dashboardGrid",envGrid:"page-module___8aEwW__envGrid",envName:"page-module___8aEwW__envName",envRow:"page-module___8aEwW__envRow",envStatus:"page-module___8aEwW__envStatus",footer:"page-module___8aEwW__footer",header:"page-module___8aEwW__header",logoArea:"page-module___8aEwW__logoArea",mainPanel:"page-module___8aEwW__mainPanel",pulse:"page-module___8aEwW__pulse",pulseDot:"page-module___8aEwW__pulseDot",quickLaunchBtn:"page-module___8aEwW__quickLaunchBtn",sectionTitle:"page-module___8aEwW__sectionTitle",sidePanel:"page-module___8aEwW__sidePanel",statusIndicator:"page-module___8aEwW__statusIndicator",stoppedBadge:"page-module___8aEwW__stoppedBadge",subtitle:"page-module___8aEwW__subtitle",terminalContainer:"page-module___8aEwW__terminalContainer",terminalInput:"page-module___8aEwW__terminalInput",terminalInputArea:"page-module___8aEwW__terminalInputArea",terminalLine:"page-module___8aEwW__terminalLine",terminalSendBtn:"page-module___8aEwW__terminalSendBtn",title:"page-module___8aEwW__title"})},40777,a=>{"use strict";var b=a.i(87924),c=a.i(72131),d=a.i(19721),e=a.i(46845);let f=(0,d.default)(async()=>{},{loadableGenerated:{modules:[37314]},ssr:!1,loading:()=>(0,b.jsx)("div",{style:{height:"400px",display:"flex",alignItems:"center",justifyContent:"center",backgroundColor:"#05070a",color:"var(--muted)",border:"1px solid var(--border)",borderBottomLeftRadius:"12px",borderBottomRightRadius:"12px"},children:(0,b.jsx)("span",{children:"Initializing terminal emulator..."})})}),g=(0,d.default)(async()=>{},{loadableGenerated:{modules:[1985]},ssr:!1,loading:()=>(0,b.jsx)("div",{style:{height:"280px",display:"flex",alignItems:"center",justifyContent:"center",backgroundColor:"var(--card)",border:"1px solid var(--border)",borderRadius:"12px",marginTop:"1.5rem"},children:(0,b.jsx)("span",{style:{color:"var(--muted)"},children:"Initializing prompt editor..."})})}),h=(0,d.default)(async()=>{},{loadableGenerated:{modules:[99026]},ssr:!1}),i=(0,d.default)(async()=>{},{loadableGenerated:{modules:[9949]},ssr:!1}),j=(0,d.default)(async()=>{},{loadableGenerated:{modules:[20032]},ssr:!1}),k=(0,d.default)(async()=>{},{loadableGenerated:{modules:[97722]},ssr:!1});a.s(["default",0,function(){let[a,d]=(0,c.useState)([]),[l,m]=(0,c.useState)(null),[n,o]=(0,c.useState)(!1),[p,q]=(0,c.useState)(!1),[r,s]=(0,c.useState)(!1),[t,u]=(0,c.useState)(!1),[v,w]=(0,c.useState)(!1),[x,y]=(0,c.useState)(!1),z=a.find(a=>a.id===l),A=a.some(a=>("claude-docker"===a.type||"aider-docker"===a.type)&&"running"===a.status),B=a.some(a=>"claude-ssh"===a.type&&"running"===a.status),C=async()=>{try{let a=await fetch("/api/sessions"),b=await a.json();b.sessions&&d(b.sessions)}catch(a){console.error("Failed to fetch sessions:",a)}};(0,c.useEffect)(()=>{(async()=>{await C()})();let a=setInterval(C,4e3);return()=>clearInterval(a)},[]);let D=async(a,b,c,d)=>{o(!0);try{let e=b;e||("claude"===a?e="Claude Local":"claude-docker"===a?e="Claude Docker":"claude-ssh"===a?e="Claude SSH":"aider"===a?e="Aider Local":"aider-docker"===a?e="Aider Docker":"mock"===a&&(e="Mock Session"));let f={type:a,name:e,workspaceRoot:c,scopedDirs:d};if(("aider"===a||"aider-docker"===a)&&!c)try{let a=await fetch("/api/context/aider");if(a.ok){let b=await a.json();b.success&&b.config&&(f.workspaceRoot=b.config.workspaceRoot,f.scopedDirs=b.config.scopedDirs)}}catch(a){console.error("Failed to load aider configuration before launch:",a)}let g=await fetch("/api/sessions/launch",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(f)}),h=await g.json();h.success&&(await C(),m(h.session.id))}catch(a){console.error("Failed to launch session:",a)}finally{o(!1)}},E=async(a,b=!1)=>{try{let c=await fetch("/api/sessions/stop",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({id:a,delete:b})});(await c.json()).success&&(b&&l===a&&m(null),await C())}catch(a){console.error("Failed to stop session:",a)}};return(0,b.jsxs)("div",{className:e.default.container,children:[(0,b.jsxs)("header",{className:e.default.header,children:[(0,b.jsxs)("div",{className:e.default.logoArea,children:[(0,b.jsx)("h1",{className:e.default.title,children:"NeuralLoom"}),(0,b.jsx)("span",{className:e.default.subtitle,children:"Unified AI Orchestrator & Context Bridge"})]}),(0,b.jsxs)("div",{className:e.default.statusIndicator,children:[(0,b.jsx)("span",{className:e.default.pulseDot}),(0,b.jsx)("span",{children:"Orchestrator Online"})]})]}),z?(0,b.jsx)("div",{style:{padding:"0 2rem",marginBottom:"2rem"},children:(0,b.jsx)(k,{sessionId:z.id,workspaceRoot:z.workspaceRoot||"",scopedDirs:z.scopedDirs||[],onClose:()=>m(null),sessions:a,onSwitchSession:a=>m(a)})}):(0,b.jsxs)("div",{className:e.default.dashboardGrid,children:[(0,b.jsxs)("main",{className:e.default.mainPanel,children:[(0,b.jsxs)("section",{children:[(0,b.jsx)("h2",{className:e.default.sectionTitle,children:"Active AI Agents"}),0===a.length?(0,b.jsxs)("div",{className:"card",style:{padding:"3rem 1.5rem",textAlign:"center"},children:[(0,b.jsx)("p",{style:{color:"var(--muted)",marginBottom:"1.5rem"},children:"No active agent sessions in this workspace. Launch a simulated session to verify the control bridge."}),(0,b.jsx)("button",{className:e.default.quickLaunchBtn,onClick:()=>D("mock"),disabled:n,style:{maxWidth:"240px",margin:"0 auto"},children:n?"Launching...":"⚡ Launch Simulated Session"})]}):(0,b.jsx)("div",{className:e.default.agentGrid,children:a.map(a=>(0,b.jsxs)("div",{className:`${e.default.agentCard} card ${l===a.id?e.default.activeBorder:""}`,children:[(0,b.jsxs)("div",{className:e.default.agentHeader,children:[(0,b.jsx)("span",{className:e.default.agentName,children:a.name}),(0,b.jsx)("span",{className:`${e.default.agentBadge} ${"stopped"===a.status?e.default.stoppedBadge:""}`,children:a.status})]}),(0,b.jsxs)("div",{className:e.default.cardBody,children:[(0,b.jsxs)("p",{style:{fontSize:"0.825rem",color:"var(--muted)"},children:["ID: ",(0,b.jsx)("code",{style:{fontSize:"0.75rem"},children:a.id.substring(0,8)}),(0,b.jsx)("br",{}),"Type: ","claude"===a.type?"Claude Local PTY":"claude-docker"===a.type?"Claude Docker PTY":"claude-ssh"===a.type?"Claude SSH PTY":"aider"===a.type?"Aider Local PTY":"aider-docker"===a.type?"Aider Docker PTY":"mock"===a.type?"Simulated Mock PTY":"Unknown PTY",(0,b.jsx)("br",{}),"Logs: ",a.logsCount," captured lines"]}),(0,b.jsxs)("div",{style:{display:"flex",gap:"0.5rem",marginTop:"1rem"},children:["running"===a.status?(0,b.jsx)("button",{onClick:()=>E(a.id,!1),style:{flex:1,padding:"0.4rem 0.6rem",borderRadius:"6px",border:"1px solid var(--danger)",backgroundColor:"transparent",fontSize:"0.75rem",fontWeight:600,color:"var(--danger)"},children:"Stop"}):(0,b.jsx)("button",{onClick:()=>E(a.id,!0),style:{flex:1,padding:"0.4rem 0.6rem",borderRadius:"6px",border:"1px solid var(--border)",backgroundColor:"transparent",fontSize:"0.75rem",fontWeight:600,color:"var(--muted)"},children:"Delete"}),(0,b.jsx)("button",{onClick:()=>m(a.id),style:{flex:2,padding:"0.4rem 0.6rem",borderRadius:"6px",border:"none",backgroundColor:l===a.id?"var(--border-focus)":"var(--primary)",fontSize:"0.75rem",fontWeight:600,color:"#fff"},children:l===a.id?"Connected":"Open Session"})]})]})]},a.id))})]}),l&&(0,b.jsxs)("section",{className:"card",style:{display:"flex",flexDirection:"column",border:"1px solid var(--border-focus)"},children:[(0,b.jsxs)("div",{className:e.default.agentHeader,style:{justifyContent:"space-between",background:"rgba(109, 40, 217, 0.08)"},children:[(0,b.jsxs)("span",{style:{fontWeight:600,display:"flex",alignItems:"center",gap:"0.5rem"},children:["🖥️ Console Bridge — ",a.find(a=>a.id===l)?.name]}),(0,b.jsx)("button",{onClick:()=>m(null),style:{border:"none",background:"none",color:"var(--muted)",cursor:"pointer",fontSize:"0.75rem"},children:"Close Panel ✖"})]}),(0,b.jsx)(f,{sessionId:l})]}),(0,b.jsxs)("section",{children:[(0,b.jsx)("h2",{className:e.default.sectionTitle,children:"Shared Context Hub & Slash Commands"}),(0,b.jsxs)("div",{className:e.default.contextList,children:[(0,b.jsxs)("div",{className:`${e.default.contextItem} card`,children:[(0,b.jsxs)("div",{className:e.default.contextMeta,children:[(0,b.jsx)("span",{className:e.default.contextTitle,children:"Staged Context & System Rules (/ccc)"}),(0,b.jsx)("span",{className:e.default.contextDetails,children:"Compiles AGENTS.md guidelines and project files folder hierarchy map."})]}),(0,b.jsx)("button",{onClick:async()=>{l&&await fetch("/api/sessions/inject",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({id:l,command:"/ccc"})})},disabled:!l,style:{padding:"0.4rem 0.8rem",borderRadius:"6px",border:"1px solid var(--primary)",backgroundColor:"transparent",color:"var(--primary)",fontSize:"0.75rem",fontWeight:600,opacity:l?1:.5,cursor:l?"pointer":"not-allowed"},children:"🚀 Mount Context (/ccc)"})]}),(0,b.jsxs)("div",{className:`${e.default.contextItem} card`,children:[(0,b.jsxs)("div",{className:e.default.contextMeta,children:[(0,b.jsx)("span",{className:e.default.contextTitle,children:"Staged Developer Prompt (/ccp)"}),(0,b.jsx)("span",{className:e.default.contextDetails,children:"Executes instructions written in .ai/neural-loom/cprompt.md."})]}),(0,b.jsx)("button",{onClick:async()=>{l&&await fetch("/api/sessions/inject",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({id:l,command:"/ccp"})})},disabled:!l,style:{padding:"0.4rem 0.8rem",borderRadius:"6px",border:"1px solid var(--success)",backgroundColor:"transparent",color:"var(--success)",fontSize:"0.75rem",fontWeight:600,opacity:l?1:.5,cursor:l?"pointer":"not-allowed"},children:"⚡ Trigger Prompt (/ccp)"})]})]}),(0,b.jsx)(g,{})]})]}),(0,b.jsxs)("aside",{className:e.default.sidePanel,children:[(0,b.jsxs)("section",{children:[(0,b.jsx)("h2",{className:e.default.sectionTitle,children:"Execution Environments"}),(0,b.jsxs)("div",{className:e.default.envGrid,children:[(0,b.jsxs)("div",{className:e.default.envRow,children:[(0,b.jsx)("span",{className:e.default.envName,children:"💻 Local host OS"}),(0,b.jsx)("span",{className:e.default.envStatus,style:{color:"var(--success)"},children:"Active"})]}),(0,b.jsxs)("div",{className:e.default.envRow,style:{opacity:A?1:.6},children:[(0,b.jsx)("span",{className:e.default.envName,children:"🐳 Docker Sandbox"}),(0,b.jsx)("span",{className:e.default.envStatus,style:{color:A?"var(--success)":"var(--muted)"},children:A?"Active":"Not Mounted"})]}),(0,b.jsxs)("div",{className:e.default.envRow,style:{opacity:B?1:.6},children:[(0,b.jsx)("span",{className:e.default.envName,children:"🌐 Remote VM (SSH)"}),(0,b.jsx)("span",{className:e.default.envStatus,style:{color:B?"var(--success)":"var(--muted)"},children:B?"Active":"Disconnected"})]})]})]}),(0,b.jsxs)("section",{style:{display:"flex",flexDirection:"column",gap:"0.75rem"},children:[(0,b.jsxs)("button",{className:e.default.quickLaunchBtn,onClick:()=>D("mock"),disabled:n,children:[(0,b.jsx)("span",{children:"⚡"}),(0,b.jsx)("span",{children:"Launch Mock Agent"})]}),(0,b.jsxs)("button",{className:e.default.quickLaunchBtn,onClick:()=>{y(!1),w(!0)},disabled:n,style:{background:"linear-gradient(135deg, hsl(262, 83%, 60%) 0%, hsl(195, 100%, 45%) 100%)",border:"none"},children:[(0,b.jsx)("span",{children:"🤖"}),(0,b.jsx)("span",{children:"Launch Claude PTY"})]}),(0,b.jsxs)("button",{className:e.default.quickLaunchBtn,onClick:()=>{y(!0),w(!0)},disabled:n,style:{background:"linear-gradient(135deg, hsl(170, 72%, 40%) 0%, hsl(195, 100%, 40%) 100%)",border:"none"},children:[(0,b.jsx)("span",{children:"🐳"}),(0,b.jsx)("span",{children:"Launch Docker PTY"})]}),(0,b.jsxs)("button",{className:e.default.quickLaunchBtn,onClick:()=>q(!0),disabled:n,style:{background:"linear-gradient(135deg, hsl(38, 92%, 50%) 0%, hsl(0, 84%, 60%) 100%)",border:"none"},children:[(0,b.jsx)("span",{children:"🌐"}),(0,b.jsx)("span",{children:"Launch SSH PTY"})]}),(0,b.jsxs)("button",{className:e.default.quickLaunchBtn,onClick:()=>{u(!1),s(!0)},disabled:n,style:{background:"linear-gradient(135deg, hsl(210, 80%, 45%) 0%, hsl(262, 80%, 55%) 100%)",border:"none"},children:[(0,b.jsx)("span",{children:"🐍"}),(0,b.jsx)("span",{children:"Launch Aider PTY"})]}),(0,b.jsxs)("button",{className:e.default.quickLaunchBtn,onClick:()=>{u(!0),s(!0)},disabled:n,style:{background:"linear-gradient(135deg, hsl(195, 100%, 40%) 0%, hsl(262, 80%, 55%) 100%)",border:"none"},children:[(0,b.jsx)("span",{children:"🐳"}),(0,b.jsx)("span",{children:"Launch Aider Docker"})]})]}),(0,b.jsxs)("section",{className:"card",style:{padding:"1.5rem",display:"flex",flexDirection:"column",gap:"0.75rem"},children:[(0,b.jsx)("h3",{style:{fontSize:"1rem",fontWeight:700},children:"Quick Actions"}),(0,b.jsxs)("ul",{style:{listStyle:"none",fontSize:"0.875rem",display:"flex",flexDirection:"column",gap:"0.5rem",color:"var(--muted)"},children:[(0,b.jsxs)("li",{style:{display:"flex",justifyContent:"space-between"},children:[(0,b.jsx)("span",{children:"Configure global API Keys"}),(0,b.jsx)("span",{style:{color:"var(--primary)",cursor:"pointer"},children:"→"})]}),(0,b.jsxs)("li",{style:{display:"flex",justifyContent:"space-between"},children:[(0,b.jsx)("span",{children:"Edit rules templates"}),(0,b.jsx)("span",{style:{color:"var(--primary)",cursor:"pointer"},children:"→"})]}),(0,b.jsxs)("li",{style:{display:"flex",justifyContent:"space-between"},children:[(0,b.jsx)("span",{children:"Inspect process locks"}),(0,b.jsx)("span",{style:{color:"var(--primary)",cursor:"pointer"},children:"→"})]})]})]})]})]}),(0,b.jsxs)("footer",{className:e.default.footer,children:[(0,b.jsx)("span",{children:"NeuralLoom v0.1.0 — Experimental AI Orchestrator Bridge"}),(0,b.jsx)("span",{children:"Directory: C:\\Users\\Dave\\OneDrive\\Projects\\JS\\neural-loom"})]}),p&&(0,b.jsx)(h,{onClose:()=>q(!1),onConfirmLaunch:()=>{q(!1),D("claude-ssh")}}),r&&(0,b.jsx)(i,{onClose:()=>s(!1),isDocker:t,onConfirmLaunch:()=>{s(!1),D(t?"aider-docker":"aider")}}),v&&(0,b.jsx)(j,{onClose:()=>w(!1),isDocker:x,onConfirmLaunch:(a,b,c)=>{w(!1),D(x?"claude-docker":"claude",a,b,c)}})]})}])}];
|
|
1
|
+
module.exports=[41997,(a,b,c)=>{"use strict";Object.defineProperty(c,"__esModule",{value:!0});var d={BailoutToCSRError:function(){return g},isBailoutToCSRError:function(){return h}};for(var e in d)Object.defineProperty(c,e,{enumerable:!0,get:d[e]});let f="BAILOUT_TO_CLIENT_SIDE_RENDERING";class g extends Error{constructor(a){super(`Bail out to client-side rendering: ${a}`),this.reason=a,this.digest=f}}function h(a){return"object"==typeof a&&null!==a&&"digest"in a&&a.digest===f}},32245,(a,b,c)=>{"use strict";Object.defineProperty(c,"__esModule",{value:!0}),Object.defineProperty(c,"BailoutToCSR",{enumerable:!0,get:function(){return e}});let d=a.r(41997);function e({reason:a,children:b}){throw Object.defineProperty(new d.BailoutToCSRError(a),"__NEXT_ERROR_CODE",{value:"E394",enumerable:!1,configurable:!0})}},7773,(a,b,c)=>{"use strict";function d(a){return a.split("/").map(a=>encodeURIComponent(a)).join("/")}Object.defineProperty(c,"__esModule",{value:!0}),Object.defineProperty(c,"encodeURIPath",{enumerable:!0,get:function(){return d}})},68063,(a,b,c)=>{"use strict";let d;Object.defineProperty(c,"__esModule",{value:!0});var e={getAssetToken:function(){return i},getAssetTokenQuery:function(){return j},getDeploymentId:function(){return g},getDeploymentIdQuery:function(){return h}};for(var f in e)Object.defineProperty(c,f,{enumerable:!0,get:e[f]});function g(){return d}function h(a=!1){return d?`${a?"&":"?"}dpl=${d}`:""}function i(){return!1}function j(a=!1){return""}d=void 0},97458,(a,b,c)=>{"use strict";Object.defineProperty(c,"__esModule",{value:!0}),Object.defineProperty(c,"PreloadChunks",{enumerable:!0,get:function(){return i}});let d=a.r(87924),e=a.r(35112),f=a.r(56704),g=a.r(7773),h=a.r(68063);function i({moduleIds:a}){let b=f.workAsyncStorage.getStore();if(void 0===b)return null;let c=[];if(b.reactLoadableManifest&&a){let d=b.reactLoadableManifest;for(let b of a){if(!d[b])continue;let a=d[b].files;c.push(...a)}}if(0===c.length)return null;let j=(0,h.getAssetTokenQuery)();return(0,d.jsx)(d.Fragment,{children:c.map(a=>{let c=`${b.assetPrefix}/_next/${(0,g.encodeURIPath)(a)}${j}`;return a.endsWith(".css")?(0,d.jsx)("link",{precedence:"dynamic",href:c,rel:"stylesheet",as:"style",nonce:b.nonce},a):((0,e.preload)(c,{as:"script",fetchPriority:"low",nonce:b.nonce}),null)})})}},69853,(a,b,c)=>{"use strict";Object.defineProperty(c,"__esModule",{value:!0}),Object.defineProperty(c,"default",{enumerable:!0,get:function(){return j}});let d=a.r(87924),e=a.r(72131),f=a.r(32245),g=a.r(97458);function h(a){return{default:a&&"default"in a?a.default:a}}let i={loader:()=>Promise.resolve(h(()=>null)),loading:null,ssr:!0},j=function(a){let b={...i,...a},c=(0,e.lazy)(()=>b.loader().then(h)),j=b.loading;function k(a){let h=j?(0,d.jsx)(j,{isLoading:!0,pastDelay:!0,error:null}):null,i=!b.ssr||!!b.loading,k=i?e.Suspense:e.Fragment,l=b.ssr?(0,d.jsxs)(d.Fragment,{children:[(0,d.jsx)(g.PreloadChunks,{moduleIds:b.modules}),(0,d.jsx)(c,{...a})]}):(0,d.jsx)(f.BailoutToCSR,{reason:"next/dynamic",children:(0,d.jsx)(c,{...a})});return(0,d.jsx)(k,{...i?{fallback:h}:{},children:l})}return k.displayName="LoadableComponent",k}},19721,(a,b,c)=>{"use strict";Object.defineProperty(c,"__esModule",{value:!0}),Object.defineProperty(c,"default",{enumerable:!0,get:function(){return e}});let d=a.r(33354)._(a.r(69853));function e(a,b){let c={};"function"==typeof a&&(c.loader=a);let e={...c,...b};return(0,d.default)({...e,modules:e.loadableGenerated?.modules})}("function"==typeof c.default||"object"==typeof c.default&&null!==c.default)&&void 0===c.default.__esModule&&(Object.defineProperty(c.default,"__esModule",{value:!0}),Object.assign(c.default,c),b.exports=c.default)},46845,a=>{a.v({activeBorder:"page-module___8aEwW__activeBorder",agentBadge:"page-module___8aEwW__agentBadge",agentCard:"page-module___8aEwW__agentCard",agentGrid:"page-module___8aEwW__agentGrid",agentHeader:"page-module___8aEwW__agentHeader",agentName:"page-module___8aEwW__agentName",ansiCyan:"page-module___8aEwW__ansiCyan",ansiGreen:"page-module___8aEwW__ansiGreen",ansiMagenta:"page-module___8aEwW__ansiMagenta",ansiRed:"page-module___8aEwW__ansiRed",ansiYellow:"page-module___8aEwW__ansiYellow",cardBody:"page-module___8aEwW__cardBody",container:"page-module___8aEwW__container",contextDetails:"page-module___8aEwW__contextDetails",contextItem:"page-module___8aEwW__contextItem",contextList:"page-module___8aEwW__contextList",contextMeta:"page-module___8aEwW__contextMeta",contextTitle:"page-module___8aEwW__contextTitle",dashboardGrid:"page-module___8aEwW__dashboardGrid",envGrid:"page-module___8aEwW__envGrid",envName:"page-module___8aEwW__envName",envRow:"page-module___8aEwW__envRow",envStatus:"page-module___8aEwW__envStatus",footer:"page-module___8aEwW__footer",header:"page-module___8aEwW__header",logoArea:"page-module___8aEwW__logoArea",mainPanel:"page-module___8aEwW__mainPanel",pulse:"page-module___8aEwW__pulse",pulseDot:"page-module___8aEwW__pulseDot",quickLaunchBtn:"page-module___8aEwW__quickLaunchBtn",sectionTitle:"page-module___8aEwW__sectionTitle",sidePanel:"page-module___8aEwW__sidePanel",statusIndicator:"page-module___8aEwW__statusIndicator",stoppedBadge:"page-module___8aEwW__stoppedBadge",subtitle:"page-module___8aEwW__subtitle",terminalContainer:"page-module___8aEwW__terminalContainer",terminalInput:"page-module___8aEwW__terminalInput",terminalInputArea:"page-module___8aEwW__terminalInputArea",terminalLine:"page-module___8aEwW__terminalLine",terminalSendBtn:"page-module___8aEwW__terminalSendBtn",title:"page-module___8aEwW__title"})},40777,a=>{"use strict";var b=a.i(87924),c=a.i(72131),d=a.i(19721),e=a.i(46845);let f=(0,d.default)(async()=>{},{loadableGenerated:{modules:[37314]},ssr:!1,loading:()=>(0,b.jsx)("div",{style:{height:"400px",display:"flex",alignItems:"center",justifyContent:"center",backgroundColor:"#05070a",color:"var(--muted)",border:"1px solid var(--border)",borderBottomLeftRadius:"12px",borderBottomRightRadius:"12px"},children:(0,b.jsx)("span",{children:"Initializing terminal emulator..."})})}),g=(0,d.default)(async()=>{},{loadableGenerated:{modules:[1985]},ssr:!1,loading:()=>(0,b.jsx)("div",{style:{height:"280px",display:"flex",alignItems:"center",justifyContent:"center",backgroundColor:"var(--card)",border:"1px solid var(--border)",borderRadius:"12px",marginTop:"1.5rem"},children:(0,b.jsx)("span",{style:{color:"var(--muted)"},children:"Initializing prompt editor..."})})}),h=(0,d.default)(async()=>{},{loadableGenerated:{modules:[99026]},ssr:!1}),i=(0,d.default)(async()=>{},{loadableGenerated:{modules:[9949]},ssr:!1}),j=(0,d.default)(async()=>{},{loadableGenerated:{modules:[20032]},ssr:!1}),k=(0,d.default)(async()=>{},{loadableGenerated:{modules:[97722]},ssr:!1});a.s(["default",0,function(){let[a,d]=(0,c.useState)([]),[l,m]=(0,c.useState)(null),[n,o]=(0,c.useState)(!1),[p,q]=(0,c.useState)(!1),[r,s]=(0,c.useState)(!1),[t,u]=(0,c.useState)(!1),[v,w]=(0,c.useState)(!1),[x,y]=(0,c.useState)(!1),z=a.find(a=>a.id===l),A=a.some(a=>("claude-docker"===a.type||"aider-docker"===a.type)&&"running"===a.status),B=a.some(a=>"claude-ssh"===a.type&&"running"===a.status),C=async()=>{try{let a=await fetch("/api/sessions"),b=await a.json();b.sessions&&d(b.sessions)}catch(a){console.error("Failed to fetch sessions:",a)}};(0,c.useEffect)(()=>{(async()=>{await C()})();let a=setInterval(C,4e3);return()=>clearInterval(a)},[]);let D=async(a,b,c,d)=>{o(!0);try{let e=b;e||("claude"===a?e="Claude Local":"claude-docker"===a?e="Claude Docker":"claude-ssh"===a?e="Claude SSH":"aider"===a?e="Aider Local":"aider-docker"===a?e="Aider Docker":"mock"===a&&(e="Mock Session"));let f={type:a,name:e,workspaceRoot:c,scopedDirs:d};if(("aider"===a||"aider-docker"===a)&&!c)try{let a=await fetch("/api/context/aider");if(a.ok){let b=await a.json();b.success&&b.config&&(f.workspaceRoot=b.config.workspaceRoot,f.scopedDirs=b.config.scopedDirs)}}catch(a){console.error("Failed to load aider configuration before launch:",a)}let g=await fetch("/api/sessions/launch",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(f)}),h=await g.json();h.success&&(await C(),m(h.session.id))}catch(a){console.error("Failed to launch session:",a)}finally{o(!1)}},E=async(a,b=!1)=>{try{let c=await fetch("/api/sessions/stop",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({id:a,delete:b})});(await c.json()).success&&(b&&l===a&&m(null),await C())}catch(a){console.error("Failed to stop session:",a)}};return(0,b.jsxs)("div",{className:e.default.container,children:[(0,b.jsxs)("header",{className:e.default.header,children:[(0,b.jsxs)("div",{className:e.default.logoArea,children:[(0,b.jsx)("h1",{className:e.default.title,children:"NeuralLoom"}),(0,b.jsx)("span",{className:e.default.subtitle,children:"Unified AI Orchestrator & Context Bridge"})]}),(0,b.jsxs)("div",{className:e.default.statusIndicator,children:[(0,b.jsx)("span",{className:e.default.pulseDot}),(0,b.jsx)("span",{children:"Orchestrator Online"})]})]}),z?(0,b.jsx)("div",{style:{padding:"0 2rem",marginBottom:"2rem"},children:(0,b.jsx)(k,{sessionId:z.id,workspaceRoot:z.workspaceRoot||"",scopedDirs:z.scopedDirs||[],onClose:()=>m(null),sessions:a,onSwitchSession:a=>m(a)})}):(0,b.jsxs)("div",{className:e.default.dashboardGrid,children:[(0,b.jsxs)("main",{className:e.default.mainPanel,children:[(0,b.jsxs)("section",{children:[(0,b.jsx)("h2",{className:e.default.sectionTitle,children:"Active AI Agents"}),0===a.length?(0,b.jsxs)("div",{className:"card",style:{padding:"3rem 1.5rem",textAlign:"center"},children:[(0,b.jsx)("p",{style:{color:"var(--muted)",marginBottom:"1.5rem"},children:"No active agent sessions in this workspace. Launch a simulated session to verify the control bridge."}),(0,b.jsx)("button",{className:e.default.quickLaunchBtn,onClick:()=>D("mock"),disabled:n,style:{maxWidth:"240px",margin:"0 auto"},children:n?"Launching...":"⚡ Launch Simulated Session"})]}):(0,b.jsx)("div",{className:e.default.agentGrid,children:a.map(a=>(0,b.jsxs)("div",{className:`${e.default.agentCard} card ${l===a.id?e.default.activeBorder:""}`,children:[(0,b.jsxs)("div",{className:e.default.agentHeader,children:[(0,b.jsx)("span",{className:e.default.agentName,children:a.name}),(0,b.jsx)("span",{className:`${e.default.agentBadge} ${"stopped"===a.status?e.default.stoppedBadge:""}`,children:a.status})]}),(0,b.jsxs)("div",{className:e.default.cardBody,children:[(0,b.jsxs)("p",{style:{fontSize:"0.825rem",color:"var(--muted)"},children:["ID: ",(0,b.jsx)("code",{style:{fontSize:"0.75rem"},children:a.id.substring(0,8)}),(0,b.jsx)("br",{}),"Type: ","claude"===a.type?"Claude Local PTY":"claude-docker"===a.type?"Claude Docker PTY":"claude-ssh"===a.type?"Claude SSH PTY":"aider"===a.type?"Aider Local PTY":"aider-docker"===a.type?"Aider Docker PTY":"mock"===a.type?"Simulated Mock PTY":"Unknown PTY",(0,b.jsx)("br",{}),"Logs: ",a.logsCount," captured lines"]}),(0,b.jsxs)("div",{style:{display:"flex",gap:"0.5rem",marginTop:"1rem"},children:["running"===a.status?(0,b.jsx)("button",{onClick:()=>E(a.id,!1),style:{flex:1,padding:"0.4rem 0.6rem",borderRadius:"6px",border:"1px solid var(--danger)",backgroundColor:"transparent",fontSize:"0.75rem",fontWeight:600,color:"var(--danger)"},children:"Stop"}):(0,b.jsx)("button",{onClick:()=>E(a.id,!0),style:{flex:1,padding:"0.4rem 0.6rem",borderRadius:"6px",border:"1px solid var(--border)",backgroundColor:"transparent",fontSize:"0.75rem",fontWeight:600,color:"var(--muted)"},children:"Delete"}),(0,b.jsx)("button",{onClick:()=>m(a.id),style:{flex:2,padding:"0.4rem 0.6rem",borderRadius:"6px",border:"none",backgroundColor:l===a.id?"var(--border-focus)":"var(--primary)",fontSize:"0.75rem",fontWeight:600,color:"#fff"},children:l===a.id?"Connected":"Open Session"})]})]})]},a.id))})]}),l&&(0,b.jsxs)("section",{className:"card",style:{display:"flex",flexDirection:"column",border:"1px solid var(--border-focus)"},children:[(0,b.jsxs)("div",{className:e.default.agentHeader,style:{justifyContent:"space-between",background:"rgba(109, 40, 217, 0.08)"},children:[(0,b.jsxs)("span",{style:{fontWeight:600,display:"flex",alignItems:"center",gap:"0.5rem"},children:["🖥️ Console Bridge — ",a.find(a=>a.id===l)?.name]}),(0,b.jsx)("button",{onClick:()=>m(null),style:{border:"none",background:"none",color:"var(--muted)",cursor:"pointer",fontSize:"0.75rem"},children:"Close Panel ✖"})]}),(0,b.jsx)(f,{sessionId:l})]}),(0,b.jsxs)("section",{children:[(0,b.jsx)("h2",{className:e.default.sectionTitle,children:"Shared Context Hub & Slash Commands"}),(0,b.jsxs)("div",{className:e.default.contextList,children:[(0,b.jsxs)("div",{className:`${e.default.contextItem} card`,children:[(0,b.jsxs)("div",{className:e.default.contextMeta,children:[(0,b.jsx)("span",{className:e.default.contextTitle,children:"Staged Context & System Rules (/ccc)"}),(0,b.jsx)("span",{className:e.default.contextDetails,children:"Compiles AGENTS.md guidelines and project files folder hierarchy map."})]}),(0,b.jsx)("button",{onClick:async()=>{l&&await fetch("/api/sessions/inject",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({id:l,command:"/ccc"})})},disabled:!l,style:{padding:"0.4rem 0.8rem",borderRadius:"6px",border:"1px solid var(--primary)",backgroundColor:"transparent",color:"var(--primary)",fontSize:"0.75rem",fontWeight:600,opacity:l?1:.5,cursor:l?"pointer":"not-allowed"},children:"🚀 Mount Context (/ccc)"})]}),(0,b.jsxs)("div",{className:`${e.default.contextItem} card`,children:[(0,b.jsxs)("div",{className:e.default.contextMeta,children:[(0,b.jsx)("span",{className:e.default.contextTitle,children:"Staged Developer Prompt (/ccp)"}),(0,b.jsx)("span",{className:e.default.contextDetails,children:"Executes instructions written in .ai/neural-loom/cprompt.md."})]}),(0,b.jsx)("button",{onClick:async()=>{l&&await fetch("/api/sessions/inject",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({id:l,command:"/ccp"})})},disabled:!l,style:{padding:"0.4rem 0.8rem",borderRadius:"6px",border:"1px solid var(--success)",backgroundColor:"transparent",color:"var(--success)",fontSize:"0.75rem",fontWeight:600,opacity:l?1:.5,cursor:l?"pointer":"not-allowed"},children:"⚡ Trigger Prompt (/ccp)"})]})]}),(0,b.jsx)(g,{})]})]}),(0,b.jsxs)("aside",{className:e.default.sidePanel,children:[(0,b.jsxs)("section",{children:[(0,b.jsx)("h2",{className:e.default.sectionTitle,children:"Execution Environments"}),(0,b.jsxs)("div",{className:e.default.envGrid,children:[(0,b.jsxs)("div",{className:e.default.envRow,children:[(0,b.jsx)("span",{className:e.default.envName,children:"💻 Local host OS"}),(0,b.jsx)("span",{className:e.default.envStatus,style:{color:"var(--success)"},children:"Active"})]}),(0,b.jsxs)("div",{className:e.default.envRow,style:{opacity:A?1:.6},children:[(0,b.jsx)("span",{className:e.default.envName,children:"🐳 Docker Sandbox"}),(0,b.jsx)("span",{className:e.default.envStatus,style:{color:A?"var(--success)":"var(--muted)"},children:A?"Active":"Not Mounted"})]}),(0,b.jsxs)("div",{className:e.default.envRow,style:{opacity:B?1:.6},children:[(0,b.jsx)("span",{className:e.default.envName,children:"🌐 Remote VM (SSH)"}),(0,b.jsx)("span",{className:e.default.envStatus,style:{color:B?"var(--success)":"var(--muted)"},children:B?"Active":"Disconnected"})]})]})]}),(0,b.jsxs)("section",{style:{display:"flex",flexDirection:"column",gap:"0.75rem"},children:[(0,b.jsxs)("button",{className:e.default.quickLaunchBtn,onClick:()=>D("mock"),disabled:n,children:[(0,b.jsx)("span",{children:"⚡"}),(0,b.jsx)("span",{children:"Launch Mock Agent"})]}),(0,b.jsxs)("button",{className:e.default.quickLaunchBtn,onClick:()=>{y(!1),w(!0)},disabled:n,style:{background:"linear-gradient(135deg, hsl(262, 83%, 60%) 0%, hsl(195, 100%, 45%) 100%)",border:"none"},children:[(0,b.jsx)("span",{children:"🤖"}),(0,b.jsx)("span",{children:"Launch Claude PTY"})]}),(0,b.jsxs)("button",{className:e.default.quickLaunchBtn,onClick:()=>{y(!0),w(!0)},disabled:n,style:{background:"linear-gradient(135deg, hsl(170, 72%, 40%) 0%, hsl(195, 100%, 40%) 100%)",border:"none"},children:[(0,b.jsx)("span",{children:"🐳"}),(0,b.jsx)("span",{children:"Launch Docker PTY"})]}),(0,b.jsxs)("button",{className:e.default.quickLaunchBtn,onClick:()=>q(!0),disabled:n,style:{background:"linear-gradient(135deg, hsl(38, 92%, 50%) 0%, hsl(0, 84%, 60%) 100%)",border:"none"},children:[(0,b.jsx)("span",{children:"🌐"}),(0,b.jsx)("span",{children:"Launch SSH PTY"})]}),(0,b.jsxs)("button",{className:e.default.quickLaunchBtn,onClick:()=>{u(!1),s(!0)},disabled:n,style:{background:"linear-gradient(135deg, hsl(210, 80%, 45%) 0%, hsl(262, 80%, 55%) 100%)",border:"none"},children:[(0,b.jsx)("span",{children:"🐍"}),(0,b.jsx)("span",{children:"Launch Aider PTY"})]}),(0,b.jsxs)("button",{className:e.default.quickLaunchBtn,onClick:()=>{u(!0),s(!0)},disabled:n,style:{background:"linear-gradient(135deg, hsl(195, 100%, 40%) 0%, hsl(262, 80%, 55%) 100%)",border:"none"},children:[(0,b.jsx)("span",{children:"🐳"}),(0,b.jsx)("span",{children:"Launch Aider Docker"})]})]}),(0,b.jsxs)("section",{className:"card",style:{padding:"1.5rem",display:"flex",flexDirection:"column",gap:"0.75rem"},children:[(0,b.jsx)("h3",{style:{fontSize:"1rem",fontWeight:700},children:"Quick Actions"}),(0,b.jsxs)("ul",{style:{listStyle:"none",fontSize:"0.875rem",display:"flex",flexDirection:"column",gap:"0.5rem",color:"var(--muted)"},children:[(0,b.jsxs)("li",{style:{display:"flex",justifyContent:"space-between"},children:[(0,b.jsx)("span",{children:"Configure global API Keys"}),(0,b.jsx)("span",{style:{color:"var(--primary)",cursor:"pointer"},children:"→"})]}),(0,b.jsxs)("li",{style:{display:"flex",justifyContent:"space-between"},children:[(0,b.jsx)("span",{children:"Edit rules templates"}),(0,b.jsx)("span",{style:{color:"var(--primary)",cursor:"pointer"},children:"→"})]}),(0,b.jsxs)("li",{style:{display:"flex",justifyContent:"space-between"},children:[(0,b.jsx)("span",{children:"Inspect process locks"}),(0,b.jsx)("span",{style:{color:"var(--primary)",cursor:"pointer"},children:"→"})]})]})]})]})]}),(0,b.jsxs)("footer",{className:e.default.footer,children:[(0,b.jsx)("span",{children:"NeuralLoom v0.2.8 — Experimental AI Orchestrator Bridge"}),(0,b.jsx)("span",{children:"Directory: C:\\Users\\Dave\\OneDrive\\Projects\\JS\\neural-loom"})]}),p&&(0,b.jsx)(h,{onClose:()=>q(!1),onConfirmLaunch:()=>{q(!1),D("claude-ssh")}}),r&&(0,b.jsx)(i,{onClose:()=>s(!1),isDocker:t,onConfirmLaunch:()=>{s(!1),D(t?"aider-docker":"aider")}}),v&&(0,b.jsx)(j,{onClose:()=>w(!1),isDocker:x,onConfirmLaunch:(a,b,c)=>{w(!1),D(x?"claude-docker":"claude",a,b,c)}})]})}])}];
|
|
2
2
|
|
|
3
3
|
//# sourceMappingURL=_0t7oqy6._.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../node_modules/next/src/shared/lib/lazy-dynamic/bailout-to-csr.ts","../../../../node_modules/next/src/shared/lib/lazy-dynamic/dynamic-bailout-to-csr.tsx","../../../../node_modules/next/src/shared/lib/encode-uri-path.ts","../../../../node_modules/next/src/shared/lib/deployment-id.ts","../../../../node_modules/next/src/shared/lib/lazy-dynamic/preload-chunks.tsx","../../../../node_modules/next/src/shared/lib/lazy-dynamic/loadable.tsx","../../../../node_modules/next/src/shared/lib/app-dynamic.tsx","turbopack:///[project]/src/app/page.module.css [app-ssr] (css module)","../../../../src/app/page.tsx"],"sourcesContent":["// This has to be a shared module which is shared between client component error boundary and dynamic component\nconst BAILOUT_TO_CSR = 'BAILOUT_TO_CLIENT_SIDE_RENDERING'\n\n/** An error that should be thrown when we want to bail out to client-side rendering. */\nexport class BailoutToCSRError extends Error {\n public readonly digest = BAILOUT_TO_CSR\n\n constructor(public readonly reason: string) {\n super(`Bail out to client-side rendering: ${reason}`)\n }\n}\n\n/** Checks if a passed argument is an error that is thrown if we want to bail out to client-side rendering. */\nexport function isBailoutToCSRError(err: unknown): err is BailoutToCSRError {\n if (typeof err !== 'object' || err === null || !('digest' in err)) {\n return false\n }\n\n return err.digest === BAILOUT_TO_CSR\n}\n","'use client'\n\nimport type { ReactElement } from 'react'\nimport { BailoutToCSRError } from './bailout-to-csr'\n\ninterface BailoutToCSRProps {\n reason: string\n children: ReactElement\n}\n\n/**\n * If rendered on the server, this component throws an error\n * to signal Next.js that it should bail out to client-side rendering instead.\n */\nexport function BailoutToCSR({ reason, children }: BailoutToCSRProps) {\n if (typeof window === 'undefined') {\n throw new BailoutToCSRError(reason)\n }\n\n return children\n}\n","export function encodeURIPath(file: string) {\n return file\n .split('/')\n .map((p) => encodeURIComponent(p))\n .join('/')\n}\n","let deploymentId: string | undefined\n\nif (typeof window !== 'undefined') {\n deploymentId = document.documentElement.dataset.dplId\n // Immediately remove the attribute to prevent hydration errors (the dplId was inserted into the\n // HTML only), React isn't aware of it at all.\n delete document.documentElement.dataset.dplId\n} else {\n // Client side: replaced with globalThis.NEXT_DEPLOYMENT_ID\n // Server side: left as is or replaced with a string or replaced with false\n deploymentId = process.env.NEXT_DEPLOYMENT_ID || undefined\n}\n\nexport function getDeploymentId(): string | undefined {\n return deploymentId\n}\n\nexport function getDeploymentIdQuery(ampersand = false): string {\n let id = getDeploymentId()\n if (id) {\n return `${ampersand ? '&' : '?'}dpl=${id}`\n }\n return ''\n}\n\nexport function getAssetToken(): string | undefined {\n return (\n process.env.NEXT_IMMUTABLE_ASSET_TOKEN || process.env.NEXT_DEPLOYMENT_ID\n )\n}\n\nexport function getAssetTokenQuery(ampersand = false): string {\n let id = getAssetToken()\n if (id) {\n return `${ampersand ? '&' : '?'}dpl=${id}`\n }\n return ''\n}\n","'use client'\n\nimport { preload } from 'react-dom'\n\nimport { workAsyncStorage } from '../../../server/app-render/work-async-storage.external'\nimport { encodeURIPath } from '../encode-uri-path'\nimport { getAssetTokenQuery } from '../deployment-id'\n\nexport function PreloadChunks({\n moduleIds,\n}: {\n moduleIds: string[] | undefined\n}) {\n // Early return in client compilation and only load requestStore on server side\n if (typeof window !== 'undefined') {\n return null\n }\n\n const workStore = workAsyncStorage.getStore()\n if (workStore === undefined) {\n return null\n }\n\n const allFiles = []\n\n // Search the current dynamic call unique key id in react loadable manifest,\n // and find the corresponding CSS files to preload\n if (workStore.reactLoadableManifest && moduleIds) {\n const manifest = workStore.reactLoadableManifest\n for (const key of moduleIds) {\n if (!manifest[key]) continue\n const chunks = manifest[key].files\n allFiles.push(...chunks)\n }\n }\n\n if (allFiles.length === 0) {\n return null\n }\n\n const query = getAssetTokenQuery()\n\n return (\n <>\n {allFiles.map((chunk) => {\n const href = `${workStore.assetPrefix}/_next/${encodeURIPath(chunk)}${query}`\n const isCss = chunk.endsWith('.css')\n // If it's stylesheet we use `precedence` o help hoist with React Float.\n // For stylesheets we actually need to render the CSS because nothing else is going to do it so it needs to be part of the component tree.\n // The `preload` for stylesheet is not optional.\n if (isCss) {\n return (\n <link\n key={chunk}\n // @ts-ignore\n precedence=\"dynamic\"\n href={href}\n rel=\"stylesheet\"\n as=\"style\"\n nonce={workStore.nonce}\n />\n )\n } else {\n // If it's script we use ReactDOM.preload to preload the resources\n preload(href, {\n as: 'script',\n fetchPriority: 'low',\n nonce: workStore.nonce,\n })\n return null\n }\n })}\n </>\n )\n}\n","import { Suspense, Fragment, lazy } from 'react'\nimport { BailoutToCSR } from './dynamic-bailout-to-csr'\nimport type { ComponentModule } from './types'\nimport { PreloadChunks } from './preload-chunks'\n\n// Normalize loader to return the module as form { default: Component } for `React.lazy`.\n// Also for backward compatible since next/dynamic allows to resolve a component directly with loader\n// Client component reference proxy need to be converted to a module.\nfunction convertModule<P>(\n mod: React.ComponentType<P> | ComponentModule<P> | undefined\n): {\n default: React.ComponentType<P>\n} {\n // Check \"default\" prop before accessing it, as it could be client reference proxy that could break it reference.\n // Cases:\n // mod: { default: Component }\n // mod: Component\n // mod: { default: proxy(Component) }\n // mod: proxy(Component)\n const hasDefault = mod && 'default' in mod\n return {\n default: hasDefault\n ? (mod as ComponentModule<P>).default\n : (mod as React.ComponentType<P>),\n }\n}\n\nconst defaultOptions = {\n loader: () => Promise.resolve(convertModule(() => null)),\n loading: null,\n ssr: true,\n}\n\ninterface LoadableOptions {\n loader?: () => Promise<React.ComponentType<any> | ComponentModule<any>>\n loading?: React.ComponentType<any> | null\n ssr?: boolean\n modules?: string[]\n}\n\nfunction Loadable(options: LoadableOptions) {\n const opts = { ...defaultOptions, ...options }\n const Lazy = lazy(() => opts.loader().then(convertModule))\n const Loading = opts.loading\n\n function LoadableComponent(props: any) {\n const fallbackElement = Loading ? (\n <Loading isLoading={true} pastDelay={true} error={null} />\n ) : null\n\n // If it's non-SSR or provided a loading component, wrap it in a suspense boundary\n const hasSuspenseBoundary = !opts.ssr || !!opts.loading\n const Wrap = hasSuspenseBoundary ? Suspense : Fragment\n const wrapProps = hasSuspenseBoundary ? { fallback: fallbackElement } : {}\n const children = opts.ssr ? (\n <>\n {/* During SSR, we need to preload the CSS from the dynamic component to avoid flash of unstyled content */}\n {typeof window === 'undefined' ? (\n <PreloadChunks moduleIds={opts.modules} />\n ) : null}\n <Lazy {...props} />\n </>\n ) : (\n <BailoutToCSR reason=\"next/dynamic\">\n <Lazy {...props} />\n </BailoutToCSR>\n )\n\n return <Wrap {...wrapProps}>{children}</Wrap>\n }\n\n LoadableComponent.displayName = 'LoadableComponent'\n\n return LoadableComponent\n}\n\nexport default Loadable\n","import type React from 'react'\nimport type { JSX } from 'react'\nimport Loadable from './lazy-dynamic/loadable'\n\nimport type {\n LoadableGeneratedOptions,\n DynamicOptionsLoadingProps,\n Loader,\n LoaderComponent,\n} from './lazy-dynamic/types'\n\nexport {\n type LoadableGeneratedOptions,\n type DynamicOptionsLoadingProps,\n type Loader,\n type LoaderComponent,\n}\n\nexport type DynamicOptions<P = {}> = LoadableGeneratedOptions & {\n loading?: () => JSX.Element | null\n loader?: Loader<P>\n loadableGenerated?: LoadableGeneratedOptions\n modules?: string[]\n ssr?: boolean\n}\n\nexport type LoadableOptions<P = {}> = DynamicOptions<P>\n\nexport type LoadableFn<P = {}> = (\n opts: LoadableOptions<P>\n) => React.ComponentType<P>\n\nexport type LoadableComponent<P = {}> = React.ComponentType<P>\n\nexport default function dynamic<P = {}>(\n dynamicOptions: DynamicOptions<P> | Loader<P>,\n options?: DynamicOptions<P>\n): React.ComponentType<P> {\n const loadableOptions: LoadableOptions<P> = {}\n\n if (typeof dynamicOptions === 'function') {\n loadableOptions.loader = dynamicOptions\n }\n\n const mergedOptions = {\n ...loadableOptions,\n ...options,\n }\n\n return Loadable({\n ...mergedOptions,\n modules: mergedOptions.loadableGenerated?.modules,\n })\n}\n","__turbopack_context__.v({\n \"activeBorder\": \"page-module___8aEwW__activeBorder\",\n \"agentBadge\": \"page-module___8aEwW__agentBadge\",\n \"agentCard\": \"page-module___8aEwW__agentCard\",\n \"agentGrid\": \"page-module___8aEwW__agentGrid\",\n \"agentHeader\": \"page-module___8aEwW__agentHeader\",\n \"agentName\": \"page-module___8aEwW__agentName\",\n \"ansiCyan\": \"page-module___8aEwW__ansiCyan\",\n \"ansiGreen\": \"page-module___8aEwW__ansiGreen\",\n \"ansiMagenta\": \"page-module___8aEwW__ansiMagenta\",\n \"ansiRed\": \"page-module___8aEwW__ansiRed\",\n \"ansiYellow\": \"page-module___8aEwW__ansiYellow\",\n \"cardBody\": \"page-module___8aEwW__cardBody\",\n \"container\": \"page-module___8aEwW__container\",\n \"contextDetails\": \"page-module___8aEwW__contextDetails\",\n \"contextItem\": \"page-module___8aEwW__contextItem\",\n \"contextList\": \"page-module___8aEwW__contextList\",\n \"contextMeta\": \"page-module___8aEwW__contextMeta\",\n \"contextTitle\": \"page-module___8aEwW__contextTitle\",\n \"dashboardGrid\": \"page-module___8aEwW__dashboardGrid\",\n \"envGrid\": \"page-module___8aEwW__envGrid\",\n \"envName\": \"page-module___8aEwW__envName\",\n \"envRow\": \"page-module___8aEwW__envRow\",\n \"envStatus\": \"page-module___8aEwW__envStatus\",\n \"footer\": \"page-module___8aEwW__footer\",\n \"header\": \"page-module___8aEwW__header\",\n \"logoArea\": \"page-module___8aEwW__logoArea\",\n \"mainPanel\": \"page-module___8aEwW__mainPanel\",\n \"pulse\": \"page-module___8aEwW__pulse\",\n \"pulseDot\": \"page-module___8aEwW__pulseDot\",\n \"quickLaunchBtn\": \"page-module___8aEwW__quickLaunchBtn\",\n \"sectionTitle\": \"page-module___8aEwW__sectionTitle\",\n \"sidePanel\": \"page-module___8aEwW__sidePanel\",\n \"statusIndicator\": \"page-module___8aEwW__statusIndicator\",\n \"stoppedBadge\": \"page-module___8aEwW__stoppedBadge\",\n \"subtitle\": \"page-module___8aEwW__subtitle\",\n \"terminalContainer\": \"page-module___8aEwW__terminalContainer\",\n \"terminalInput\": \"page-module___8aEwW__terminalInput\",\n \"terminalInputArea\": \"page-module___8aEwW__terminalInputArea\",\n \"terminalLine\": \"page-module___8aEwW__terminalLine\",\n \"terminalSendBtn\": \"page-module___8aEwW__terminalSendBtn\",\n \"title\": \"page-module___8aEwW__title\",\n});\n","\"use client\";\n\nimport { useEffect, useState } from \"react\";\nimport dynamic from \"next/dynamic\";\nimport styles from \"./page.module.css\";\n\ninterface RunnerStatus {\n id: string;\n name: string;\n type: 'mock' | 'claude' | 'claude-docker' | 'claude-ssh' | 'aider' | 'aider-docker';\n status: 'idle' | 'running' | 'stopped';\n createdAt: string;\n logsCount: number;\n workspaceRoot?: string;\n scopedDirs?: string[];\n}\n\n// Dynamically import TerminalConsole to bypass SSR errors\nconst TerminalConsole = dynamic(() => import(\"./components/TerminalConsole\"), {\n ssr: false,\n loading: () => (\n <div \n style={{ \n height: \"400px\", \n display: \"flex\", \n alignItems: \"center\", \n justifyContent: \"center\", \n backgroundColor: \"#05070a\", \n color: \"var(--muted)\", \n border: \"1px solid var(--border)\", \n borderBottomLeftRadius: \"12px\", \n borderBottomRightRadius: \"12px\" \n }}\n >\n <span>Initializing terminal emulator...</span>\n </div>\n ),\n});\n\n// Dynamically import ContextEditor to bypass SSR errors\nconst ContextEditor = dynamic(() => import(\"./components/ContextEditor\"), {\n ssr: false,\n loading: () => (\n <div \n style={{ \n height: \"280px\", \n display: \"flex\", \n alignItems: \"center\", \n justifyContent: \"center\", \n backgroundColor: \"var(--card)\", \n border: \"1px solid var(--border)\", \n borderRadius: \"12px\", \n marginTop: \"1.5rem\" \n }}\n >\n <span style={{ color: \"var(--muted)\" }}>Initializing prompt editor...</span>\n </div>\n ),\n});\n\n// Dynamically import SshWizard to bypass SSR errors\nconst SshWizard = dynamic(() => import(\"./components/SshWizard\"), {\n ssr: false,\n});\n\n// Dynamically import AiderWizard to bypass SSR errors\nconst AiderWizard = dynamic(() => import(\"./components/AiderWizard\"), {\n ssr: false,\n});\n\n// Dynamically import ClaudeWizard to bypass SSR errors\nconst ClaudeWizard = dynamic(() => import(\"./components/ClaudeWizard\"), {\n ssr: false,\n});\n\n// Dynamically import IdeLayout to bypass SSR errors\nconst IdeLayout = dynamic(() => import(\"./components/IdeLayout\"), {\n ssr: false,\n});\n\nexport default function Home() {\n const [sessions, setSessions] = useState<RunnerStatus[]>([]);\n const [activeSessionId, setActiveSessionId] = useState<string | null>(null);\n const [isLoading, setIsLoading] = useState<boolean>(false);\n const [isSshWizardOpen, setIsSshWizardOpen] = useState<boolean>(false);\n const [isAiderWizardOpen, setIsAiderWizardOpen] = useState<boolean>(false);\n const [isAiderDockerLaunch, setIsAiderDockerLaunch] = useState<boolean>(false);\n const [isClaudeWizardOpen, setIsClaudeWizardOpen] = useState<boolean>(false);\n const [isClaudeDockerLaunch, setIsClaudeDockerLaunch] = useState<boolean>(false);\n\n const activeSession = sessions.find(s => s.id === activeSessionId);\n const isDockerActive = sessions.some(s => (s.type === 'claude-docker' || s.type === 'aider-docker') && s.status === 'running');\n const isSshActive = sessions.some(s => s.type === 'claude-ssh' && s.status === 'running');\n\n // Fetch all sessions on mount & periodically\n const fetchSessions = async () => {\n try {\n const res = await fetch(\"/api/sessions\");\n const data = await res.json();\n if (data.sessions) {\n setSessions(data.sessions);\n }\n } catch (err) {\n console.error(\"Failed to fetch sessions:\", err);\n }\n };\n\n useEffect(() => {\n const initFetch = async () => {\n await fetchSessions();\n };\n initFetch();\n const interval = setInterval(fetchSessions, 4000);\n return () => clearInterval(interval);\n }, []);\n\n // Launch a new Session\n const handleLaunchSession = async (\n type: 'mock' | 'claude' | 'claude-docker' | 'claude-ssh' | 'aider' | 'aider-docker',\n customName?: string,\n customWorkspaceRoot?: string,\n customScopedDirs?: string[]\n ) => {\n setIsLoading(true);\n try {\n let sessionName = customName;\n if (!sessionName) {\n if (type === 'claude') sessionName = \"Claude Local\";\n else if (type === 'claude-docker') sessionName = \"Claude Docker\";\n else if (type === 'claude-ssh') sessionName = \"Claude SSH\";\n else if (type === 'aider') sessionName = \"Aider Local\";\n else if (type === 'aider-docker') sessionName = \"Aider Docker\";\n else if (type === 'mock') sessionName = \"Mock Session\";\n }\n\n const launchBody: {\n type: string;\n name?: string;\n workspaceRoot?: string;\n scopedDirs?: string[];\n } = { \n type, \n name: sessionName, \n workspaceRoot: customWorkspaceRoot, \n scopedDirs: customScopedDirs \n };\n\n if ((type === 'aider' || type === 'aider-docker') && !customWorkspaceRoot) {\n try {\n const configRes = await fetch(\"/api/context/aider\");\n if (configRes.ok) {\n const configData = await configRes.json();\n if (configData.success && configData.config) {\n launchBody.workspaceRoot = configData.config.workspaceRoot;\n launchBody.scopedDirs = configData.config.scopedDirs;\n }\n }\n } catch (err) {\n console.error(\"Failed to load aider configuration before launch:\", err);\n }\n }\n\n const res = await fetch(\"/api/sessions/launch\", {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify(launchBody)\n });\n const data = await res.json();\n if (data.success) {\n await fetchSessions();\n setActiveSessionId(data.session.id);\n }\n } catch (err) {\n console.error(\"Failed to launch session:\", err);\n } finally {\n setIsLoading(false);\n }\n };\n\n // Stop/Disconnect Session\n const handleStopSession = async (id: string, deletePermanently = false) => {\n try {\n const res = await fetch(\"/api/sessions/stop\", {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({ id, delete: deletePermanently })\n });\n const data = await res.json();\n if (data.success) {\n if (deletePermanently && activeSessionId === id) {\n setActiveSessionId(null);\n }\n await fetchSessions();\n }\n } catch (err) {\n console.error(\"Failed to stop session:\", err);\n }\n };\n\n return (\n <div className={styles.container}>\n {/* Header */}\n <header className={styles.header}>\n <div className={styles.logoArea}>\n <h1 className={styles.title}>NeuralLoom</h1>\n <span className={styles.subtitle}>Unified AI Orchestrator & Context Bridge</span>\n </div>\n <div className={styles.statusIndicator}>\n <span className={styles.pulseDot}></span>\n <span>Orchestrator Online</span>\n </div>\n </header>\n\n {/* Main Dashboard Grid or Active Session IDE */}\n {activeSession ? (\n <div style={{ padding: \"0 2rem\", marginBottom: \"2rem\" }}>\n <IdeLayout\n sessionId={activeSession.id}\n workspaceRoot={activeSession.workspaceRoot || \"\"}\n scopedDirs={activeSession.scopedDirs || []}\n onClose={() => setActiveSessionId(null)}\n sessions={sessions}\n onSwitchSession={(id) => setActiveSessionId(id)}\n />\n </div>\n ) : (\n <div className={styles.dashboardGrid}>\n \n {/* Left Panel: Active Agents & Interactive Terminal */}\n <main className={styles.mainPanel}>\n <section>\n <h2 className={styles.sectionTitle}>Active AI Agents</h2>\n \n {sessions.length === 0 ? (\n <div className=\"card\" style={{ padding: \"3rem 1.5rem\", textAlign: \"center\" }}>\n <p style={{ color: \"var(--muted)\", marginBottom: \"1.5rem\" }}>\n No active agent sessions in this workspace. Launch a simulated session to verify the control bridge.\n </p>\n <button \n className={styles.quickLaunchBtn} \n onClick={() => handleLaunchSession('mock')}\n disabled={isLoading}\n style={{ maxWidth: \"240px\", margin: \"0 auto\" }}\n >\n {isLoading ? \"Launching...\" : \"⚡ Launch Simulated Session\"}\n </button>\n </div>\n ) : (\n <div className={styles.agentGrid}>\n {sessions.map(session => (\n <div key={session.id} className={`${styles.agentCard} card ${activeSessionId === session.id ? styles.activeBorder : \"\"}`}>\n <div className={styles.agentHeader}>\n <span className={styles.agentName}>{session.name}</span>\n <span className={`${styles.agentBadge} ${session.status === 'stopped' ? styles.stoppedBadge : \"\"}`}>\n {session.status}\n </span>\n </div>\n <div className={styles.cardBody}>\n <p style={{ fontSize: \"0.825rem\", color: \"var(--muted)\" }}>\n ID: <code style={{ fontSize: \"0.75rem\" }}>{session.id.substring(0, 8)}</code><br />\n Type: {\n session.type === 'claude' ? \"Claude Local PTY\" :\n session.type === 'claude-docker' ? \"Claude Docker PTY\" :\n session.type === 'claude-ssh' ? \"Claude SSH PTY\" :\n session.type === 'aider' ? \"Aider Local PTY\" :\n session.type === 'aider-docker' ? \"Aider Docker PTY\" :\n session.type === 'mock' ? \"Simulated Mock PTY\" : \"Unknown PTY\"\n }<br />\n Logs: {session.logsCount} captured lines\n </p>\n \n <div style={{ display: \"flex\", gap: \"0.5rem\", marginTop: \"1rem\" }}>\n {session.status === 'running' ? (\n <button \n onClick={() => handleStopSession(session.id, false)}\n style={{\n flex: 1,\n padding: \"0.4rem 0.6rem\",\n borderRadius: \"6px\",\n border: \"1px solid var(--danger)\",\n backgroundColor: \"transparent\",\n fontSize: \"0.75rem\",\n fontWeight: 600,\n color: \"var(--danger)\"\n }}\n >Stop</button>\n ) : (\n <button \n onClick={() => handleStopSession(session.id, true)}\n style={{\n flex: 1,\n padding: \"0.4rem 0.6rem\",\n borderRadius: \"6px\",\n border: \"1px solid var(--border)\",\n backgroundColor: \"transparent\",\n fontSize: \"0.75rem\",\n fontWeight: 600,\n color: \"var(--muted)\"\n }}\n >Delete</button>\n )}\n <button \n onClick={() => setActiveSessionId(session.id)}\n style={{\n flex: 2,\n padding: \"0.4rem 0.6rem\",\n borderRadius: \"6px\",\n border: \"none\",\n backgroundColor: activeSessionId === session.id ? \"var(--border-focus)\" : \"var(--primary)\",\n fontSize: \"0.75rem\",\n fontWeight: 600,\n color: \"#fff\"\n }}\n >\n {activeSessionId === session.id ? \"Connected\" : \"Open Session\"}\n </button>\n </div>\n </div>\n </div>\n ))}\n </div>\n )}\n </section>\n\n {/* Interactive Session Terminal Display */}\n {activeSessionId && (\n <section className=\"card\" style={{ display: \"flex\", flexDirection: \"column\", border: \"1px solid var(--border-focus)\" }}>\n <div className={styles.agentHeader} style={{ justifyContent: \"space-between\", background: \"rgba(109, 40, 217, 0.08)\" }}>\n <span style={{ fontWeight: 600, display: \"flex\", alignItems: \"center\", gap: \"0.5rem\" }}>\n 🖥️ Console Bridge — {sessions.find(s => s.id === activeSessionId)?.name}\n </span>\n <button \n onClick={() => setActiveSessionId(null)}\n style={{\n border: \"none\",\n background: \"none\",\n color: \"var(--muted)\",\n cursor: \"pointer\",\n fontSize: \"0.75rem\"\n }}\n >Close Panel ✖</button>\n </div>\n <TerminalConsole sessionId={activeSessionId} />\n </section>\n )}\n\n {/* Context Hub Staging section */}\n <section>\n <h2 className={styles.sectionTitle}>Shared Context Hub & Slash Commands</h2>\n <div className={styles.contextList}>\n <div className={`${styles.contextItem} card`}>\n <div className={styles.contextMeta}>\n <span className={styles.contextTitle}>Staged Context & System Rules (/ccc)</span>\n <span className={styles.contextDetails}>Compiles AGENTS.md guidelines and project files folder hierarchy map.</span>\n </div>\n <button\n onClick={async () => {\n if (!activeSessionId) return;\n await fetch(\"/api/sessions/inject\", {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({ id: activeSessionId, command: \"/ccc\" })\n });\n }}\n disabled={!activeSessionId}\n style={{\n padding: \"0.4rem 0.8rem\",\n borderRadius: \"6px\",\n border: \"1px solid var(--primary)\",\n backgroundColor: \"transparent\",\n color: \"var(--primary)\",\n fontSize: \"0.75rem\",\n fontWeight: 600,\n opacity: activeSessionId ? 1 : 0.5,\n cursor: activeSessionId ? \"pointer\" : \"not-allowed\"\n }}\n >\n 🚀 Mount Context (/ccc)\n </button>\n </div>\n \n <div className={`${styles.contextItem} card`}>\n <div className={styles.contextMeta}>\n <span className={styles.contextTitle}>Staged Developer Prompt (/ccp)</span>\n <span className={styles.contextDetails}>Executes instructions written in .ai/neural-loom/cprompt.md.</span>\n </div>\n <button\n onClick={async () => {\n if (!activeSessionId) return;\n await fetch(\"/api/sessions/inject\", {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({ id: activeSessionId, command: \"/ccp\" })\n });\n }}\n disabled={!activeSessionId}\n style={{\n padding: \"0.4rem 0.8rem\",\n borderRadius: \"6px\",\n border: \"1px solid var(--success)\",\n backgroundColor: \"transparent\",\n color: \"var(--success)\",\n fontSize: \"0.75rem\",\n fontWeight: 600,\n opacity: activeSessionId ? 1 : 0.5,\n cursor: activeSessionId ? \"pointer\" : \"not-allowed\"\n }}\n >\n ⚡ Trigger Prompt (/ccp)\n </button>\n </div>\n </div>\n <ContextEditor />\n </section>\n </main>\n\n {/* Right Panel: Environments & Actions */}\n <aside className={styles.sidePanel}>\n <section>\n <h2 className={styles.sectionTitle}>Execution Environments</h2>\n <div className={styles.envGrid}>\n <div className={styles.envRow}>\n <span className={styles.envName}>💻 Local host OS</span>\n <span className={styles.envStatus} style={{ color: \"var(--success)\" }}>Active</span>\n </div>\n <div className={styles.envRow} style={{ opacity: isDockerActive ? 1 : 0.6 }}>\n <span className={styles.envName}>🐳 Docker Sandbox</span>\n <span className={styles.envStatus} style={{ color: isDockerActive ? \"var(--success)\" : \"var(--muted)\" }}>\n {isDockerActive ? \"Active\" : \"Not Mounted\"}\n </span>\n </div>\n <div className={styles.envRow} style={{ opacity: isSshActive ? 1 : 0.6 }}>\n <span className={styles.envName}>🌐 Remote VM (SSH)</span>\n <span className={styles.envStatus} style={{ color: isSshActive ? \"var(--success)\" : \"var(--muted)\" }}>\n {isSshActive ? \"Active\" : \"Disconnected\"}\n </span>\n </div>\n </div>\n </section>\n\n <section style={{ display: \"flex\", flexDirection: \"column\", gap: \"0.75rem\" }}>\n <button className={styles.quickLaunchBtn} onClick={() => handleLaunchSession('mock')} disabled={isLoading}>\n <span>⚡</span>\n <span>Launch Mock Agent</span>\n </button>\n <button \n className={styles.quickLaunchBtn} \n onClick={() => {\n setIsClaudeDockerLaunch(false);\n setIsClaudeWizardOpen(true);\n }} \n disabled={isLoading}\n style={{\n background: \"linear-gradient(135deg, hsl(262, 83%, 60%) 0%, hsl(195, 100%, 45%) 100%)\",\n border: \"none\"\n }}\n >\n <span>🤖</span>\n <span>Launch Claude PTY</span>\n </button>\n <button \n className={styles.quickLaunchBtn} \n onClick={() => {\n setIsClaudeDockerLaunch(true);\n setIsClaudeWizardOpen(true);\n }} \n disabled={isLoading}\n style={{\n background: \"linear-gradient(135deg, hsl(170, 72%, 40%) 0%, hsl(195, 100%, 40%) 100%)\",\n border: \"none\"\n }}\n >\n <span>🐳</span>\n <span>Launch Docker PTY</span>\n </button>\n <button \n className={styles.quickLaunchBtn} \n onClick={() => setIsSshWizardOpen(true)} \n disabled={isLoading}\n style={{\n background: \"linear-gradient(135deg, hsl(38, 92%, 50%) 0%, hsl(0, 84%, 60%) 100%)\",\n border: \"none\"\n }}\n >\n <span>🌐</span>\n <span>Launch SSH PTY</span>\n </button>\n <button \n className={styles.quickLaunchBtn} \n onClick={() => {\n setIsAiderDockerLaunch(false);\n setIsAiderWizardOpen(true);\n }} \n disabled={isLoading}\n style={{\n background: \"linear-gradient(135deg, hsl(210, 80%, 45%) 0%, hsl(262, 80%, 55%) 100%)\",\n border: \"none\"\n }}\n >\n <span>🐍</span>\n <span>Launch Aider PTY</span>\n </button>\n <button \n className={styles.quickLaunchBtn} \n onClick={() => {\n setIsAiderDockerLaunch(true);\n setIsAiderWizardOpen(true);\n }} \n disabled={isLoading}\n style={{\n background: \"linear-gradient(135deg, hsl(195, 100%, 40%) 0%, hsl(262, 80%, 55%) 100%)\",\n border: \"none\"\n }}\n >\n <span>🐳</span>\n <span>Launch Aider Docker</span>\n </button>\n </section>\n\n <section className=\"card\" style={{ padding: \"1.5rem\", display: \"flex\", flexDirection: \"column\", gap: \"0.75rem\" }}>\n <h3 style={{ fontSize: \"1rem\", fontWeight: 700 }}>Quick Actions</h3>\n <ul style={{ listStyle: \"none\", fontSize: \"0.875rem\", display: \"flex\", flexDirection: \"column\", gap: \"0.5rem\", color: \"var(--muted)\" }}>\n <li style={{ display: \"flex\", justifyContent: \"space-between\" }}>\n <span>Configure global API Keys</span>\n <span style={{ color: \"var(--primary)\", cursor: \"pointer\" }}>→</span>\n </li>\n <li style={{ display: \"flex\", justifyContent: \"space-between\" }}>\n <span>Edit rules templates</span>\n <span style={{ color: \"var(--primary)\", cursor: \"pointer\" }}>→</span>\n </li>\n <li style={{ display: \"flex\", justifyContent: \"space-between\" }}>\n <span>Inspect process locks</span>\n <span style={{ color: \"var(--primary)\", cursor: \"pointer\" }}>→</span>\n </li>\n </ul>\n </section>\n </aside>\n\n </div>\n )}\n\n {/* Footer */}\n <footer className={styles.footer}>\n <span>NeuralLoom v0.1.0 — Experimental AI Orchestrator Bridge</span>\n <span>Directory: C:\\Users\\Dave\\OneDrive\\Projects\\JS\\neural-loom</span>\n </footer>\n\n {isSshWizardOpen && (\n <SshWizard\n onClose={() => setIsSshWizardOpen(false)}\n onConfirmLaunch={() => {\n setIsSshWizardOpen(false);\n handleLaunchSession('claude-ssh');\n }}\n />\n )}\n\n {isAiderWizardOpen && (\n <AiderWizard\n onClose={() => setIsAiderWizardOpen(false)}\n isDocker={isAiderDockerLaunch}\n onConfirmLaunch={() => {\n setIsAiderWizardOpen(false);\n handleLaunchSession(isAiderDockerLaunch ? 'aider-docker' : 'aider');\n }}\n />\n )}\n\n {isClaudeWizardOpen && (\n <ClaudeWizard\n onClose={() => setIsClaudeWizardOpen(false)}\n isDocker={isClaudeDockerLaunch}\n onConfirmLaunch={(name, workspaceRoot, scopedDirs) => {\n setIsClaudeWizardOpen(false);\n handleLaunchSession(isClaudeDockerLaunch ? 'claude-docker' : 'claude', name, workspaceRoot, scopedDirs);\n }}\n />\n )}\n </div>\n );\n}\n"],"names":["BailoutToCSRError","isBailoutToCSRError","BAILOUT_TO_CSR","Error","constructor","reason","digest","err","BailoutToCSR","children","window","encodeURIPath","file","split","map","p","encodeURIComponent","join","getAssetToken","getAssetTokenQuery","getDeploymentId","getDeploymentIdQuery","deploymentId","document","documentElement","dataset","dplId","process","env","NEXT_DEPLOYMENT_ID","undefined","ampersand","id","NEXT_IMMUTABLE_ASSET_TOKEN","PreloadChunks","moduleIds","workStore","workAsyncStorage","getStore","allFiles","reactLoadableManifest","manifest","key","chunks","files","push","length","query","chunk","href","assetPrefix","isCss","endsWith","link","precedence","rel","as","nonce","preload","fetchPriority","convertModule","mod","hasDefault","default","defaultOptions","loader","Promise","resolve","loading","ssr","Loadable","options","opts","Lazy","lazy","then","Loading","LoadableComponent","props","fallbackElement","isLoading","pastDelay","error","hasSuspenseBoundary","Wrap","Suspense","Fragment","wrapProps","fallback","modules","displayName","dynamic","dynamicOptions","loadableOptions","mergedOptions","loadableGenerated","TerminalConsole","style","height","display","alignItems","justifyContent","backgroundColor","color","border","borderBottomLeftRadius","borderBottomRightRadius","ContextEditor","borderRadius","marginTop","SshWizard","AiderWizard","ClaudeWizard","IdeLayout","Home","sessions","setSessions","activeSessionId","setActiveSessionId","setIsLoading","isSshWizardOpen","setIsSshWizardOpen","isAiderWizardOpen","setIsAiderWizardOpen","isAiderDockerLaunch","setIsAiderDockerLaunch","isClaudeWizardOpen","setIsClaudeWizardOpen","isClaudeDockerLaunch","setIsClaudeDockerLaunch","activeSession","find","s","isDockerActive","some","type","status","isSshActive","fetchSessions","res","fetch","data","json","console","initFetch","interval","setInterval","clearInterval","handleLaunchSession","customName","customWorkspaceRoot","customScopedDirs","sessionName","launchBody","name","workspaceRoot","scopedDirs","configRes","ok","configData","success","config","method","headers","body","JSON","stringify","session","handleStopSession","deletePermanently","delete","className","container","header","logoArea","title","subtitle","statusIndicator","pulseDot","padding","marginBottom","sessionId","onClose","onSwitchSession","dashboardGrid","mainPanel","sectionTitle","textAlign","quickLaunchBtn","onClick","disabled","maxWidth","margin","agentGrid","agentCard","activeBorder","agentHeader","agentName","agentBadge","stoppedBadge","cardBody","fontSize","substring","logsCount","gap","flex","fontWeight","flexDirection","background","cursor","contextList","contextItem","contextMeta","contextTitle","contextDetails","command","opacity","sidePanel","envGrid","envRow","envName","envStatus","listStyle","footer","onConfirmLaunch","isDocker"],"mappings":"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","ignoreList":[0,1,2,3,4,5,6]}
|
|
1
|
+
{"version":3,"sources":["../../../../node_modules/next/src/shared/lib/lazy-dynamic/bailout-to-csr.ts","../../../../node_modules/next/src/shared/lib/lazy-dynamic/dynamic-bailout-to-csr.tsx","../../../../node_modules/next/src/shared/lib/encode-uri-path.ts","../../../../node_modules/next/src/shared/lib/deployment-id.ts","../../../../node_modules/next/src/shared/lib/lazy-dynamic/preload-chunks.tsx","../../../../node_modules/next/src/shared/lib/lazy-dynamic/loadable.tsx","../../../../node_modules/next/src/shared/lib/app-dynamic.tsx","turbopack:///[project]/src/app/page.module.css [app-ssr] (css module)","../../../../src/app/page.tsx"],"sourcesContent":["// This has to be a shared module which is shared between client component error boundary and dynamic component\nconst BAILOUT_TO_CSR = 'BAILOUT_TO_CLIENT_SIDE_RENDERING'\n\n/** An error that should be thrown when we want to bail out to client-side rendering. */\nexport class BailoutToCSRError extends Error {\n public readonly digest = BAILOUT_TO_CSR\n\n constructor(public readonly reason: string) {\n super(`Bail out to client-side rendering: ${reason}`)\n }\n}\n\n/** Checks if a passed argument is an error that is thrown if we want to bail out to client-side rendering. */\nexport function isBailoutToCSRError(err: unknown): err is BailoutToCSRError {\n if (typeof err !== 'object' || err === null || !('digest' in err)) {\n return false\n }\n\n return err.digest === BAILOUT_TO_CSR\n}\n","'use client'\n\nimport type { ReactElement } from 'react'\nimport { BailoutToCSRError } from './bailout-to-csr'\n\ninterface BailoutToCSRProps {\n reason: string\n children: ReactElement\n}\n\n/**\n * If rendered on the server, this component throws an error\n * to signal Next.js that it should bail out to client-side rendering instead.\n */\nexport function BailoutToCSR({ reason, children }: BailoutToCSRProps) {\n if (typeof window === 'undefined') {\n throw new BailoutToCSRError(reason)\n }\n\n return children\n}\n","export function encodeURIPath(file: string) {\n return file\n .split('/')\n .map((p) => encodeURIComponent(p))\n .join('/')\n}\n","let deploymentId: string | undefined\n\nif (typeof window !== 'undefined') {\n deploymentId = document.documentElement.dataset.dplId\n // Immediately remove the attribute to prevent hydration errors (the dplId was inserted into the\n // HTML only), React isn't aware of it at all.\n delete document.documentElement.dataset.dplId\n} else {\n // Client side: replaced with globalThis.NEXT_DEPLOYMENT_ID\n // Server side: left as is or replaced with a string or replaced with false\n deploymentId = process.env.NEXT_DEPLOYMENT_ID || undefined\n}\n\nexport function getDeploymentId(): string | undefined {\n return deploymentId\n}\n\nexport function getDeploymentIdQuery(ampersand = false): string {\n let id = getDeploymentId()\n if (id) {\n return `${ampersand ? '&' : '?'}dpl=${id}`\n }\n return ''\n}\n\nexport function getAssetToken(): string | undefined {\n return (\n process.env.NEXT_IMMUTABLE_ASSET_TOKEN || process.env.NEXT_DEPLOYMENT_ID\n )\n}\n\nexport function getAssetTokenQuery(ampersand = false): string {\n let id = getAssetToken()\n if (id) {\n return `${ampersand ? '&' : '?'}dpl=${id}`\n }\n return ''\n}\n","'use client'\n\nimport { preload } from 'react-dom'\n\nimport { workAsyncStorage } from '../../../server/app-render/work-async-storage.external'\nimport { encodeURIPath } from '../encode-uri-path'\nimport { getAssetTokenQuery } from '../deployment-id'\n\nexport function PreloadChunks({\n moduleIds,\n}: {\n moduleIds: string[] | undefined\n}) {\n // Early return in client compilation and only load requestStore on server side\n if (typeof window !== 'undefined') {\n return null\n }\n\n const workStore = workAsyncStorage.getStore()\n if (workStore === undefined) {\n return null\n }\n\n const allFiles = []\n\n // Search the current dynamic call unique key id in react loadable manifest,\n // and find the corresponding CSS files to preload\n if (workStore.reactLoadableManifest && moduleIds) {\n const manifest = workStore.reactLoadableManifest\n for (const key of moduleIds) {\n if (!manifest[key]) continue\n const chunks = manifest[key].files\n allFiles.push(...chunks)\n }\n }\n\n if (allFiles.length === 0) {\n return null\n }\n\n const query = getAssetTokenQuery()\n\n return (\n <>\n {allFiles.map((chunk) => {\n const href = `${workStore.assetPrefix}/_next/${encodeURIPath(chunk)}${query}`\n const isCss = chunk.endsWith('.css')\n // If it's stylesheet we use `precedence` o help hoist with React Float.\n // For stylesheets we actually need to render the CSS because nothing else is going to do it so it needs to be part of the component tree.\n // The `preload` for stylesheet is not optional.\n if (isCss) {\n return (\n <link\n key={chunk}\n // @ts-ignore\n precedence=\"dynamic\"\n href={href}\n rel=\"stylesheet\"\n as=\"style\"\n nonce={workStore.nonce}\n />\n )\n } else {\n // If it's script we use ReactDOM.preload to preload the resources\n preload(href, {\n as: 'script',\n fetchPriority: 'low',\n nonce: workStore.nonce,\n })\n return null\n }\n })}\n </>\n )\n}\n","import { Suspense, Fragment, lazy } from 'react'\nimport { BailoutToCSR } from './dynamic-bailout-to-csr'\nimport type { ComponentModule } from './types'\nimport { PreloadChunks } from './preload-chunks'\n\n// Normalize loader to return the module as form { default: Component } for `React.lazy`.\n// Also for backward compatible since next/dynamic allows to resolve a component directly with loader\n// Client component reference proxy need to be converted to a module.\nfunction convertModule<P>(\n mod: React.ComponentType<P> | ComponentModule<P> | undefined\n): {\n default: React.ComponentType<P>\n} {\n // Check \"default\" prop before accessing it, as it could be client reference proxy that could break it reference.\n // Cases:\n // mod: { default: Component }\n // mod: Component\n // mod: { default: proxy(Component) }\n // mod: proxy(Component)\n const hasDefault = mod && 'default' in mod\n return {\n default: hasDefault\n ? (mod as ComponentModule<P>).default\n : (mod as React.ComponentType<P>),\n }\n}\n\nconst defaultOptions = {\n loader: () => Promise.resolve(convertModule(() => null)),\n loading: null,\n ssr: true,\n}\n\ninterface LoadableOptions {\n loader?: () => Promise<React.ComponentType<any> | ComponentModule<any>>\n loading?: React.ComponentType<any> | null\n ssr?: boolean\n modules?: string[]\n}\n\nfunction Loadable(options: LoadableOptions) {\n const opts = { ...defaultOptions, ...options }\n const Lazy = lazy(() => opts.loader().then(convertModule))\n const Loading = opts.loading\n\n function LoadableComponent(props: any) {\n const fallbackElement = Loading ? (\n <Loading isLoading={true} pastDelay={true} error={null} />\n ) : null\n\n // If it's non-SSR or provided a loading component, wrap it in a suspense boundary\n const hasSuspenseBoundary = !opts.ssr || !!opts.loading\n const Wrap = hasSuspenseBoundary ? Suspense : Fragment\n const wrapProps = hasSuspenseBoundary ? { fallback: fallbackElement } : {}\n const children = opts.ssr ? (\n <>\n {/* During SSR, we need to preload the CSS from the dynamic component to avoid flash of unstyled content */}\n {typeof window === 'undefined' ? (\n <PreloadChunks moduleIds={opts.modules} />\n ) : null}\n <Lazy {...props} />\n </>\n ) : (\n <BailoutToCSR reason=\"next/dynamic\">\n <Lazy {...props} />\n </BailoutToCSR>\n )\n\n return <Wrap {...wrapProps}>{children}</Wrap>\n }\n\n LoadableComponent.displayName = 'LoadableComponent'\n\n return LoadableComponent\n}\n\nexport default Loadable\n","import type React from 'react'\nimport type { JSX } from 'react'\nimport Loadable from './lazy-dynamic/loadable'\n\nimport type {\n LoadableGeneratedOptions,\n DynamicOptionsLoadingProps,\n Loader,\n LoaderComponent,\n} from './lazy-dynamic/types'\n\nexport {\n type LoadableGeneratedOptions,\n type DynamicOptionsLoadingProps,\n type Loader,\n type LoaderComponent,\n}\n\nexport type DynamicOptions<P = {}> = LoadableGeneratedOptions & {\n loading?: () => JSX.Element | null\n loader?: Loader<P>\n loadableGenerated?: LoadableGeneratedOptions\n modules?: string[]\n ssr?: boolean\n}\n\nexport type LoadableOptions<P = {}> = DynamicOptions<P>\n\nexport type LoadableFn<P = {}> = (\n opts: LoadableOptions<P>\n) => React.ComponentType<P>\n\nexport type LoadableComponent<P = {}> = React.ComponentType<P>\n\nexport default function dynamic<P = {}>(\n dynamicOptions: DynamicOptions<P> | Loader<P>,\n options?: DynamicOptions<P>\n): React.ComponentType<P> {\n const loadableOptions: LoadableOptions<P> = {}\n\n if (typeof dynamicOptions === 'function') {\n loadableOptions.loader = dynamicOptions\n }\n\n const mergedOptions = {\n ...loadableOptions,\n ...options,\n }\n\n return Loadable({\n ...mergedOptions,\n modules: mergedOptions.loadableGenerated?.modules,\n })\n}\n","__turbopack_context__.v({\n \"activeBorder\": \"page-module___8aEwW__activeBorder\",\n \"agentBadge\": \"page-module___8aEwW__agentBadge\",\n \"agentCard\": \"page-module___8aEwW__agentCard\",\n \"agentGrid\": \"page-module___8aEwW__agentGrid\",\n \"agentHeader\": \"page-module___8aEwW__agentHeader\",\n \"agentName\": \"page-module___8aEwW__agentName\",\n \"ansiCyan\": \"page-module___8aEwW__ansiCyan\",\n \"ansiGreen\": \"page-module___8aEwW__ansiGreen\",\n \"ansiMagenta\": \"page-module___8aEwW__ansiMagenta\",\n \"ansiRed\": \"page-module___8aEwW__ansiRed\",\n \"ansiYellow\": \"page-module___8aEwW__ansiYellow\",\n \"cardBody\": \"page-module___8aEwW__cardBody\",\n \"container\": \"page-module___8aEwW__container\",\n \"contextDetails\": \"page-module___8aEwW__contextDetails\",\n \"contextItem\": \"page-module___8aEwW__contextItem\",\n \"contextList\": \"page-module___8aEwW__contextList\",\n \"contextMeta\": \"page-module___8aEwW__contextMeta\",\n \"contextTitle\": \"page-module___8aEwW__contextTitle\",\n \"dashboardGrid\": \"page-module___8aEwW__dashboardGrid\",\n \"envGrid\": \"page-module___8aEwW__envGrid\",\n \"envName\": \"page-module___8aEwW__envName\",\n \"envRow\": \"page-module___8aEwW__envRow\",\n \"envStatus\": \"page-module___8aEwW__envStatus\",\n \"footer\": \"page-module___8aEwW__footer\",\n \"header\": \"page-module___8aEwW__header\",\n \"logoArea\": \"page-module___8aEwW__logoArea\",\n \"mainPanel\": \"page-module___8aEwW__mainPanel\",\n \"pulse\": \"page-module___8aEwW__pulse\",\n \"pulseDot\": \"page-module___8aEwW__pulseDot\",\n \"quickLaunchBtn\": \"page-module___8aEwW__quickLaunchBtn\",\n \"sectionTitle\": \"page-module___8aEwW__sectionTitle\",\n \"sidePanel\": \"page-module___8aEwW__sidePanel\",\n \"statusIndicator\": \"page-module___8aEwW__statusIndicator\",\n \"stoppedBadge\": \"page-module___8aEwW__stoppedBadge\",\n \"subtitle\": \"page-module___8aEwW__subtitle\",\n \"terminalContainer\": \"page-module___8aEwW__terminalContainer\",\n \"terminalInput\": \"page-module___8aEwW__terminalInput\",\n \"terminalInputArea\": \"page-module___8aEwW__terminalInputArea\",\n \"terminalLine\": \"page-module___8aEwW__terminalLine\",\n \"terminalSendBtn\": \"page-module___8aEwW__terminalSendBtn\",\n \"title\": \"page-module___8aEwW__title\",\n});\n","\"use client\";\n\nimport { useEffect, useState } from \"react\";\nimport dynamic from \"next/dynamic\";\nimport styles from \"./page.module.css\";\n\ninterface RunnerStatus {\n id: string;\n name: string;\n type: 'mock' | 'claude' | 'claude-docker' | 'claude-ssh' | 'aider' | 'aider-docker';\n status: 'idle' | 'running' | 'stopped';\n createdAt: string;\n logsCount: number;\n workspaceRoot?: string;\n scopedDirs?: string[];\n}\n\n// Dynamically import TerminalConsole to bypass SSR errors\nconst TerminalConsole = dynamic(() => import(\"./components/TerminalConsole\"), {\n ssr: false,\n loading: () => (\n <div \n style={{ \n height: \"400px\", \n display: \"flex\", \n alignItems: \"center\", \n justifyContent: \"center\", \n backgroundColor: \"#05070a\", \n color: \"var(--muted)\", \n border: \"1px solid var(--border)\", \n borderBottomLeftRadius: \"12px\", \n borderBottomRightRadius: \"12px\" \n }}\n >\n <span>Initializing terminal emulator...</span>\n </div>\n ),\n});\n\n// Dynamically import ContextEditor to bypass SSR errors\nconst ContextEditor = dynamic(() => import(\"./components/ContextEditor\"), {\n ssr: false,\n loading: () => (\n <div \n style={{ \n height: \"280px\", \n display: \"flex\", \n alignItems: \"center\", \n justifyContent: \"center\", \n backgroundColor: \"var(--card)\", \n border: \"1px solid var(--border)\", \n borderRadius: \"12px\", \n marginTop: \"1.5rem\" \n }}\n >\n <span style={{ color: \"var(--muted)\" }}>Initializing prompt editor...</span>\n </div>\n ),\n});\n\n// Dynamically import SshWizard to bypass SSR errors\nconst SshWizard = dynamic(() => import(\"./components/SshWizard\"), {\n ssr: false,\n});\n\n// Dynamically import AiderWizard to bypass SSR errors\nconst AiderWizard = dynamic(() => import(\"./components/AiderWizard\"), {\n ssr: false,\n});\n\n// Dynamically import ClaudeWizard to bypass SSR errors\nconst ClaudeWizard = dynamic(() => import(\"./components/ClaudeWizard\"), {\n ssr: false,\n});\n\n// Dynamically import IdeLayout to bypass SSR errors\nconst IdeLayout = dynamic(() => import(\"./components/IdeLayout\"), {\n ssr: false,\n});\n\nexport default function Home() {\n const [sessions, setSessions] = useState<RunnerStatus[]>([]);\n const [activeSessionId, setActiveSessionId] = useState<string | null>(null);\n const [isLoading, setIsLoading] = useState<boolean>(false);\n const [isSshWizardOpen, setIsSshWizardOpen] = useState<boolean>(false);\n const [isAiderWizardOpen, setIsAiderWizardOpen] = useState<boolean>(false);\n const [isAiderDockerLaunch, setIsAiderDockerLaunch] = useState<boolean>(false);\n const [isClaudeWizardOpen, setIsClaudeWizardOpen] = useState<boolean>(false);\n const [isClaudeDockerLaunch, setIsClaudeDockerLaunch] = useState<boolean>(false);\n\n const activeSession = sessions.find(s => s.id === activeSessionId);\n const isDockerActive = sessions.some(s => (s.type === 'claude-docker' || s.type === 'aider-docker') && s.status === 'running');\n const isSshActive = sessions.some(s => s.type === 'claude-ssh' && s.status === 'running');\n\n // Fetch all sessions on mount & periodically\n const fetchSessions = async () => {\n try {\n const res = await fetch(\"/api/sessions\");\n const data = await res.json();\n if (data.sessions) {\n setSessions(data.sessions);\n }\n } catch (err) {\n console.error(\"Failed to fetch sessions:\", err);\n }\n };\n\n useEffect(() => {\n const initFetch = async () => {\n await fetchSessions();\n };\n initFetch();\n const interval = setInterval(fetchSessions, 4000);\n return () => clearInterval(interval);\n }, []);\n\n // Launch a new Session\n const handleLaunchSession = async (\n type: 'mock' | 'claude' | 'claude-docker' | 'claude-ssh' | 'aider' | 'aider-docker',\n customName?: string,\n customWorkspaceRoot?: string,\n customScopedDirs?: string[]\n ) => {\n setIsLoading(true);\n try {\n let sessionName = customName;\n if (!sessionName) {\n if (type === 'claude') sessionName = \"Claude Local\";\n else if (type === 'claude-docker') sessionName = \"Claude Docker\";\n else if (type === 'claude-ssh') sessionName = \"Claude SSH\";\n else if (type === 'aider') sessionName = \"Aider Local\";\n else if (type === 'aider-docker') sessionName = \"Aider Docker\";\n else if (type === 'mock') sessionName = \"Mock Session\";\n }\n\n const launchBody: {\n type: string;\n name?: string;\n workspaceRoot?: string;\n scopedDirs?: string[];\n } = { \n type, \n name: sessionName, \n workspaceRoot: customWorkspaceRoot, \n scopedDirs: customScopedDirs \n };\n\n if ((type === 'aider' || type === 'aider-docker') && !customWorkspaceRoot) {\n try {\n const configRes = await fetch(\"/api/context/aider\");\n if (configRes.ok) {\n const configData = await configRes.json();\n if (configData.success && configData.config) {\n launchBody.workspaceRoot = configData.config.workspaceRoot;\n launchBody.scopedDirs = configData.config.scopedDirs;\n }\n }\n } catch (err) {\n console.error(\"Failed to load aider configuration before launch:\", err);\n }\n }\n\n const res = await fetch(\"/api/sessions/launch\", {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify(launchBody)\n });\n const data = await res.json();\n if (data.success) {\n await fetchSessions();\n setActiveSessionId(data.session.id);\n }\n } catch (err) {\n console.error(\"Failed to launch session:\", err);\n } finally {\n setIsLoading(false);\n }\n };\n\n // Stop/Disconnect Session\n const handleStopSession = async (id: string, deletePermanently = false) => {\n try {\n const res = await fetch(\"/api/sessions/stop\", {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({ id, delete: deletePermanently })\n });\n const data = await res.json();\n if (data.success) {\n if (deletePermanently && activeSessionId === id) {\n setActiveSessionId(null);\n }\n await fetchSessions();\n }\n } catch (err) {\n console.error(\"Failed to stop session:\", err);\n }\n };\n\n return (\n <div className={styles.container}>\n {/* Header */}\n <header className={styles.header}>\n <div className={styles.logoArea}>\n <h1 className={styles.title}>NeuralLoom</h1>\n <span className={styles.subtitle}>Unified AI Orchestrator & Context Bridge</span>\n </div>\n <div className={styles.statusIndicator}>\n <span className={styles.pulseDot}></span>\n <span>Orchestrator Online</span>\n </div>\n </header>\n\n {/* Main Dashboard Grid or Active Session IDE */}\n {activeSession ? (\n <div style={{ padding: \"0 2rem\", marginBottom: \"2rem\" }}>\n <IdeLayout\n sessionId={activeSession.id}\n workspaceRoot={activeSession.workspaceRoot || \"\"}\n scopedDirs={activeSession.scopedDirs || []}\n onClose={() => setActiveSessionId(null)}\n sessions={sessions}\n onSwitchSession={(id) => setActiveSessionId(id)}\n />\n </div>\n ) : (\n <div className={styles.dashboardGrid}>\n \n {/* Left Panel: Active Agents & Interactive Terminal */}\n <main className={styles.mainPanel}>\n <section>\n <h2 className={styles.sectionTitle}>Active AI Agents</h2>\n \n {sessions.length === 0 ? (\n <div className=\"card\" style={{ padding: \"3rem 1.5rem\", textAlign: \"center\" }}>\n <p style={{ color: \"var(--muted)\", marginBottom: \"1.5rem\" }}>\n No active agent sessions in this workspace. Launch a simulated session to verify the control bridge.\n </p>\n <button \n className={styles.quickLaunchBtn} \n onClick={() => handleLaunchSession('mock')}\n disabled={isLoading}\n style={{ maxWidth: \"240px\", margin: \"0 auto\" }}\n >\n {isLoading ? \"Launching...\" : \"⚡ Launch Simulated Session\"}\n </button>\n </div>\n ) : (\n <div className={styles.agentGrid}>\n {sessions.map(session => (\n <div key={session.id} className={`${styles.agentCard} card ${activeSessionId === session.id ? styles.activeBorder : \"\"}`}>\n <div className={styles.agentHeader}>\n <span className={styles.agentName}>{session.name}</span>\n <span className={`${styles.agentBadge} ${session.status === 'stopped' ? styles.stoppedBadge : \"\"}`}>\n {session.status}\n </span>\n </div>\n <div className={styles.cardBody}>\n <p style={{ fontSize: \"0.825rem\", color: \"var(--muted)\" }}>\n ID: <code style={{ fontSize: \"0.75rem\" }}>{session.id.substring(0, 8)}</code><br />\n Type: {\n session.type === 'claude' ? \"Claude Local PTY\" :\n session.type === 'claude-docker' ? \"Claude Docker PTY\" :\n session.type === 'claude-ssh' ? \"Claude SSH PTY\" :\n session.type === 'aider' ? \"Aider Local PTY\" :\n session.type === 'aider-docker' ? \"Aider Docker PTY\" :\n session.type === 'mock' ? \"Simulated Mock PTY\" : \"Unknown PTY\"\n }<br />\n Logs: {session.logsCount} captured lines\n </p>\n \n <div style={{ display: \"flex\", gap: \"0.5rem\", marginTop: \"1rem\" }}>\n {session.status === 'running' ? (\n <button \n onClick={() => handleStopSession(session.id, false)}\n style={{\n flex: 1,\n padding: \"0.4rem 0.6rem\",\n borderRadius: \"6px\",\n border: \"1px solid var(--danger)\",\n backgroundColor: \"transparent\",\n fontSize: \"0.75rem\",\n fontWeight: 600,\n color: \"var(--danger)\"\n }}\n >Stop</button>\n ) : (\n <button \n onClick={() => handleStopSession(session.id, true)}\n style={{\n flex: 1,\n padding: \"0.4rem 0.6rem\",\n borderRadius: \"6px\",\n border: \"1px solid var(--border)\",\n backgroundColor: \"transparent\",\n fontSize: \"0.75rem\",\n fontWeight: 600,\n color: \"var(--muted)\"\n }}\n >Delete</button>\n )}\n <button \n onClick={() => setActiveSessionId(session.id)}\n style={{\n flex: 2,\n padding: \"0.4rem 0.6rem\",\n borderRadius: \"6px\",\n border: \"none\",\n backgroundColor: activeSessionId === session.id ? \"var(--border-focus)\" : \"var(--primary)\",\n fontSize: \"0.75rem\",\n fontWeight: 600,\n color: \"#fff\"\n }}\n >\n {activeSessionId === session.id ? \"Connected\" : \"Open Session\"}\n </button>\n </div>\n </div>\n </div>\n ))}\n </div>\n )}\n </section>\n\n {/* Interactive Session Terminal Display */}\n {activeSessionId && (\n <section className=\"card\" style={{ display: \"flex\", flexDirection: \"column\", border: \"1px solid var(--border-focus)\" }}>\n <div className={styles.agentHeader} style={{ justifyContent: \"space-between\", background: \"rgba(109, 40, 217, 0.08)\" }}>\n <span style={{ fontWeight: 600, display: \"flex\", alignItems: \"center\", gap: \"0.5rem\" }}>\n 🖥️ Console Bridge — {sessions.find(s => s.id === activeSessionId)?.name}\n </span>\n <button \n onClick={() => setActiveSessionId(null)}\n style={{\n border: \"none\",\n background: \"none\",\n color: \"var(--muted)\",\n cursor: \"pointer\",\n fontSize: \"0.75rem\"\n }}\n >Close Panel ✖</button>\n </div>\n <TerminalConsole sessionId={activeSessionId} />\n </section>\n )}\n\n {/* Context Hub Staging section */}\n <section>\n <h2 className={styles.sectionTitle}>Shared Context Hub & Slash Commands</h2>\n <div className={styles.contextList}>\n <div className={`${styles.contextItem} card`}>\n <div className={styles.contextMeta}>\n <span className={styles.contextTitle}>Staged Context & System Rules (/ccc)</span>\n <span className={styles.contextDetails}>Compiles AGENTS.md guidelines and project files folder hierarchy map.</span>\n </div>\n <button\n onClick={async () => {\n if (!activeSessionId) return;\n await fetch(\"/api/sessions/inject\", {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({ id: activeSessionId, command: \"/ccc\" })\n });\n }}\n disabled={!activeSessionId}\n style={{\n padding: \"0.4rem 0.8rem\",\n borderRadius: \"6px\",\n border: \"1px solid var(--primary)\",\n backgroundColor: \"transparent\",\n color: \"var(--primary)\",\n fontSize: \"0.75rem\",\n fontWeight: 600,\n opacity: activeSessionId ? 1 : 0.5,\n cursor: activeSessionId ? \"pointer\" : \"not-allowed\"\n }}\n >\n 🚀 Mount Context (/ccc)\n </button>\n </div>\n \n <div className={`${styles.contextItem} card`}>\n <div className={styles.contextMeta}>\n <span className={styles.contextTitle}>Staged Developer Prompt (/ccp)</span>\n <span className={styles.contextDetails}>Executes instructions written in .ai/neural-loom/cprompt.md.</span>\n </div>\n <button\n onClick={async () => {\n if (!activeSessionId) return;\n await fetch(\"/api/sessions/inject\", {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({ id: activeSessionId, command: \"/ccp\" })\n });\n }}\n disabled={!activeSessionId}\n style={{\n padding: \"0.4rem 0.8rem\",\n borderRadius: \"6px\",\n border: \"1px solid var(--success)\",\n backgroundColor: \"transparent\",\n color: \"var(--success)\",\n fontSize: \"0.75rem\",\n fontWeight: 600,\n opacity: activeSessionId ? 1 : 0.5,\n cursor: activeSessionId ? \"pointer\" : \"not-allowed\"\n }}\n >\n ⚡ Trigger Prompt (/ccp)\n </button>\n </div>\n </div>\n <ContextEditor />\n </section>\n </main>\n\n {/* Right Panel: Environments & Actions */}\n <aside className={styles.sidePanel}>\n <section>\n <h2 className={styles.sectionTitle}>Execution Environments</h2>\n <div className={styles.envGrid}>\n <div className={styles.envRow}>\n <span className={styles.envName}>💻 Local host OS</span>\n <span className={styles.envStatus} style={{ color: \"var(--success)\" }}>Active</span>\n </div>\n <div className={styles.envRow} style={{ opacity: isDockerActive ? 1 : 0.6 }}>\n <span className={styles.envName}>🐳 Docker Sandbox</span>\n <span className={styles.envStatus} style={{ color: isDockerActive ? \"var(--success)\" : \"var(--muted)\" }}>\n {isDockerActive ? \"Active\" : \"Not Mounted\"}\n </span>\n </div>\n <div className={styles.envRow} style={{ opacity: isSshActive ? 1 : 0.6 }}>\n <span className={styles.envName}>🌐 Remote VM (SSH)</span>\n <span className={styles.envStatus} style={{ color: isSshActive ? \"var(--success)\" : \"var(--muted)\" }}>\n {isSshActive ? \"Active\" : \"Disconnected\"}\n </span>\n </div>\n </div>\n </section>\n\n <section style={{ display: \"flex\", flexDirection: \"column\", gap: \"0.75rem\" }}>\n <button className={styles.quickLaunchBtn} onClick={() => handleLaunchSession('mock')} disabled={isLoading}>\n <span>⚡</span>\n <span>Launch Mock Agent</span>\n </button>\n <button \n className={styles.quickLaunchBtn} \n onClick={() => {\n setIsClaudeDockerLaunch(false);\n setIsClaudeWizardOpen(true);\n }} \n disabled={isLoading}\n style={{\n background: \"linear-gradient(135deg, hsl(262, 83%, 60%) 0%, hsl(195, 100%, 45%) 100%)\",\n border: \"none\"\n }}\n >\n <span>🤖</span>\n <span>Launch Claude PTY</span>\n </button>\n <button \n className={styles.quickLaunchBtn} \n onClick={() => {\n setIsClaudeDockerLaunch(true);\n setIsClaudeWizardOpen(true);\n }} \n disabled={isLoading}\n style={{\n background: \"linear-gradient(135deg, hsl(170, 72%, 40%) 0%, hsl(195, 100%, 40%) 100%)\",\n border: \"none\"\n }}\n >\n <span>🐳</span>\n <span>Launch Docker PTY</span>\n </button>\n <button \n className={styles.quickLaunchBtn} \n onClick={() => setIsSshWizardOpen(true)} \n disabled={isLoading}\n style={{\n background: \"linear-gradient(135deg, hsl(38, 92%, 50%) 0%, hsl(0, 84%, 60%) 100%)\",\n border: \"none\"\n }}\n >\n <span>🌐</span>\n <span>Launch SSH PTY</span>\n </button>\n <button \n className={styles.quickLaunchBtn} \n onClick={() => {\n setIsAiderDockerLaunch(false);\n setIsAiderWizardOpen(true);\n }} \n disabled={isLoading}\n style={{\n background: \"linear-gradient(135deg, hsl(210, 80%, 45%) 0%, hsl(262, 80%, 55%) 100%)\",\n border: \"none\"\n }}\n >\n <span>🐍</span>\n <span>Launch Aider PTY</span>\n </button>\n <button \n className={styles.quickLaunchBtn} \n onClick={() => {\n setIsAiderDockerLaunch(true);\n setIsAiderWizardOpen(true);\n }} \n disabled={isLoading}\n style={{\n background: \"linear-gradient(135deg, hsl(195, 100%, 40%) 0%, hsl(262, 80%, 55%) 100%)\",\n border: \"none\"\n }}\n >\n <span>🐳</span>\n <span>Launch Aider Docker</span>\n </button>\n </section>\n\n <section className=\"card\" style={{ padding: \"1.5rem\", display: \"flex\", flexDirection: \"column\", gap: \"0.75rem\" }}>\n <h3 style={{ fontSize: \"1rem\", fontWeight: 700 }}>Quick Actions</h3>\n <ul style={{ listStyle: \"none\", fontSize: \"0.875rem\", display: \"flex\", flexDirection: \"column\", gap: \"0.5rem\", color: \"var(--muted)\" }}>\n <li style={{ display: \"flex\", justifyContent: \"space-between\" }}>\n <span>Configure global API Keys</span>\n <span style={{ color: \"var(--primary)\", cursor: \"pointer\" }}>→</span>\n </li>\n <li style={{ display: \"flex\", justifyContent: \"space-between\" }}>\n <span>Edit rules templates</span>\n <span style={{ color: \"var(--primary)\", cursor: \"pointer\" }}>→</span>\n </li>\n <li style={{ display: \"flex\", justifyContent: \"space-between\" }}>\n <span>Inspect process locks</span>\n <span style={{ color: \"var(--primary)\", cursor: \"pointer\" }}>→</span>\n </li>\n </ul>\n </section>\n </aside>\n\n </div>\n )}\n\n {/* Footer */}\n <footer className={styles.footer}>\n <span>NeuralLoom v0.2.8 — Experimental AI Orchestrator Bridge</span>\n <span>Directory: C:\\Users\\Dave\\OneDrive\\Projects\\JS\\neural-loom</span>\n </footer>\n\n {isSshWizardOpen && (\n <SshWizard\n onClose={() => setIsSshWizardOpen(false)}\n onConfirmLaunch={() => {\n setIsSshWizardOpen(false);\n handleLaunchSession('claude-ssh');\n }}\n />\n )}\n\n {isAiderWizardOpen && (\n <AiderWizard\n onClose={() => setIsAiderWizardOpen(false)}\n isDocker={isAiderDockerLaunch}\n onConfirmLaunch={() => {\n setIsAiderWizardOpen(false);\n handleLaunchSession(isAiderDockerLaunch ? 'aider-docker' : 'aider');\n }}\n />\n )}\n\n {isClaudeWizardOpen && (\n <ClaudeWizard\n onClose={() => setIsClaudeWizardOpen(false)}\n isDocker={isClaudeDockerLaunch}\n onConfirmLaunch={(name, workspaceRoot, scopedDirs) => {\n setIsClaudeWizardOpen(false);\n handleLaunchSession(isClaudeDockerLaunch ? 'claude-docker' : 'claude', name, workspaceRoot, scopedDirs);\n }}\n />\n )}\n </div>\n );\n}\n"],"names":["BailoutToCSRError","isBailoutToCSRError","BAILOUT_TO_CSR","Error","constructor","reason","digest","err","BailoutToCSR","children","window","encodeURIPath","file","split","map","p","encodeURIComponent","join","getAssetToken","getAssetTokenQuery","getDeploymentId","getDeploymentIdQuery","deploymentId","document","documentElement","dataset","dplId","process","env","NEXT_DEPLOYMENT_ID","undefined","ampersand","id","NEXT_IMMUTABLE_ASSET_TOKEN","PreloadChunks","moduleIds","workStore","workAsyncStorage","getStore","allFiles","reactLoadableManifest","manifest","key","chunks","files","push","length","query","chunk","href","assetPrefix","isCss","endsWith","link","precedence","rel","as","nonce","preload","fetchPriority","convertModule","mod","hasDefault","default","defaultOptions","loader","Promise","resolve","loading","ssr","Loadable","options","opts","Lazy","lazy","then","Loading","LoadableComponent","props","fallbackElement","isLoading","pastDelay","error","hasSuspenseBoundary","Wrap","Suspense","Fragment","wrapProps","fallback","modules","displayName","dynamic","dynamicOptions","loadableOptions","mergedOptions","loadableGenerated","TerminalConsole","style","height","display","alignItems","justifyContent","backgroundColor","color","border","borderBottomLeftRadius","borderBottomRightRadius","ContextEditor","borderRadius","marginTop","SshWizard","AiderWizard","ClaudeWizard","IdeLayout","Home","sessions","setSessions","activeSessionId","setActiveSessionId","setIsLoading","isSshWizardOpen","setIsSshWizardOpen","isAiderWizardOpen","setIsAiderWizardOpen","isAiderDockerLaunch","setIsAiderDockerLaunch","isClaudeWizardOpen","setIsClaudeWizardOpen","isClaudeDockerLaunch","setIsClaudeDockerLaunch","activeSession","find","s","isDockerActive","some","type","status","isSshActive","fetchSessions","res","fetch","data","json","console","initFetch","interval","setInterval","clearInterval","handleLaunchSession","customName","customWorkspaceRoot","customScopedDirs","sessionName","launchBody","name","workspaceRoot","scopedDirs","configRes","ok","configData","success","config","method","headers","body","JSON","stringify","session","handleStopSession","deletePermanently","delete","className","container","header","logoArea","title","subtitle","statusIndicator","pulseDot","padding","marginBottom","sessionId","onClose","onSwitchSession","dashboardGrid","mainPanel","sectionTitle","textAlign","quickLaunchBtn","onClick","disabled","maxWidth","margin","agentGrid","agentCard","activeBorder","agentHeader","agentName","agentBadge","stoppedBadge","cardBody","fontSize","substring","logsCount","gap","flex","fontWeight","flexDirection","background","cursor","contextList","contextItem","contextMeta","contextTitle","contextDetails","command","opacity","sidePanel","envGrid","envRow","envName","envStatus","listStyle","footer","onConfirmLaunch","isDocker"],"mappings":"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","ignoreList":[0,1,2,3,4,5,6]}
|
|
@@ -7,9 +7,9 @@ globalThis.__BUILD_MANIFEST = {
|
|
|
7
7
|
"static/chunks/03~yq9q893hmn.js"
|
|
8
8
|
],
|
|
9
9
|
"lowPriorityFiles": [
|
|
10
|
-
"static/
|
|
11
|
-
"static/
|
|
12
|
-
"static/
|
|
10
|
+
"static/2HGCuinlX_PNFgwkjIVKe/_buildManifest.js",
|
|
11
|
+
"static/2HGCuinlX_PNFgwkjIVKe/_ssgManifest.js",
|
|
12
|
+
"static/2HGCuinlX_PNFgwkjIVKe/_clientMiddlewareManifest.js"
|
|
13
13
|
],
|
|
14
14
|
"rootMainFiles": [
|
|
15
15
|
"static/chunks/0fpki3y6aj230.js",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
<!DOCTYPE html><html lang="en" class="geist_a71539c9-module__T19VSG__variable geist_mono_8d43a2aa-module__8Li5zG__variable"><head><meta charSet="utf-8"/><meta name="viewport" content="width=device-width, initial-scale=1"/><link rel="stylesheet" href="/_next/static/chunks/139c54uo1w7.4.css" data-precedence="next"/><link rel="preload" as="script" fetchPriority="low" href="/_next/static/chunks/0fpki3y6aj230.js"/><script src="/_next/static/chunks/140ovxvjat1ch.js" async=""></script><script src="/_next/static/chunks/07lhk_q6pmm3r.js" async=""></script><script src="/_next/static/chunks/turbopack-08fpdsd.-ns2y.js" async=""></script><script src="/_next/static/chunks/0dbhjjzl8qfwv.js" async=""></script><meta name="robots" content="noindex"/><meta name="next-size-adjust" content=""/><title>404: This page could not be found.</title><title>NeuralLoom - Unified AI Agent Orchestrator & Context Bridge</title><meta name="description" content="Advanced console dashboard and context staging manager for Claude Code and simulated AI agents."/><link rel="icon" href="/favicon.ico?favicon.0x3dzn~oxb6tn.ico" sizes="256x256" type="image/x-icon"/><script src="/_next/static/chunks/03~yq9q893hmn.js" noModule=""></script></head><body><div hidden=""><!--$--><!--/$--></div><div style="font-family:system-ui,"Segoe UI",Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji";height:100vh;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center"><div><style>body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}</style><h1 class="next-error-h1" style="display:inline-block;margin:0 20px 0 0;padding:0 23px 0 0;font-size:24px;font-weight:500;vertical-align:top;line-height:49px">404</h1><div style="display:inline-block"><h2 style="font-size:14px;font-weight:400;line-height:49px;margin:0">This page could not be found.</h2></div></div></div><!--$--><!--/$--><script src="/_next/static/chunks/0fpki3y6aj230.js" id="_R_" async=""></script><script>(self.__next_f=self.__next_f||[]).push([0])</script><script>self.__next_f.push([1,"1:\"$Sreact.fragment\"\n2:I[39756,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"default\"]\n3:I[37457,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"default\"]\n4:I[97367,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"OutletBoundary\"]\n5:\"$Sreact.suspense\"\n8:I[97367,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"ViewportBoundary\"]\na:I[97367,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"MetadataBoundary\"]\nc:I[68027,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"default\",1]\n:HL[\"/_next/static/chunks/139c54uo1w7.4.css\",\"style\"]\n"])</script><script>self.__next_f.push([1,"0:{\"P\":null,\"c\":[\"\",\"_not-found\"],\"q\":\"\",\"i\":false,\"f\":[[[\"\",{\"children\":[\"/_not-found\",{\"children\":[\"__PAGE__\",{}]}]},\"$undefined\",\"$undefined\",16],[[\"$\",\"$1\",\"c\",{\"children\":[[[\"$\",\"link\",\"0\",{\"rel\":\"stylesheet\",\"href\":\"/_next/static/chunks/139c54uo1w7.4.css\",\"precedence\":\"next\",\"crossOrigin\":\"$undefined\",\"nonce\":\"$undefined\"}],[\"$\",\"script\",\"script-0\",{\"src\":\"/_next/static/chunks/0dbhjjzl8qfwv.js\",\"async\":true,\"nonce\":\"$undefined\"}]],[\"$\",\"html\",null,{\"lang\":\"en\",\"className\":\"geist_a71539c9-module__T19VSG__variable geist_mono_8d43a2aa-module__8Li5zG__variable\",\"children\":[\"$\",\"body\",null,{\"children\":[\"$\",\"$L2\",null,{\"parallelRouterKey\":\"children\",\"error\":\"$undefined\",\"errorStyles\":\"$undefined\",\"errorScripts\":\"$undefined\",\"template\":[\"$\",\"$L3\",null,{}],\"templateStyles\":\"$undefined\",\"templateScripts\":\"$undefined\",\"notFound\":[[[\"$\",\"title\",null,{\"children\":\"404: This page could not be found.\"}],[\"$\",\"div\",null,{\"style\":{\"fontFamily\":\"system-ui,\\\"Segoe UI\\\",Roboto,Helvetica,Arial,sans-serif,\\\"Apple Color Emoji\\\",\\\"Segoe UI Emoji\\\"\",\"height\":\"100vh\",\"textAlign\":\"center\",\"display\":\"flex\",\"flexDirection\":\"column\",\"alignItems\":\"center\",\"justifyContent\":\"center\"},\"children\":[\"$\",\"div\",null,{\"children\":[[\"$\",\"style\",null,{\"dangerouslySetInnerHTML\":{\"__html\":\"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}\"}}],[\"$\",\"h1\",null,{\"className\":\"next-error-h1\",\"style\":{\"display\":\"inline-block\",\"margin\":\"0 20px 0 0\",\"padding\":\"0 23px 0 0\",\"fontSize\":24,\"fontWeight\":500,\"verticalAlign\":\"top\",\"lineHeight\":\"49px\"},\"children\":404}],[\"$\",\"div\",null,{\"style\":{\"display\":\"inline-block\"},\"children\":[\"$\",\"h2\",null,{\"style\":{\"fontSize\":14,\"fontWeight\":400,\"lineHeight\":\"49px\",\"margin\":0},\"children\":\"This page could not be found.\"}]}]]}]}]],[]],\"forbidden\":\"$undefined\",\"unauthorized\":\"$undefined\"}]}]}]]}],{\"children\":[[\"$\",\"$1\",\"c\",{\"children\":[null,[\"$\",\"$L2\",null,{\"parallelRouterKey\":\"children\",\"error\":\"$undefined\",\"errorStyles\":\"$undefined\",\"errorScripts\":\"$undefined\",\"template\":[\"$\",\"$L3\",null,{}],\"templateStyles\":\"$undefined\",\"templateScripts\":\"$undefined\",\"notFound\":\"$undefined\",\"forbidden\":\"$undefined\",\"unauthorized\":\"$undefined\"}]]}],{\"children\":[[\"$\",\"$1\",\"c\",{\"children\":[[[\"$\",\"title\",null,{\"children\":\"404: This page could not be found.\"}],[\"$\",\"div\",null,{\"style\":\"$0:f:0:1:0:props:children:1:props:children:props:children:props:notFound:0:1:props:style\",\"children\":[\"$\",\"div\",null,{\"children\":[[\"$\",\"style\",null,{\"dangerouslySetInnerHTML\":{\"__html\":\"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}\"}}],[\"$\",\"h1\",null,{\"className\":\"next-error-h1\",\"style\":\"$0:f:0:1:0:props:children:1:props:children:props:children:props:notFound:0:1:props:children:props:children:1:props:style\",\"children\":404}],[\"$\",\"div\",null,{\"style\":\"$0:f:0:1:0:props:children:1:props:children:props:children:props:notFound:0:1:props:children:props:children:2:props:style\",\"children\":[\"$\",\"h2\",null,{\"style\":\"$0:f:0:1:0:props:children:1:props:children:props:children:props:notFound:0:1:props:children:props:children:2:props:children:props:style\",\"children\":\"This page could not be found.\"}]}]]}]}]],null,[\"$\",\"$L4\",null,{\"children\":[\"$\",\"$5\",null,{\"name\":\"Next.MetadataOutlet\",\"children\":\"$@6\"}]}]]}],{},null,false,null]},null,false,\"$@7\"]},null,false,null],[\"$\",\"$1\",\"h\",{\"children\":[[\"$\",\"meta\",null,{\"name\":\"robots\",\"content\":\"noindex\"}],[\"$\",\"$L8\",null,{\"children\":\"$L9\"}],[\"$\",\"div\",null,{\"hidden\":true,\"children\":[\"$\",\"$La\",null,{\"children\":[\"$\",\"$5\",null,{\"name\":\"Next.Metadata\",\"children\":\"$Lb\"}]}]}],[\"$\",\"meta\",null,{\"name\":\"next-size-adjust\",\"content\":\"\"}]]}],false]],\"m\":\"$undefined\",\"G\":[\"$c\",[[\"$\",\"link\",\"0\",{\"rel\":\"stylesheet\",\"href\":\"/_next/static/chunks/139c54uo1w7.4.css\",\"precedence\":\"next\",\"crossOrigin\":\"$undefined\",\"nonce\":\"$undefined\"}]]],\"S\":true,\"h\":null,\"s\":\"$undefined\",\"l\":\"$undefined\",\"p\":\"$undefined\",\"d\":\"$undefined\",\"b\":\"
|
|
1
|
+
<!DOCTYPE html><html lang="en" class="geist_a71539c9-module__T19VSG__variable geist_mono_8d43a2aa-module__8Li5zG__variable"><head><meta charSet="utf-8"/><meta name="viewport" content="width=device-width, initial-scale=1"/><link rel="stylesheet" href="/_next/static/chunks/139c54uo1w7.4.css" data-precedence="next"/><link rel="preload" as="script" fetchPriority="low" href="/_next/static/chunks/0fpki3y6aj230.js"/><script src="/_next/static/chunks/140ovxvjat1ch.js" async=""></script><script src="/_next/static/chunks/07lhk_q6pmm3r.js" async=""></script><script src="/_next/static/chunks/turbopack-08fpdsd.-ns2y.js" async=""></script><script src="/_next/static/chunks/0dbhjjzl8qfwv.js" async=""></script><meta name="robots" content="noindex"/><meta name="next-size-adjust" content=""/><title>404: This page could not be found.</title><title>NeuralLoom - Unified AI Agent Orchestrator & Context Bridge</title><meta name="description" content="Advanced console dashboard and context staging manager for Claude Code and simulated AI agents."/><link rel="icon" href="/favicon.ico?favicon.0x3dzn~oxb6tn.ico" sizes="256x256" type="image/x-icon"/><script src="/_next/static/chunks/03~yq9q893hmn.js" noModule=""></script></head><body><div hidden=""><!--$--><!--/$--></div><div style="font-family:system-ui,"Segoe UI",Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji";height:100vh;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center"><div><style>body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}</style><h1 class="next-error-h1" style="display:inline-block;margin:0 20px 0 0;padding:0 23px 0 0;font-size:24px;font-weight:500;vertical-align:top;line-height:49px">404</h1><div style="display:inline-block"><h2 style="font-size:14px;font-weight:400;line-height:49px;margin:0">This page could not be found.</h2></div></div></div><!--$--><!--/$--><script src="/_next/static/chunks/0fpki3y6aj230.js" id="_R_" async=""></script><script>(self.__next_f=self.__next_f||[]).push([0])</script><script>self.__next_f.push([1,"1:\"$Sreact.fragment\"\n2:I[39756,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"default\"]\n3:I[37457,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"default\"]\n4:I[97367,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"OutletBoundary\"]\n5:\"$Sreact.suspense\"\n8:I[97367,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"ViewportBoundary\"]\na:I[97367,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"MetadataBoundary\"]\nc:I[68027,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"default\",1]\n:HL[\"/_next/static/chunks/139c54uo1w7.4.css\",\"style\"]\n"])</script><script>self.__next_f.push([1,"0:{\"P\":null,\"c\":[\"\",\"_not-found\"],\"q\":\"\",\"i\":false,\"f\":[[[\"\",{\"children\":[\"/_not-found\",{\"children\":[\"__PAGE__\",{}]}]},\"$undefined\",\"$undefined\",16],[[\"$\",\"$1\",\"c\",{\"children\":[[[\"$\",\"link\",\"0\",{\"rel\":\"stylesheet\",\"href\":\"/_next/static/chunks/139c54uo1w7.4.css\",\"precedence\":\"next\",\"crossOrigin\":\"$undefined\",\"nonce\":\"$undefined\"}],[\"$\",\"script\",\"script-0\",{\"src\":\"/_next/static/chunks/0dbhjjzl8qfwv.js\",\"async\":true,\"nonce\":\"$undefined\"}]],[\"$\",\"html\",null,{\"lang\":\"en\",\"className\":\"geist_a71539c9-module__T19VSG__variable geist_mono_8d43a2aa-module__8Li5zG__variable\",\"children\":[\"$\",\"body\",null,{\"children\":[\"$\",\"$L2\",null,{\"parallelRouterKey\":\"children\",\"error\":\"$undefined\",\"errorStyles\":\"$undefined\",\"errorScripts\":\"$undefined\",\"template\":[\"$\",\"$L3\",null,{}],\"templateStyles\":\"$undefined\",\"templateScripts\":\"$undefined\",\"notFound\":[[[\"$\",\"title\",null,{\"children\":\"404: This page could not be found.\"}],[\"$\",\"div\",null,{\"style\":{\"fontFamily\":\"system-ui,\\\"Segoe UI\\\",Roboto,Helvetica,Arial,sans-serif,\\\"Apple Color Emoji\\\",\\\"Segoe UI Emoji\\\"\",\"height\":\"100vh\",\"textAlign\":\"center\",\"display\":\"flex\",\"flexDirection\":\"column\",\"alignItems\":\"center\",\"justifyContent\":\"center\"},\"children\":[\"$\",\"div\",null,{\"children\":[[\"$\",\"style\",null,{\"dangerouslySetInnerHTML\":{\"__html\":\"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}\"}}],[\"$\",\"h1\",null,{\"className\":\"next-error-h1\",\"style\":{\"display\":\"inline-block\",\"margin\":\"0 20px 0 0\",\"padding\":\"0 23px 0 0\",\"fontSize\":24,\"fontWeight\":500,\"verticalAlign\":\"top\",\"lineHeight\":\"49px\"},\"children\":404}],[\"$\",\"div\",null,{\"style\":{\"display\":\"inline-block\"},\"children\":[\"$\",\"h2\",null,{\"style\":{\"fontSize\":14,\"fontWeight\":400,\"lineHeight\":\"49px\",\"margin\":0},\"children\":\"This page could not be found.\"}]}]]}]}]],[]],\"forbidden\":\"$undefined\",\"unauthorized\":\"$undefined\"}]}]}]]}],{\"children\":[[\"$\",\"$1\",\"c\",{\"children\":[null,[\"$\",\"$L2\",null,{\"parallelRouterKey\":\"children\",\"error\":\"$undefined\",\"errorStyles\":\"$undefined\",\"errorScripts\":\"$undefined\",\"template\":[\"$\",\"$L3\",null,{}],\"templateStyles\":\"$undefined\",\"templateScripts\":\"$undefined\",\"notFound\":\"$undefined\",\"forbidden\":\"$undefined\",\"unauthorized\":\"$undefined\"}]]}],{\"children\":[[\"$\",\"$1\",\"c\",{\"children\":[[[\"$\",\"title\",null,{\"children\":\"404: This page could not be found.\"}],[\"$\",\"div\",null,{\"style\":\"$0:f:0:1:0:props:children:1:props:children:props:children:props:notFound:0:1:props:style\",\"children\":[\"$\",\"div\",null,{\"children\":[[\"$\",\"style\",null,{\"dangerouslySetInnerHTML\":{\"__html\":\"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}\"}}],[\"$\",\"h1\",null,{\"className\":\"next-error-h1\",\"style\":\"$0:f:0:1:0:props:children:1:props:children:props:children:props:notFound:0:1:props:children:props:children:1:props:style\",\"children\":404}],[\"$\",\"div\",null,{\"style\":\"$0:f:0:1:0:props:children:1:props:children:props:children:props:notFound:0:1:props:children:props:children:2:props:style\",\"children\":[\"$\",\"h2\",null,{\"style\":\"$0:f:0:1:0:props:children:1:props:children:props:children:props:notFound:0:1:props:children:props:children:2:props:children:props:style\",\"children\":\"This page could not be found.\"}]}]]}]}]],null,[\"$\",\"$L4\",null,{\"children\":[\"$\",\"$5\",null,{\"name\":\"Next.MetadataOutlet\",\"children\":\"$@6\"}]}]]}],{},null,false,null]},null,false,\"$@7\"]},null,false,null],[\"$\",\"$1\",\"h\",{\"children\":[[\"$\",\"meta\",null,{\"name\":\"robots\",\"content\":\"noindex\"}],[\"$\",\"$L8\",null,{\"children\":\"$L9\"}],[\"$\",\"div\",null,{\"hidden\":true,\"children\":[\"$\",\"$La\",null,{\"children\":[\"$\",\"$5\",null,{\"name\":\"Next.Metadata\",\"children\":\"$Lb\"}]}]}],[\"$\",\"meta\",null,{\"name\":\"next-size-adjust\",\"content\":\"\"}]]}],false]],\"m\":\"$undefined\",\"G\":[\"$c\",[[\"$\",\"link\",\"0\",{\"rel\":\"stylesheet\",\"href\":\"/_next/static/chunks/139c54uo1w7.4.css\",\"precedence\":\"next\",\"crossOrigin\":\"$undefined\",\"nonce\":\"$undefined\"}]]],\"S\":true,\"h\":null,\"s\":\"$undefined\",\"l\":\"$undefined\",\"p\":\"$undefined\",\"d\":\"$undefined\",\"b\":\"2HGCuinlX_PNFgwkjIVKe\"}\n"])</script><script>self.__next_f.push([1,"d:[]\n7:\"$Wd\"\n"])</script><script>self.__next_f.push([1,"9:[[\"$\",\"meta\",\"0\",{\"charSet\":\"utf-8\"}],[\"$\",\"meta\",\"1\",{\"name\":\"viewport\",\"content\":\"width=device-width, initial-scale=1\"}]]\n"])</script><script>self.__next_f.push([1,"e:I[27201,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"IconMark\"]\n6:null\nb:[[\"$\",\"title\",\"0\",{\"children\":\"NeuralLoom - Unified AI Agent Orchestrator \u0026 Context Bridge\"}],[\"$\",\"meta\",\"1\",{\"name\":\"description\",\"content\":\"Advanced console dashboard and context staging manager for Claude Code and simulated AI agents.\"}],[\"$\",\"link\",\"2\",{\"rel\":\"icon\",\"href\":\"/favicon.ico?favicon.0x3dzn~oxb6tn.ico\",\"sizes\":\"256x256\",\"type\":\"image/x-icon\"}],[\"$\",\"$Le\",\"3\",{}]]\n"])</script></body></html>
|
|
@@ -1 +1 @@
|
|
|
1
|
-
<!DOCTYPE html><html id="__next_error__"><head><meta charSet="utf-8"/><meta name="viewport" content="width=device-width, initial-scale=1"/><link rel="preload" as="script" fetchPriority="low" href="/_next/static/chunks/0fpki3y6aj230.js"/><script src="/_next/static/chunks/140ovxvjat1ch.js" async=""></script><script src="/_next/static/chunks/07lhk_q6pmm3r.js" async=""></script><script src="/_next/static/chunks/turbopack-08fpdsd.-ns2y.js" async=""></script><script src="/_next/static/chunks/0dbhjjzl8qfwv.js" async=""></script><meta name="next-size-adjust" content=""/><title>500: This page couldn’t load</title><link rel="icon" href="/favicon.ico?favicon.0x3dzn~oxb6tn.ico" sizes="256x256" type="image/x-icon"/><style>:root {--next-error-bg: #fff;--next-error-text: #171717;--next-error-title: #171717;--next-error-message: #171717;--next-error-digest: #666666;--next-error-btn-text: #fff;--next-error-btn-bg: #171717;--next-error-btn-border: none;--next-error-btn-secondary-text: #171717;--next-error-btn-secondary-bg: transparent;--next-error-btn-secondary-border: 1px solid rgba(0,0,0,0.08);}@media (prefers-color-scheme: dark) {:root {--next-error-bg: #0a0a0a;--next-error-text: #ededed;--next-error-title: #ededed;--next-error-message: #ededed;--next-error-digest: #a0a0a0;--next-error-btn-text: #0a0a0a;--next-error-btn-bg: #ededed;--next-error-btn-border: none;--next-error-btn-secondary-text: #ededed;--next-error-btn-secondary-bg: transparent;--next-error-btn-secondary-border: 1px solid rgba(255,255,255,0.14);}}body { margin: 0; color: var(--next-error-text); background: var(--next-error-bg); }</style><script src="/_next/static/chunks/03~yq9q893hmn.js" noModule=""></script></head><body><div hidden=""><!--$--><!--/$--></div><div style="font-family:system-ui,"Segoe UI",Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji";height:100vh;display:flex;align-items:center;justify-content:center"><div style="margin-top:-32px;max-width:325px;padding:32px 28px;text-align:left"><svg width="32" height="32" viewBox="-0.2 -1.5 32 32" fill="none" style="margin-bottom:24px"><path d="M16.9328 0C18.0839 0.000116771 19.1334 0.658832 19.634 1.69531L31.4299 26.1309C32.0708 27.4588 31.1036 28.9999 29.6291 29H2.00215C0.527541 29 -0.439628 27.4588 0.201371 26.1309L11.9973 1.69531C12.4979 0.658823 13.5474 7.75066e-05 14.6984 0H16.9328ZM3.59493 26H28.0363L16.9328 3H14.6984L3.59493 26ZM15.8156 19C16.9202 19.0001 17.8156 19.8955 17.8156 21C17.8156 22.1045 16.9202 22.9999 15.8156 23C14.7111 23 13.8156 22.1046 13.8156 21C13.8156 19.8954 14.7111 19 15.8156 19ZM17.3156 16.5H14.3156V8.5H17.3156V16.5Z" fill="var(--next-error-title)"></path></svg><h1 style="font-size:24px;font-weight:500;letter-spacing:-0.02em;line-height:32px;margin:0 0 12px 0;color:var(--next-error-title)">This page couldn’t load</h1><p style="font-size:14px;font-weight:400;line-height:21px;margin:0 0 20px 0;color:var(--next-error-message)">A server error occurred. Reload to try again.</p><form style="margin:0"><button type="submit" style="display:inline-flex;align-items:center;justify-content:center;height:32px;padding:0 12px;font-size:14px;font-weight:500;line-height:20px;border-radius:6px;cursor:pointer;color:var(--next-error-btn-text);background:var(--next-error-btn-bg);border:var(--next-error-btn-border)">Reload</button></form></div></div><!--$--><!--/$--><script src="/_next/static/chunks/0fpki3y6aj230.js" id="_R_" async=""></script><script>(self.__next_f=self.__next_f||[]).push([0])</script><script>self.__next_f.push([1,"1:\"$Sreact.fragment\"\n2:I[39756,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"default\"]\n3:I[37457,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"default\"]\n4:I[97367,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"OutletBoundary\"]\n5:\"$Sreact.suspense\"\n8:I[97367,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"ViewportBoundary\"]\na:I[97367,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"MetadataBoundary\"]\nc:I[68027,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"default\",1]\n"])</script><script>self.__next_f.push([1,"0:{\"P\":null,\"c\":[\"\",\"_global-error\"],\"q\":\"\",\"i\":false,\"f\":[[[\"\",{\"children\":[\"__PAGE__\",{}]}],[[\"$\",\"$1\",\"c\",{\"children\":[null,[\"$\",\"$L2\",null,{\"parallelRouterKey\":\"children\",\"error\":\"$undefined\",\"errorStyles\":\"$undefined\",\"errorScripts\":\"$undefined\",\"template\":[\"$\",\"$L3\",null,{}],\"templateStyles\":\"$undefined\",\"templateScripts\":\"$undefined\",\"notFound\":\"$undefined\",\"forbidden\":\"$undefined\",\"unauthorized\":\"$undefined\"}]]}],{\"children\":[[\"$\",\"$1\",\"c\",{\"children\":[[\"$\",\"html\",null,{\"id\":\"__next_error__\",\"children\":[[\"$\",\"head\",null,{\"children\":[[\"$\",\"title\",null,{\"children\":\"500: This page couldn’t load\"}],[\"$\",\"style\",null,{\"dangerouslySetInnerHTML\":{\"__html\":\":root {--next-error-bg: #fff;--next-error-text: #171717;--next-error-title: #171717;--next-error-message: #171717;--next-error-digest: #666666;--next-error-btn-text: #fff;--next-error-btn-bg: #171717;--next-error-btn-border: none;--next-error-btn-secondary-text: #171717;--next-error-btn-secondary-bg: transparent;--next-error-btn-secondary-border: 1px solid rgba(0,0,0,0.08);}@media (prefers-color-scheme: dark) {:root {--next-error-bg: #0a0a0a;--next-error-text: #ededed;--next-error-title: #ededed;--next-error-message: #ededed;--next-error-digest: #a0a0a0;--next-error-btn-text: #0a0a0a;--next-error-btn-bg: #ededed;--next-error-btn-border: none;--next-error-btn-secondary-text: #ededed;--next-error-btn-secondary-bg: transparent;--next-error-btn-secondary-border: 1px solid rgba(255,255,255,0.14);}}body { margin: 0; color: var(--next-error-text); background: var(--next-error-bg); }\"}}]]}],[\"$\",\"body\",null,{\"children\":[\"$\",\"div\",null,{\"style\":{\"fontFamily\":\"system-ui,\\\"Segoe UI\\\",Roboto,Helvetica,Arial,sans-serif,\\\"Apple Color Emoji\\\",\\\"Segoe UI Emoji\\\"\",\"height\":\"100vh\",\"display\":\"flex\",\"alignItems\":\"center\",\"justifyContent\":\"center\"},\"children\":[\"$\",\"div\",null,{\"style\":{\"marginTop\":\"-32px\",\"maxWidth\":\"325px\",\"padding\":\"32px 28px\",\"textAlign\":\"left\"},\"children\":[[\"$\",\"svg\",null,{\"width\":\"32\",\"height\":\"32\",\"viewBox\":\"-0.2 -1.5 32 32\",\"fill\":\"none\",\"style\":{\"marginBottom\":\"24px\"},\"children\":[\"$\",\"path\",null,{\"d\":\"M16.9328 0C18.0839 0.000116771 19.1334 0.658832 19.634 1.69531L31.4299 26.1309C32.0708 27.4588 31.1036 28.9999 29.6291 29H2.00215C0.527541 29 -0.439628 27.4588 0.201371 26.1309L11.9973 1.69531C12.4979 0.658823 13.5474 7.75066e-05 14.6984 0H16.9328ZM3.59493 26H28.0363L16.9328 3H14.6984L3.59493 26ZM15.8156 19C16.9202 19.0001 17.8156 19.8955 17.8156 21C17.8156 22.1045 16.9202 22.9999 15.8156 23C14.7111 23 13.8156 22.1046 13.8156 21C13.8156 19.8954 14.7111 19 15.8156 19ZM17.3156 16.5H14.3156V8.5H17.3156V16.5Z\",\"fill\":\"var(--next-error-title)\"}]}],[\"$\",\"h1\",null,{\"style\":{\"fontSize\":\"24px\",\"fontWeight\":500,\"letterSpacing\":\"-0.02em\",\"lineHeight\":\"32px\",\"margin\":\"0 0 12px 0\",\"color\":\"var(--next-error-title)\"},\"children\":\"This page couldn’t load\"}],[\"$\",\"p\",null,{\"style\":{\"fontSize\":\"14px\",\"fontWeight\":400,\"lineHeight\":\"21px\",\"margin\":\"0 0 20px 0\",\"color\":\"var(--next-error-message)\"},\"children\":\"A server error occurred. Reload to try again.\"}],[\"$\",\"form\",null,{\"style\":{\"margin\":0},\"children\":[\"$\",\"button\",null,{\"type\":\"submit\",\"style\":{\"display\":\"inline-flex\",\"alignItems\":\"center\",\"justifyContent\":\"center\",\"height\":\"32px\",\"padding\":\"0 12px\",\"fontSize\":\"14px\",\"fontWeight\":500,\"lineHeight\":\"20px\",\"borderRadius\":\"6px\",\"cursor\":\"pointer\",\"color\":\"var(--next-error-btn-text)\",\"background\":\"var(--next-error-btn-bg)\",\"border\":\"var(--next-error-btn-border)\"},\"children\":\"Reload\"}]}]]}]}]}]]}],null,[\"$\",\"$L4\",null,{\"children\":[\"$\",\"$5\",null,{\"name\":\"Next.MetadataOutlet\",\"children\":\"$@6\"}]}]]}],{},null,false,null]},null,false,\"$@7\"],[\"$\",\"$1\",\"h\",{\"children\":[null,[\"$\",\"$L8\",null,{\"children\":\"$L9\"}],[\"$\",\"div\",null,{\"hidden\":true,\"children\":[\"$\",\"$La\",null,{\"children\":[\"$\",\"$5\",null,{\"name\":\"Next.Metadata\",\"children\":\"$Lb\"}]}]}],[\"$\",\"meta\",null,{\"name\":\"next-size-adjust\",\"content\":\"\"}]]}],false]],\"m\":\"$undefined\",\"G\":[\"$c\",[]],\"S\":true,\"h\":null,\"s\":\"$undefined\",\"l\":\"$undefined\",\"p\":\"$undefined\",\"d\":\"$undefined\",\"b\":\"
|
|
1
|
+
<!DOCTYPE html><html id="__next_error__"><head><meta charSet="utf-8"/><meta name="viewport" content="width=device-width, initial-scale=1"/><link rel="preload" as="script" fetchPriority="low" href="/_next/static/chunks/0fpki3y6aj230.js"/><script src="/_next/static/chunks/140ovxvjat1ch.js" async=""></script><script src="/_next/static/chunks/07lhk_q6pmm3r.js" async=""></script><script src="/_next/static/chunks/turbopack-08fpdsd.-ns2y.js" async=""></script><script src="/_next/static/chunks/0dbhjjzl8qfwv.js" async=""></script><meta name="next-size-adjust" content=""/><title>500: This page couldn’t load</title><link rel="icon" href="/favicon.ico?favicon.0x3dzn~oxb6tn.ico" sizes="256x256" type="image/x-icon"/><style>:root {--next-error-bg: #fff;--next-error-text: #171717;--next-error-title: #171717;--next-error-message: #171717;--next-error-digest: #666666;--next-error-btn-text: #fff;--next-error-btn-bg: #171717;--next-error-btn-border: none;--next-error-btn-secondary-text: #171717;--next-error-btn-secondary-bg: transparent;--next-error-btn-secondary-border: 1px solid rgba(0,0,0,0.08);}@media (prefers-color-scheme: dark) {:root {--next-error-bg: #0a0a0a;--next-error-text: #ededed;--next-error-title: #ededed;--next-error-message: #ededed;--next-error-digest: #a0a0a0;--next-error-btn-text: #0a0a0a;--next-error-btn-bg: #ededed;--next-error-btn-border: none;--next-error-btn-secondary-text: #ededed;--next-error-btn-secondary-bg: transparent;--next-error-btn-secondary-border: 1px solid rgba(255,255,255,0.14);}}body { margin: 0; color: var(--next-error-text); background: var(--next-error-bg); }</style><script src="/_next/static/chunks/03~yq9q893hmn.js" noModule=""></script></head><body><div hidden=""><!--$--><!--/$--></div><div style="font-family:system-ui,"Segoe UI",Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji";height:100vh;display:flex;align-items:center;justify-content:center"><div style="margin-top:-32px;max-width:325px;padding:32px 28px;text-align:left"><svg width="32" height="32" viewBox="-0.2 -1.5 32 32" fill="none" style="margin-bottom:24px"><path d="M16.9328 0C18.0839 0.000116771 19.1334 0.658832 19.634 1.69531L31.4299 26.1309C32.0708 27.4588 31.1036 28.9999 29.6291 29H2.00215C0.527541 29 -0.439628 27.4588 0.201371 26.1309L11.9973 1.69531C12.4979 0.658823 13.5474 7.75066e-05 14.6984 0H16.9328ZM3.59493 26H28.0363L16.9328 3H14.6984L3.59493 26ZM15.8156 19C16.9202 19.0001 17.8156 19.8955 17.8156 21C17.8156 22.1045 16.9202 22.9999 15.8156 23C14.7111 23 13.8156 22.1046 13.8156 21C13.8156 19.8954 14.7111 19 15.8156 19ZM17.3156 16.5H14.3156V8.5H17.3156V16.5Z" fill="var(--next-error-title)"></path></svg><h1 style="font-size:24px;font-weight:500;letter-spacing:-0.02em;line-height:32px;margin:0 0 12px 0;color:var(--next-error-title)">This page couldn’t load</h1><p style="font-size:14px;font-weight:400;line-height:21px;margin:0 0 20px 0;color:var(--next-error-message)">A server error occurred. Reload to try again.</p><form style="margin:0"><button type="submit" style="display:inline-flex;align-items:center;justify-content:center;height:32px;padding:0 12px;font-size:14px;font-weight:500;line-height:20px;border-radius:6px;cursor:pointer;color:var(--next-error-btn-text);background:var(--next-error-btn-bg);border:var(--next-error-btn-border)">Reload</button></form></div></div><!--$--><!--/$--><script src="/_next/static/chunks/0fpki3y6aj230.js" id="_R_" async=""></script><script>(self.__next_f=self.__next_f||[]).push([0])</script><script>self.__next_f.push([1,"1:\"$Sreact.fragment\"\n2:I[39756,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"default\"]\n3:I[37457,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"default\"]\n4:I[97367,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"OutletBoundary\"]\n5:\"$Sreact.suspense\"\n8:I[97367,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"ViewportBoundary\"]\na:I[97367,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"MetadataBoundary\"]\nc:I[68027,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"default\",1]\n"])</script><script>self.__next_f.push([1,"0:{\"P\":null,\"c\":[\"\",\"_global-error\"],\"q\":\"\",\"i\":false,\"f\":[[[\"\",{\"children\":[\"__PAGE__\",{}]}],[[\"$\",\"$1\",\"c\",{\"children\":[null,[\"$\",\"$L2\",null,{\"parallelRouterKey\":\"children\",\"error\":\"$undefined\",\"errorStyles\":\"$undefined\",\"errorScripts\":\"$undefined\",\"template\":[\"$\",\"$L3\",null,{}],\"templateStyles\":\"$undefined\",\"templateScripts\":\"$undefined\",\"notFound\":\"$undefined\",\"forbidden\":\"$undefined\",\"unauthorized\":\"$undefined\"}]]}],{\"children\":[[\"$\",\"$1\",\"c\",{\"children\":[[\"$\",\"html\",null,{\"id\":\"__next_error__\",\"children\":[[\"$\",\"head\",null,{\"children\":[[\"$\",\"title\",null,{\"children\":\"500: This page couldn’t load\"}],[\"$\",\"style\",null,{\"dangerouslySetInnerHTML\":{\"__html\":\":root {--next-error-bg: #fff;--next-error-text: #171717;--next-error-title: #171717;--next-error-message: #171717;--next-error-digest: #666666;--next-error-btn-text: #fff;--next-error-btn-bg: #171717;--next-error-btn-border: none;--next-error-btn-secondary-text: #171717;--next-error-btn-secondary-bg: transparent;--next-error-btn-secondary-border: 1px solid rgba(0,0,0,0.08);}@media (prefers-color-scheme: dark) {:root {--next-error-bg: #0a0a0a;--next-error-text: #ededed;--next-error-title: #ededed;--next-error-message: #ededed;--next-error-digest: #a0a0a0;--next-error-btn-text: #0a0a0a;--next-error-btn-bg: #ededed;--next-error-btn-border: none;--next-error-btn-secondary-text: #ededed;--next-error-btn-secondary-bg: transparent;--next-error-btn-secondary-border: 1px solid rgba(255,255,255,0.14);}}body { margin: 0; color: var(--next-error-text); background: var(--next-error-bg); }\"}}]]}],[\"$\",\"body\",null,{\"children\":[\"$\",\"div\",null,{\"style\":{\"fontFamily\":\"system-ui,\\\"Segoe UI\\\",Roboto,Helvetica,Arial,sans-serif,\\\"Apple Color Emoji\\\",\\\"Segoe UI Emoji\\\"\",\"height\":\"100vh\",\"display\":\"flex\",\"alignItems\":\"center\",\"justifyContent\":\"center\"},\"children\":[\"$\",\"div\",null,{\"style\":{\"marginTop\":\"-32px\",\"maxWidth\":\"325px\",\"padding\":\"32px 28px\",\"textAlign\":\"left\"},\"children\":[[\"$\",\"svg\",null,{\"width\":\"32\",\"height\":\"32\",\"viewBox\":\"-0.2 -1.5 32 32\",\"fill\":\"none\",\"style\":{\"marginBottom\":\"24px\"},\"children\":[\"$\",\"path\",null,{\"d\":\"M16.9328 0C18.0839 0.000116771 19.1334 0.658832 19.634 1.69531L31.4299 26.1309C32.0708 27.4588 31.1036 28.9999 29.6291 29H2.00215C0.527541 29 -0.439628 27.4588 0.201371 26.1309L11.9973 1.69531C12.4979 0.658823 13.5474 7.75066e-05 14.6984 0H16.9328ZM3.59493 26H28.0363L16.9328 3H14.6984L3.59493 26ZM15.8156 19C16.9202 19.0001 17.8156 19.8955 17.8156 21C17.8156 22.1045 16.9202 22.9999 15.8156 23C14.7111 23 13.8156 22.1046 13.8156 21C13.8156 19.8954 14.7111 19 15.8156 19ZM17.3156 16.5H14.3156V8.5H17.3156V16.5Z\",\"fill\":\"var(--next-error-title)\"}]}],[\"$\",\"h1\",null,{\"style\":{\"fontSize\":\"24px\",\"fontWeight\":500,\"letterSpacing\":\"-0.02em\",\"lineHeight\":\"32px\",\"margin\":\"0 0 12px 0\",\"color\":\"var(--next-error-title)\"},\"children\":\"This page couldn’t load\"}],[\"$\",\"p\",null,{\"style\":{\"fontSize\":\"14px\",\"fontWeight\":400,\"lineHeight\":\"21px\",\"margin\":\"0 0 20px 0\",\"color\":\"var(--next-error-message)\"},\"children\":\"A server error occurred. Reload to try again.\"}],[\"$\",\"form\",null,{\"style\":{\"margin\":0},\"children\":[\"$\",\"button\",null,{\"type\":\"submit\",\"style\":{\"display\":\"inline-flex\",\"alignItems\":\"center\",\"justifyContent\":\"center\",\"height\":\"32px\",\"padding\":\"0 12px\",\"fontSize\":\"14px\",\"fontWeight\":500,\"lineHeight\":\"20px\",\"borderRadius\":\"6px\",\"cursor\":\"pointer\",\"color\":\"var(--next-error-btn-text)\",\"background\":\"var(--next-error-btn-bg)\",\"border\":\"var(--next-error-btn-border)\"},\"children\":\"Reload\"}]}]]}]}]}]]}],null,[\"$\",\"$L4\",null,{\"children\":[\"$\",\"$5\",null,{\"name\":\"Next.MetadataOutlet\",\"children\":\"$@6\"}]}]]}],{},null,false,null]},null,false,\"$@7\"],[\"$\",\"$1\",\"h\",{\"children\":[null,[\"$\",\"$L8\",null,{\"children\":\"$L9\"}],[\"$\",\"div\",null,{\"hidden\":true,\"children\":[\"$\",\"$La\",null,{\"children\":[\"$\",\"$5\",null,{\"name\":\"Next.Metadata\",\"children\":\"$Lb\"}]}]}],[\"$\",\"meta\",null,{\"name\":\"next-size-adjust\",\"content\":\"\"}]]}],false]],\"m\":\"$undefined\",\"G\":[\"$c\",[]],\"S\":true,\"h\":null,\"s\":\"$undefined\",\"l\":\"$undefined\",\"p\":\"$undefined\",\"d\":\"$undefined\",\"b\":\"2HGCuinlX_PNFgwkjIVKe\"}\n"])</script><script>self.__next_f.push([1,"d:[]\n7:\"$Wd\"\n"])</script><script>self.__next_f.push([1,"9:[[\"$\",\"meta\",\"0\",{\"charSet\":\"utf-8\"}],[\"$\",\"meta\",\"1\",{\"name\":\"viewport\",\"content\":\"width=device-width, initial-scale=1\"}]]\n"])</script><script>self.__next_f.push([1,"e:I[27201,[\"/_next/static/chunks/0dbhjjzl8qfwv.js\"],\"IconMark\"]\n6:null\nb:[[\"$\",\"link\",\"0\",{\"rel\":\"icon\",\"href\":\"/favicon.ico?favicon.0x3dzn~oxb6tn.ico\",\"sizes\":\"256x256\",\"type\":\"image/x-icon\"}],[\"$\",\"$Le\",\"1\",{}]]\n"])</script></body></html>
|
|
@@ -1 +1 @@
|
|
|
1
|
-
self.__RSC_SERVER_MANIFEST="{\n \"node\": {},\n \"edge\": {},\n \"encryptionKey\": \"
|
|
1
|
+
self.__RSC_SERVER_MANIFEST="{\n \"node\": {},\n \"edge\": {},\n \"encryptionKey\": \"JqpmKV8Ps6Y47CLeKN+yMmhwPR2Rogh5CYtmgdHR+rA=\"\n}"
|