conductor-oss 0.58.38 → 0.58.39

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (91) hide show
  1. package/package.json +5 -5
  2. package/web/.next/standalone/packages/web/.next/BUILD_ID +1 -1
  3. package/web/.next/standalone/packages/web/.next/app-path-routes-manifest.json +4 -4
  4. package/web/.next/standalone/packages/web/.next/build-manifest.json +3 -3
  5. package/web/.next/standalone/packages/web/.next/prerender-manifest.json +3 -3
  6. package/web/.next/standalone/packages/web/.next/react-loadable-manifest.json +4 -4
  7. package/web/.next/standalone/packages/web/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  8. package/web/.next/standalone/packages/web/.next/server/app/_global-error.html +1 -1
  9. package/web/.next/standalone/packages/web/.next/server/app/_global-error.rsc +1 -1
  10. package/web/.next/standalone/packages/web/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  11. package/web/.next/standalone/packages/web/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  12. package/web/.next/standalone/packages/web/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  13. package/web/.next/standalone/packages/web/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  14. package/web/.next/standalone/packages/web/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  15. package/web/.next/standalone/packages/web/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  16. package/web/.next/standalone/packages/web/.next/server/app/_not-found/page.js +1 -1
  17. package/web/.next/standalone/packages/web/.next/server/app/_not-found/page.js.nft.json +1 -1
  18. package/web/.next/standalone/packages/web/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  19. package/web/.next/standalone/packages/web/.next/server/app/api/sessions/[id]/preview/dom/route.js +1 -1
  20. package/web/.next/standalone/packages/web/.next/server/app/api/sessions/[id]/preview/route.js +1 -1
  21. package/web/.next/standalone/packages/web/.next/server/app/api/sessions/[id]/preview/screenshot/route.js +1 -1
  22. package/web/.next/standalone/packages/web/.next/server/app/bridge/connect/page.js +1 -1
  23. package/web/.next/standalone/packages/web/.next/server/app/bridge/connect/page.js.nft.json +1 -1
  24. package/web/.next/standalone/packages/web/.next/server/app/bridge/connect/page_client-reference-manifest.js +1 -1
  25. package/web/.next/standalone/packages/web/.next/server/app/embed/terminal/[id]/page.js +1 -1
  26. package/web/.next/standalone/packages/web/.next/server/app/embed/terminal/[id]/page.js.nft.json +1 -1
  27. package/web/.next/standalone/packages/web/.next/server/app/embed/terminal/[id]/page_client-reference-manifest.js +1 -1
  28. package/web/.next/standalone/packages/web/.next/server/app/page.js +1 -1
  29. package/web/.next/standalone/packages/web/.next/server/app/page.js.nft.json +1 -1
  30. package/web/.next/standalone/packages/web/.next/server/app/page_client-reference-manifest.js +1 -1
  31. package/web/.next/standalone/packages/web/.next/server/app/sessions/[id]/page.js +1 -1
  32. package/web/.next/standalone/packages/web/.next/server/app/sessions/[id]/page.js.nft.json +1 -1
  33. package/web/.next/standalone/packages/web/.next/server/app/sessions/[id]/page_client-reference-manifest.js +1 -1
  34. package/web/.next/standalone/packages/web/.next/server/app/settings/bridge/page.js +1 -1
  35. package/web/.next/standalone/packages/web/.next/server/app/settings/bridge/page.js.nft.json +1 -1
  36. package/web/.next/standalone/packages/web/.next/server/app/settings/bridge/page_client-reference-manifest.js +1 -1
  37. package/web/.next/standalone/packages/web/.next/server/app/sign-in/[[...sign-in]]/page.js +1 -1
  38. package/web/.next/standalone/packages/web/.next/server/app/sign-in/[[...sign-in]]/page.js.nft.json +1 -1
  39. package/web/.next/standalone/packages/web/.next/server/app/sign-in/[[...sign-in]]/page_client-reference-manifest.js +1 -1
  40. package/web/.next/standalone/packages/web/.next/server/app/sign-in/hosted/page.js +1 -1
  41. package/web/.next/standalone/packages/web/.next/server/app/sign-in/hosted/page.js.nft.json +1 -1
  42. package/web/.next/standalone/packages/web/.next/server/app/sign-in/hosted/page_client-reference-manifest.js +1 -1
  43. package/web/.next/standalone/packages/web/.next/server/app/sign-in/sso-callback/page.js +1 -1
  44. package/web/.next/standalone/packages/web/.next/server/app/sign-in/sso-callback/page.js.nft.json +1 -1
  45. package/web/.next/standalone/packages/web/.next/server/app/sign-in/sso-callback/page_client-reference-manifest.js +1 -1
  46. package/web/.next/standalone/packages/web/.next/server/app/unlock/page.js +1 -1
  47. package/web/.next/standalone/packages/web/.next/server/app/unlock/page.js.nft.json +1 -1
  48. package/web/.next/standalone/packages/web/.next/server/app/unlock/page_client-reference-manifest.js +1 -1
  49. package/web/.next/standalone/packages/web/.next/server/app-paths-manifest.json +4 -4
  50. package/web/.next/standalone/packages/web/.next/server/chunks/1121.js +1 -1
  51. package/web/.next/standalone/packages/web/.next/server/chunks/2089.js +3 -3
  52. package/web/.next/standalone/packages/web/.next/server/chunks/2553.js +1 -0
  53. package/web/.next/standalone/packages/web/.next/server/chunks/3364.js +1 -1
  54. package/web/.next/standalone/packages/web/.next/server/chunks/3990.js +1 -1
  55. package/web/.next/standalone/packages/web/.next/server/chunks/60.js +1 -0
  56. package/web/.next/standalone/packages/web/.next/server/chunks/9455.js +1 -1
  57. package/web/.next/standalone/packages/web/.next/server/middleware-build-manifest.js +1 -1
  58. package/web/.next/standalone/packages/web/.next/server/middleware-react-loadable-manifest.js +1 -1
  59. package/web/.next/standalone/packages/web/.next/server/next-font-manifest.js +1 -1
  60. package/web/.next/standalone/packages/web/.next/server/next-font-manifest.json +1 -1
  61. package/web/.next/standalone/packages/web/.next/server/pages/500.html +1 -1
  62. package/web/.next/standalone/packages/web/.next/server/server-reference-manifest.js +1 -1
  63. package/web/.next/standalone/packages/web/.next/server/server-reference-manifest.json +1 -1
  64. package/web/.next/standalone/packages/web/.next/static/chunks/4443.611b659fd26e567b.js +1 -0
  65. package/web/.next/standalone/packages/web/.next/static/chunks/7649.96df81c61d4eeaaa.js +1 -0
  66. package/web/.next/standalone/packages/web/.next/static/chunks/{8510-e4eaf9374866500e.js → 8510-eb40f26ac825fca3.js} +1 -1
  67. package/web/.next/standalone/packages/web/.next/static/chunks/883-bd3ca76b76fb6a07.js +3 -0
  68. package/web/.next/standalone/packages/web/.next/static/chunks/app/layout-40d6d4ccf615ee62.js +1 -0
  69. package/web/.next/standalone/packages/web/.next/static/chunks/webpack-b8e6b1ccb85a3faa.js +1 -0
  70. package/web/.next/static/chunks/4443.611b659fd26e567b.js +1 -0
  71. package/web/.next/static/chunks/7649.96df81c61d4eeaaa.js +1 -0
  72. package/web/.next/static/chunks/{8510-e4eaf9374866500e.js → 8510-eb40f26ac825fca3.js} +1 -1
  73. package/web/.next/static/chunks/883-bd3ca76b76fb6a07.js +3 -0
  74. package/web/.next/static/chunks/app/layout-40d6d4ccf615ee62.js +1 -0
  75. package/web/.next/static/chunks/webpack-b8e6b1ccb85a3faa.js +1 -0
  76. package/web/.next/standalone/packages/web/.next/server/chunks/2987.js +0 -1
  77. package/web/.next/standalone/packages/web/.next/server/chunks/7380.js +0 -1
  78. package/web/.next/standalone/packages/web/.next/static/chunks/4443.8f1f4c2256782e25.js +0 -1
  79. package/web/.next/standalone/packages/web/.next/static/chunks/598.b616d95afccd12f7.js +0 -1
  80. package/web/.next/standalone/packages/web/.next/static/chunks/883-367a8a7a5b5f264c.js +0 -3
  81. package/web/.next/standalone/packages/web/.next/static/chunks/app/layout-e300c02215f732d9.js +0 -1
  82. package/web/.next/standalone/packages/web/.next/static/chunks/webpack-cc708b43e5621559.js +0 -1
  83. package/web/.next/static/chunks/4443.8f1f4c2256782e25.js +0 -1
  84. package/web/.next/static/chunks/598.b616d95afccd12f7.js +0 -1
  85. package/web/.next/static/chunks/883-367a8a7a5b5f264c.js +0 -3
  86. package/web/.next/static/chunks/app/layout-e300c02215f732d9.js +0 -1
  87. package/web/.next/static/chunks/webpack-cc708b43e5621559.js +0 -1
  88. /package/web/.next/standalone/packages/web/.next/static/{wSKJfeGluep6ETJsfyTGv → W7Ix_gUgmq_cKa_iZEKIf}/_buildManifest.js +0 -0
  89. /package/web/.next/standalone/packages/web/.next/static/{wSKJfeGluep6ETJsfyTGv → W7Ix_gUgmq_cKa_iZEKIf}/_ssgManifest.js +0 -0
  90. /package/web/.next/static/{wSKJfeGluep6ETJsfyTGv → W7Ix_gUgmq_cKa_iZEKIf}/_buildManifest.js +0 -0
  91. /package/web/.next/static/{wSKJfeGluep6ETJsfyTGv → W7Ix_gUgmq_cKa_iZEKIf}/_ssgManifest.js +0 -0
@@ -0,0 +1 @@
1
+ "use strict";exports.id=2553,exports.ids=[2553],exports.modules={21292:(a,b,c)=>{c.d(b,{a:()=>e});var d=c(85660);let e=(0,d.createServerReference)("0056a043e7b275ff1a94e951b504cb5d5b7fea4808",d.callServer,void 0,d.findSourceMapURL,"createOrReadKeylessAction")},82553:(a,b,c)=>{c.r(b),c.d(b,{createOrReadKeylessAction:()=>f.a,deleteKeylessAction:()=>e,detectKeylessEnvDriftAction:()=>g.A,syncKeylessConfigAction:()=>h});var d=c(85660);let e=(0,d.createServerReference)("0020ee235bab230e8215f50c6c37aaff8bd82b18e7",d.callServer,void 0,d.findSourceMapURL,"deleteKeylessAction");var f=c(21292),g=c(89891);let h=(0,d.createServerReference)("402ce17edc7360e1763794c2b2af42c153477dcb07",d.callServer,void 0,d.findSourceMapURL,"syncKeylessConfigAction")}};
@@ -1,3 +1,3 @@
1
1
  "use strict";exports.id=3364,exports.ids=[3364],exports.modules={3364:(a,b,c)=>{c.r(b),c.d(b,{SessionTerminal:()=>u});var d=c(92692),e=c(64583),f=c(37303);let g=(0,f.A)("file-up",[["path",{d:"M6 22a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h8a2.4 2.4 0 0 1 1.704.706l3.588 3.588A2.4 2.4 0 0 1 20 8v12a2 2 0 0 1-2 2z",key:"1oefj6"}],["path",{d:"M14 2v5a1 1 0 0 0 1 1h5",key:"wfsgrz"}],["path",{d:"M12 12v6",key:"3ahymv"}],["path",{d:"m15 15-3-3-3 3",key:"15xj92"}]]),h=(0,f.A)("square-stop",[["rect",{width:"18",height:"18",x:"3",y:"3",rx:"2",key:"afitv7"}],["rect",{x:"9",y:"9",width:"6",height:"6",rx:"1",key:"1ssd4o"}]]);var i=c(75185),j=c(60790),k=c(2625),l=(c(76680),c(71277)),m=c(1071),n=c(49071),o=c(46818),p=c(31084);let q=new Set(["queued","spawning","running","working","needs_input","stuck"]);c(62465);let r=new Set(["archived","killed","terminated","restored"]);async function s(a,b,c){let d=await fetch((0,o.S)(`/api/sessions/${encodeURIComponent(a)}/keys`,c),{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({keys:b})});if(!d.ok){let a=await d.json().catch(()=>null);throw Error(a?.error??`Failed to queue terminal input (${d.status})`)}}function t(a){let{sessionId:b,projectId:c,bridgeId:f,sessionState:t,runtimeMode:u,pendingInsert:v,immersiveMobileMode:w=!1,panelVisible:x=!0,onPendingInsertConsumed:y}=a,z=(0,l.useRef)(null),A=(0,l.useRef)(null);(0,l.useRef)(0);let B=(0,l.useRef)(0),C=(0,l.useRef)(null),D=(0,l.useRef)(null);(0,l.useRef)([]);let E=(0,l.useRef)(!1);(0,l.useRef)(null),(0,l.useRef)(0),(0,l.useRef)(Date.now());let F=(0,l.useRef)(null),G=(0,l.useRef)(null),H=(0,l.useRef)(0);(0,l.useRef)(0),(0,l.useRef)(0),(0,l.useRef)(0);let I=(0,l.useRef)(0);(0,l.useRef)(null);let J=(0,l.useMemo)(()=>t.trim().toLowerCase(),[t]),K="ttyd"===(u?.trim().toLowerCase()??null),L=K?!r.has(J):q.has(J);(0,l.useRef)(L).current=L,(0,l.useRef)(null),(0,l.useRef)(null);let[M,N]=(0,l.useState)(null),[O,P]=(0,l.useState)(null),[Q,R]=(0,l.useState)(null),[S,T]=(0,l.useState)(L),[U,V]=(0,l.useState)(null),[W,X]=(0,l.useState)(!1),[Y,Z]=(0,l.useState)(0),[$,_]=(0,l.useState)(0),[aa,ab]=(0,l.useState)(""),[ac,ad]=(0,l.useState)(!1),[ae,af]=(0,l.useState)(null),[ag,ah]=(0,l.useState)(null),[ai,aj]=(0,l.useState)(null),[ak,al]=(0,l.useState)(!1),[am,an]=(0,l.useState)(!1);(0,l.useRef)(null),(0,l.useRef)(null);let ao=(0,l.useRef)(!1);(0,l.useRef)(0),(0,l.useRef)(null),(0,l.useRef)(null);let ap=(0,l.useCallback)(()=>{},[]),aq=(0,l.useCallback)(()=>{D.current,C.current},[]),ar=(0,l.useCallback)(()=>{},[ap,aq]),as=(0,l.useCallback)(()=>{let a=function(a){if(!a)return null;try{let b=new URL(a).searchParams.get("token")?.trim();return b&&b.length>0?b:null}catch{return null}}(O);a&&function(a,b){let c;if(a&&b&&null!==a.contentWindow){try{c=new URL(a.src).origin}catch{c=""}c&&"null"!==c&&a.contentWindow.postMessage({type:"conductor-ttyd-auth-token",token:b},c)}}(D.current,a)},[O]),at=(0,l.useCallback)(()=>{let a;var b=D.current,c=Q;if(b?.contentWindow&&c){try{a=new URL(b.src).origin}catch{a=""}if(a&&"null"!==a)try{b.contentWindow.postMessage({type:"conductor-ttyd-relay-url",relayTtydWsUrl:c},a)}catch{}}},[Q]),au=(0,l.useCallback)(a=>{},[L,ar,at,as]);(0,l.useCallback)(()=>{},[L,au]),(0,l.useCallback)(async()=>{let a=aa.trim();if(0!==a.length&&!ac){ad(!0),af(null);try{let c=await fetch((0,o.S)(`/api/sessions/${encodeURIComponent(b)}/actions`,f),{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({action:"send",message:a})});if(!c.ok){let a=await c.json().catch(()=>null);throw Error(a?.error??`Failed to send message (${c.status})`)}ab(""),z.current?.focus()}catch(a){af(a instanceof Error?a.message:"Failed to send message")}finally{ad(!1)}}},[f,aa,ac,b]),(0,l.useCallback)(async()=>{try{let a=await navigator.clipboard.readText();a&&await s(b,a,f)}catch{}},[f,b]);let av=(0,l.useCallback)(()=>{A.current?.click()},[]),aw=(0,l.useCallback)(async a=>{let{files:d}=a.target;if(a.target.value="",d&&0!==d.length){aj(null),al(!0);try{for(let a of(await (0,n.P)({files:Array.from(d),projectId:c,taskRef:b,bridgeId:f})))await s(b,`\r
2
2
  [attached file: ${a}]\r
3
- `,f)}catch(a){aj(a instanceof Error?a.message:"Failed to upload attachment.")}finally{al(!1)}}},[f,c,b]),ax=(0,l.useCallback)(async()=>{await s(b,"\x03",f)},[f,b]),ay=(0,l.useCallback)(()=>{C.current},[]),az=(0,l.useCallback)(()=>{I.current+=1,V(null),B.current=0,ao.current=!0,E.current=!1,X(!1),Z(a=>a+1),_(a=>a+1)},[]),aA=L?"Connecting live terminal":"Live terminal is not active",aB=U??(L?"Reconnecting to the existing ttyd terminal.":K?"This ttyd terminal is no longer attached. It only closes after an explicit kill or archive.":`Session status is \`${J}\`. Interactive ttyd terminals only run while the agent is active.`),aC=O??M??void 0,aD=(0,p.s)(b,{bridgeId:f,tab:"terminal"});return(0,d.jsxs)("div",{className:w?"group/terminal relative flex min-h-0 min-w-0 w-full flex-1 flex-col overflow-hidden bg-[#060404]":"group/terminal relative flex min-h-0 min-w-0 w-full flex-1 flex-col overflow-hidden rounded-none border-0 bg-[#060404] lg:rounded-[14px] lg:border lg:border-white/10 lg:shadow-[inset_0_1px_0_rgba(255,255,255,0.04)]",children:[(0,d.jsxs)("div",{className:"absolute right-2 top-2 z-20 flex items-center gap-2 sm:right-3 sm:top-3",children:[(0,d.jsx)("input",{ref:A,type:"file",multiple:!0,accept:"*/*",className:"sr-only",tabIndex:-1,"aria-hidden":!0,onChange:a=>void aw(a)}),(0,d.jsx)(m.$,{type:"button",size:"icon",variant:"ghost",disabled:!L||!M||ak,className:"h-9 w-9 rounded-full border border-white/10 bg-[#141010]/92 text-[#c9c0b7] backdrop-blur-sm hover:bg-[#201818] disabled:opacity-40 sm:h-7 sm:w-7",onClick:av,"aria-label":"Attach photos or files",children:ak?(0,d.jsx)(e.A,{className:"h-3.5 w-3.5 animate-spin"}):(0,d.jsx)(g,{className:"h-3.5 w-3.5"})}),null,(0,d.jsx)(m.$,{type:"button",size:"icon",variant:"ghost",className:"h-9 w-9 rounded-full border border-white/10 bg-[#141010]/92 text-[#c9c0b7] backdrop-blur-sm hover:bg-[#201818] sm:h-7 sm:w-7",onClick:ax,"aria-label":"Soft stop (Ctrl+C)",children:(0,d.jsx)(h,{className:"h-3.5 w-3.5"})}),(0,d.jsx)(m.$,{type:"button",size:"icon",variant:"ghost",className:"h-9 w-9 rounded-full border border-white/10 bg-[#141010]/92 text-[#c9c0b7] backdrop-blur-sm hover:bg-[#201818] sm:h-7 sm:w-7",onClick:az,"aria-label":"Reload ttyd terminal",children:S?(0,d.jsx)(e.A,{className:"h-3.5 w-3.5 animate-spin"}):(0,d.jsx)(i.A,{className:"h-3.5 w-3.5"})})]}),(0,d.jsx)("div",{className:w?"min-h-0 min-w-0 h-0 flex-1 overflow-hidden px-0 pb-[env(safe-area-inset-bottom)] pt-0 w-full":"min-h-0 min-w-0 h-0 flex-1 overflow-hidden px-0.5 pb-0 pt-0.5 lg:px-1.5 lg:pb-1 lg:pt-3 w-full",children:L&&M?(0,d.jsxs)("div",{ref:C,className:"relative flex h-full min-h-0 w-full flex-1 flex-col overflow-hidden rounded-[10px] bg-[#060404] pb-[env(safe-area-inset-bottom)]",children:[W?null:(0,d.jsx)("div",{className:"absolute inset-0 z-10 flex items-center justify-center bg-[#060404]",children:(0,d.jsxs)("div",{className:"flex items-center gap-2 rounded-full border border-white/10 bg-[#141010]/92 px-3 py-2 text-[12px] text-[#c9c0b7] backdrop-blur-sm",children:[(0,d.jsx)(e.A,{className:"h-3.5 w-3.5 animate-spin"}),(0,d.jsx)("span",{children:"Loading ttyd terminal…"})]})}),(0,d.jsx)("iframe",{ref:D,title:`ttyd terminal for ${b}`,src:M,className:"block h-full min-h-0 w-full flex-1 border-0 bg-[#060404]",allow:"clipboard-read; clipboard-write",loading:"eager",onError:()=>{V("Failed to load the terminal frame. Try reload or open in a new tab.")},onLoad:()=>{let a=Date.now();H.current+=1,G.current=a,null===F.current&&(F.current=a),X(!0),V(null),ay(),as(),at(),ar()}},`${b}:${Y}`)]}):(0,d.jsx)("div",{className:"flex h-full items-center justify-center p-4",children:(0,d.jsx)("div",{className:"max-w-lg rounded-[16px] border border-white/10 bg-[#141010]/92 p-5 text-[#efe8e1] shadow-[0_24px_48px_rgba(0,0,0,0.34)]",children:(0,d.jsxs)("div",{className:"flex items-start gap-3",children:[(0,d.jsx)("div",{className:"mt-0.5 rounded-full border border-white/10 bg-[#201818] p-2 text-[#c9c0b7]",children:U?(0,d.jsx)(j.A,{className:"h-4 w-4"}):(0,d.jsx)(e.A,{className:`h-4 w-4 ${S?"animate-spin":""}`})}),(0,d.jsxs)("div",{className:"min-w-0 flex-1",children:[(0,d.jsx)("div",{className:"text-[14px] font-medium",children:aA}),(0,d.jsx)("div",{className:"mt-1 text-[12px] leading-5 text-[#a79c94]",children:aB}),aC?(0,d.jsxs)("div",{className:"mt-3 flex flex-wrap items-center gap-x-3 gap-y-1",children:[(0,d.jsx)("a",{href:aD,target:"_blank",rel:"noreferrer",className:"text-[12px] text-[#d7c6b7] underline underline-offset-4",children:"Open the full terminal page"}),(0,d.jsx)("a",{href:aC,target:"_blank",rel:"noreferrer",className:"text-[12px] text-[#a79c94] underline underline-offset-4",children:"Open the ttyd terminal directly"})]}):null]})]})})})}),ag||ai?(0,d.jsxs)("div",{className:"absolute inset-x-0 bottom-0 z-10 border-t border-white/12 bg-[#161212] px-3 py-2 text-[11px] text-[#ffb39e] backdrop-blur-sm [padding-bottom:env(safe-area-inset-bottom)]",children:[ag?(0,d.jsxs)("div",{className:"flex items-center gap-1.5",children:[(0,d.jsx)(j.A,{className:"h-3 w-3 shrink-0"}),(0,d.jsx)("span",{className:"truncate",children:ag}),(0,d.jsx)("button",{type:"button",className:"ml-auto shrink-0 text-[#8e847d] hover:text-[#c9c0b7]",onClick:()=>ah(null),children:(0,d.jsx)(k.A,{className:"h-3 w-3"})})]}):null,ai?(0,d.jsxs)("div",{className:`flex items-center gap-1.5 ${ag?"mt-2":""}`,children:[(0,d.jsx)(j.A,{className:"h-3 w-3 shrink-0"}),(0,d.jsx)("span",{className:"truncate",children:ai}),(0,d.jsx)("button",{type:"button",className:"ml-auto shrink-0 text-[#8e847d] hover:text-[#c9c0b7]",onClick:()=>aj(null),children:(0,d.jsx)(k.A,{className:"h-3 w-3"})})]}):null]}):null,null]})}let u=(0,l.memo)(function(a){return(0,d.jsx)(t,{...a})},function(a,b){var c,d;let e=a.panelVisible??!0,f=b.panelVisible??!0;return a.sessionId===b.sessionId&&a.projectId===b.projectId&&a.bridgeId===b.bridgeId&&e===f&&((c=a.pendingInsert)===(d=b.pendingInsert)||!!c&&!!d&&c.nonce===d.nonce&&c.inlineText===d.inlineText)&&(!e&&!f||a.sessionState===b.sessionState&&a.runtimeMode===b.runtimeMode&&a.immersiveMobileMode===b.immersiveMobileMode)})},31084:(a,b,c)=>{c.d(b,{J:()=>e,s:()=>f});var d=c(19954);function e(a){let b=(0,d.C0)(a);if(!b)return"/";let c=new URLSearchParams;return c.set("bridge",b),`/?${c.toString()}`}function f(a,b={}){let c,e=a.trim(),g=(0,d.DW)(e)?e:(c=(0,d.C0)(b.bridgeId))?(0,d.Bp)(c,e):e,h=new URLSearchParams,i=b.tab?.trim();i&&h.set("tab",i);let j=h.toString(),k=`/sessions/${encodeURIComponent(g)}`;return j.length>0?`${k}?${j}`:k}},49071:(a,b,c)=>{c.d(b,{P:()=>f});var d=c(46818);function e(a){return a&&"object"==typeof a?a:null}async function f({files:a,projectId:b,taskRef:c,bridgeId:g,preferAbsolute:h=!0}){if(!a.length)return[];let i=b.trim();if(!i)throw Error("Project id is required to upload attachments");let j=new FormData;j.append("projectId",i);let k=c?.trim();for(let b of(k&&j.append("taskRef",k),a))j.append("files",b);let l=await fetch((0,d.S)("/api/attachments",g),{method:"POST",body:j}),m=await l.json().catch(()=>null);if(!l.ok){let b=1===a.length?a[0]?.name??"attachment":`${a.length} attachments`;throw Error(m?.error??`Failed to upload ${b}`)}let n=(Array.isArray(m?.files)?m.files:m?[m]:[]).map(a=>(function(a,b){let c=e(a);if(!c)return null;let d=e(c.attachment);for(let a of b?[c.absolutePath,c.path,c.filePath,d?.absolutePath,d?.path,d?.filePath]:[c.path,c.absolutePath,c.filePath,d?.path,d?.absolutePath,d?.filePath])if("string"==typeof a&&a.trim().length>0)return a.trim();return null})(a,h)).filter(a=>!!a);if(0===n.length)throw Error("Attachment upload succeeded but did not return a usable file path");return n}},60790:(a,b,c)=>{c.d(b,{A:()=>d});let d=(0,c(37303).A)("circle-alert",[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["line",{x1:"12",x2:"12",y1:"8",y2:"12",key:"1pkeuh"}],["line",{x1:"12",x2:"12.01",y1:"16",y2:"16",key:"4dfq90"}]])},76680:(a,b,c)=>{c.d(b,{A:()=>d});let d=(0,c(37303).A)("send",[["path",{d:"M14.536 21.686a.5.5 0 0 0 .937-.024l6.5-19a.496.496 0 0 0-.635-.635l-19 6.5a.5.5 0 0 0-.024.937l7.93 3.18a2 2 0 0 1 1.112 1.11z",key:"1ffxy3"}],["path",{d:"m21.854 2.147-10.94 10.939",key:"12cjpa"}]])}};
3
+ `,f)}catch(a){aj(a instanceof Error?a.message:"Failed to upload attachment.")}finally{al(!1)}}},[f,c,b]),ax=(0,l.useCallback)(async()=>{await s(b,"\x03",f)},[f,b]),ay=(0,l.useCallback)(()=>{C.current},[]),az=(0,l.useCallback)(()=>{I.current+=1,V(null),B.current=0,ao.current=!0,E.current=!1,X(!1),Z(a=>a+1),_(a=>a+1)},[]),aA=L?"Connecting live terminal":"Live terminal is not active",aB=U??(L?"Reconnecting to the existing terminal.":K?"This terminal is no longer attached. It only closes after an explicit kill or archive.":`Session status is \`${J}\`. Interactive terminals only run while the agent is active.`),aC=O??M??void 0,aD=(0,p.s)(b,{bridgeId:f,tab:"terminal"});return(0,d.jsxs)("div",{className:w?"group/terminal relative flex min-h-0 min-w-0 w-full flex-1 flex-col overflow-hidden bg-[#060404]":"group/terminal relative flex min-h-0 min-w-0 w-full flex-1 flex-col overflow-hidden rounded-none border-0 bg-[#060404] lg:rounded-[14px] lg:border lg:border-white/10 lg:shadow-[inset_0_1px_0_rgba(255,255,255,0.04)]",children:[(0,d.jsxs)("div",{className:"absolute right-2 top-2 z-20 flex items-center gap-2 sm:right-3 sm:top-3",children:[(0,d.jsx)("input",{ref:A,type:"file",multiple:!0,accept:"*/*",className:"sr-only",tabIndex:-1,"aria-hidden":!0,onChange:a=>void aw(a)}),(0,d.jsx)(m.$,{type:"button",size:"icon",variant:"ghost",disabled:!L||!M||ak,className:"h-9 w-9 rounded-full border border-white/10 bg-[#141010]/92 text-[#c9c0b7] backdrop-blur-sm hover:bg-[#201818] disabled:opacity-40 sm:h-7 sm:w-7",onClick:av,"aria-label":"Attach photos or files",children:ak?(0,d.jsx)(e.A,{className:"h-3.5 w-3.5 animate-spin"}):(0,d.jsx)(g,{className:"h-3.5 w-3.5"})}),null,(0,d.jsx)(m.$,{type:"button",size:"icon",variant:"ghost",className:"h-9 w-9 rounded-full border border-white/10 bg-[#141010]/92 text-[#c9c0b7] backdrop-blur-sm hover:bg-[#201818] sm:h-7 sm:w-7",onClick:ax,"aria-label":"Soft stop (Ctrl+C)",children:(0,d.jsx)(h,{className:"h-3.5 w-3.5"})}),(0,d.jsx)(m.$,{type:"button",size:"icon",variant:"ghost",className:"h-9 w-9 rounded-full border border-white/10 bg-[#141010]/92 text-[#c9c0b7] backdrop-blur-sm hover:bg-[#201818] sm:h-7 sm:w-7",onClick:az,"aria-label":"Reload terminal",children:S?(0,d.jsx)(e.A,{className:"h-3.5 w-3.5 animate-spin"}):(0,d.jsx)(i.A,{className:"h-3.5 w-3.5"})})]}),(0,d.jsx)("div",{className:w?"min-h-0 min-w-0 h-0 flex-1 overflow-hidden px-0 pb-[env(safe-area-inset-bottom)] pt-0 w-full":"min-h-0 min-w-0 h-0 flex-1 overflow-hidden px-0.5 pb-0 pt-0.5 lg:px-1.5 lg:pb-1 lg:pt-3 w-full",children:L&&M?(0,d.jsxs)("div",{ref:C,className:"relative flex h-full min-h-0 w-full flex-1 flex-col overflow-hidden rounded-[10px] bg-[#060404] pb-[env(safe-area-inset-bottom)]",children:[W?null:(0,d.jsx)("div",{className:"absolute inset-0 z-10 flex items-center justify-center bg-[#060404]",children:(0,d.jsxs)("div",{className:"flex items-center gap-2 rounded-full border border-white/10 bg-[#141010]/92 px-3 py-2 text-[12px] text-[#c9c0b7] backdrop-blur-sm",children:[(0,d.jsx)(e.A,{className:"h-3.5 w-3.5 animate-spin"}),(0,d.jsx)("span",{children:"Loading terminal…"})]})}),(0,d.jsx)("iframe",{ref:D,title:`terminal for ${b}`,src:M,className:"block h-full min-h-0 w-full flex-1 border-0 bg-[#060404]",allow:"clipboard-read; clipboard-write",loading:"eager",onError:()=>{V("Failed to load the terminal frame. Try reload or open in a new tab.")},onLoad:()=>{let a=Date.now();H.current+=1,G.current=a,null===F.current&&(F.current=a),X(!0),V(null),ay(),as(),at(),ar()}},`${b}:${Y}`)]}):(0,d.jsx)("div",{className:"flex h-full items-center justify-center p-4",children:(0,d.jsx)("div",{className:"max-w-lg rounded-[16px] border border-white/10 bg-[#141010]/92 p-5 text-[#efe8e1] shadow-[0_24px_48px_rgba(0,0,0,0.34)]",children:(0,d.jsxs)("div",{className:"flex items-start gap-3",children:[(0,d.jsx)("div",{className:"mt-0.5 rounded-full border border-white/10 bg-[#201818] p-2 text-[#c9c0b7]",children:U?(0,d.jsx)(j.A,{className:"h-4 w-4"}):(0,d.jsx)(e.A,{className:`h-4 w-4 ${S?"animate-spin":""}`})}),(0,d.jsxs)("div",{className:"min-w-0 flex-1",children:[(0,d.jsx)("div",{className:"text-[14px] font-medium",children:aA}),(0,d.jsx)("div",{className:"mt-1 text-[12px] leading-5 text-[#a79c94]",children:aB}),aC?(0,d.jsxs)("div",{className:"mt-3 flex flex-wrap items-center gap-x-3 gap-y-1",children:[(0,d.jsx)("a",{href:aD,target:"_blank",rel:"noreferrer",className:"text-[12px] text-[#d7c6b7] underline underline-offset-4",children:"Open the full terminal page"}),(0,d.jsx)("a",{href:aC,target:"_blank",rel:"noreferrer",className:"text-[12px] text-[#a79c94] underline underline-offset-4",children:"Open the terminal directly"})]}):null]})]})})})}),ag||ai?(0,d.jsxs)("div",{className:"absolute inset-x-0 bottom-0 z-10 border-t border-white/12 bg-[#161212] px-3 py-2 text-[11px] text-[#ffb39e] backdrop-blur-sm [padding-bottom:env(safe-area-inset-bottom)]",children:[ag?(0,d.jsxs)("div",{className:"flex items-center gap-1.5",children:[(0,d.jsx)(j.A,{className:"h-3 w-3 shrink-0"}),(0,d.jsx)("span",{className:"truncate",children:ag}),(0,d.jsx)("button",{type:"button",className:"ml-auto shrink-0 text-[#8e847d] hover:text-[#c9c0b7]",onClick:()=>ah(null),children:(0,d.jsx)(k.A,{className:"h-3 w-3"})})]}):null,ai?(0,d.jsxs)("div",{className:`flex items-center gap-1.5 ${ag?"mt-2":""}`,children:[(0,d.jsx)(j.A,{className:"h-3 w-3 shrink-0"}),(0,d.jsx)("span",{className:"truncate",children:ai}),(0,d.jsx)("button",{type:"button",className:"ml-auto shrink-0 text-[#8e847d] hover:text-[#c9c0b7]",onClick:()=>aj(null),children:(0,d.jsx)(k.A,{className:"h-3 w-3"})})]}):null]}):null,null]})}let u=(0,l.memo)(function(a){return(0,d.jsx)(t,{...a})},function(a,b){var c,d;let e=a.panelVisible??!0,f=b.panelVisible??!0;return a.sessionId===b.sessionId&&a.projectId===b.projectId&&a.bridgeId===b.bridgeId&&e===f&&((c=a.pendingInsert)===(d=b.pendingInsert)||!!c&&!!d&&c.nonce===d.nonce&&c.inlineText===d.inlineText)&&(!e&&!f||a.sessionState===b.sessionState&&a.runtimeMode===b.runtimeMode&&a.immersiveMobileMode===b.immersiveMobileMode)})},31084:(a,b,c)=>{c.d(b,{J:()=>e,s:()=>f});var d=c(19954);function e(a){let b=(0,d.C0)(a);if(!b)return"/";let c=new URLSearchParams;return c.set("bridge",b),`/?${c.toString()}`}function f(a,b={}){let c,e=a.trim(),g=(0,d.DW)(e)?e:(c=(0,d.C0)(b.bridgeId))?(0,d.Bp)(c,e):e,h=new URLSearchParams,i=b.tab?.trim();i&&h.set("tab",i);let j=h.toString(),k=`/sessions/${encodeURIComponent(g)}`;return j.length>0?`${k}?${j}`:k}},49071:(a,b,c)=>{c.d(b,{P:()=>f});var d=c(46818);function e(a){return a&&"object"==typeof a?a:null}async function f({files:a,projectId:b,taskRef:c,bridgeId:g,preferAbsolute:h=!0}){if(!a.length)return[];let i=b.trim();if(!i)throw Error("Project id is required to upload attachments");let j=new FormData;j.append("projectId",i);let k=c?.trim();for(let b of(k&&j.append("taskRef",k),a))j.append("files",b);let l=await fetch((0,d.S)("/api/attachments",g),{method:"POST",body:j}),m=await l.json().catch(()=>null);if(!l.ok){let b=1===a.length?a[0]?.name??"attachment":`${a.length} attachments`;throw Error(m?.error??`Failed to upload ${b}`)}let n=(Array.isArray(m?.files)?m.files:m?[m]:[]).map(a=>(function(a,b){let c=e(a);if(!c)return null;let d=e(c.attachment);for(let a of b?[c.absolutePath,c.path,c.filePath,d?.absolutePath,d?.path,d?.filePath]:[c.path,c.absolutePath,c.filePath,d?.path,d?.absolutePath,d?.filePath])if("string"==typeof a&&a.trim().length>0)return a.trim();return null})(a,h)).filter(a=>!!a);if(0===n.length)throw Error("Attachment upload succeeded but did not return a usable file path");return n}},60790:(a,b,c)=>{c.d(b,{A:()=>d});let d=(0,c(37303).A)("circle-alert",[["circle",{cx:"12",cy:"12",r:"10",key:"1mglay"}],["line",{x1:"12",x2:"12",y1:"8",y2:"12",key:"1pkeuh"}],["line",{x1:"12",x2:"12.01",y1:"16",y2:"16",key:"4dfq90"}]])},76680:(a,b,c)=>{c.d(b,{A:()=>d});let d=(0,c(37303).A)("send",[["path",{d:"M14.536 21.686a.5.5 0 0 0 .937-.024l6.5-19a.496.496 0 0 0-.635-.635l-19 6.5a.5.5 0 0 0-.024.937l7.93 3.18a2 2 0 0 1 1.112 1.11z",key:"1ffxy3"}],["path",{d:"m21.854 2.147-10.94 10.939",key:"12cjpa"}]])}};
@@ -1 +1 @@
1
- "use strict";exports.id=3990,exports.ids=[3990],exports.modules={25985:(a,b,c)=>{c.d(b,{FM:()=>g,JZ:()=>f,N7:()=>h});var d=c(32679),e=c(70209);async function f(a){let b=await (0,d.ny)(a),c=new Headers({"x-conductor-proxy-authorized":"true","x-conductor-access-authenticated":b.authenticated||"local"===b.provider?"true":"false"});b.role&&c.set("x-conductor-access-role",b.role),b.email&&c.set("x-conductor-access-email",b.email),b.provider&&c.set("x-conductor-access-provider",b.provider);let e=process.env.CONDUCTOR_PROXY_AUTH_SECRET?.trim()||null;return e&&c.set("x-conductor-proxy-secret",e),c}async function g(a,b,c={}){let h=await (0,d.sB)(a,c.role??"viewer");if(h)return h;if(c.requireActionGuard){let b=(0,d.G1)(a);if(b)return b}return(0,e.zP)(a,b,{headers:await f(a)})}async function h(a,b,c={}){let g=await (0,d.sB)(a,c.role??"viewer");if(g)return g;if(c.requireActionGuard){let b=(0,d.G1)(a);if(b)return b}return(0,e.X_)(a,b,{headers:await f(a)})}},28480:(a,b,c)=>{c.a(a,async(a,d)=>{try{c.d(b,{Ob:()=>A});var e=c(71553),f=c(31421),g=c(4573),h=c(73024),i=c(77030),j=c(76760),k=c(8856),l=c(34140),m=c(36026),n=c(94842),o=c(59506),p=a([k,l]);[k,l]=p.then?(await p)():p;let B={width:1440,height:960},C=["127.0.0.1","localhost","::1","0.0.0.0"],D=/^[a-z][a-z\d+.-]*:\/\//i,E=/^(?:localhost|127\.0\.0\.1|0\.0\.0\.0|\[::1\]|::1)(?::\d+)?(?:\/.*)?$/i;function q(a){return a.replace(/^\[(.*)\]$/,"$1").toLowerCase()}function r(a){let b=q(a);return C.includes(b)}function s(a){let b=a.split(".").map(a=>Number.parseInt(a,10));if(4!==b.length||b.some(a=>!Number.isInteger(a)||a<0||a>255))return!0;let[c,d]=b;return 0===c||10===c||127===c||100===c&&d>=64&&d<=127||169===c&&254===d||172===c&&d>=16&&d<=31||192===c&&168===d||198===c&&(18===d||19===d)||c>=224}function t(a){let b=q(a),c=(0,i.isIP)(b);if(4===c)return s(b);if(6===c){let a,c;return c=(a=q(b).toLowerCase()).startsWith("::ffff:")?a.slice(7):null,"::"===a||"::1"===a||a.startsWith("fe8")||a.startsWith("fe9")||a.startsWith("fea")||a.startsWith("feb")||a.startsWith("fc")||a.startsWith("fd")||!!c&&s(c)}return!1}async function u(a){if(process.env.CONDUCTOR_ALLOW_UNSAFE_PREVIEW_HOSTS?.trim().toLowerCase()==="true")return;let b=new URL(a);if(!r(b.hostname)){if(t(b.hostname))throw Error("Preview navigation to private network hosts is blocked. Use loopback URLs for local dev servers or set CONDUCTOR_ALLOW_UNSAFE_PREVIEW_HOSTS=true to override.");if((await (0,e.lookup)(b.hostname,{all:!0,verbatim:!0}).catch(()=>[])).some(a=>t(a.address)))throw Error("Preview navigation resolved to a private network address and was blocked. Set CONDUCTOR_ALLOW_UNSAFE_PREVIEW_HOSTS=true only if you intentionally trust that target.")}}function v(a,b){if(!b)return"direct";try{let c=new URL(a),d=r(q(c.hostname));if(b.allowedOrigins.includes(c.origin))return"bridge";return d?"blocked":"direct"}catch{return"direct"}}function w(a,b){try{let c=new URL(a),d=new URL(b);return c.origin===d.origin}catch{return a===b}}let F=globalThis;function x(a,b){a.push(b),a.length>150&&a.splice(0,a.length-150)}function y(a){return`${a}-${Date.now()}-${Math.random().toString(36).slice(2,8)}`}function z(a){return(a??"").replace(/\s+/g," ").trim()}class G{async getBrowser(){return this.browserPromise||(this.browserPromise=k.default.launch({headless:!0,executablePath:function(){let a=process.env.PUPPETEER_EXECUTABLE_PATH?.trim();if(a)return a;for(let a of[l.ChromeReleaseChannel.STABLE,l.ChromeReleaseChannel.CANARY,l.ChromeReleaseChannel.BETA,l.ChromeReleaseChannel.DEV])try{return(0,l.computeSystemExecutablePath)({browser:l.Browser.CHROME,channel:a})}catch{}let b=function(){for(let a of"darwin"===process.platform?["/Applications/Google Chrome.app/Contents/MacOS/Google Chrome","/Applications/Google Chrome Canary.app/Contents/MacOS/Google Chrome Canary","/Applications/Chromium.app/Contents/MacOS/Chromium","/Applications/Microsoft Edge.app/Contents/MacOS/Microsoft Edge","/Applications/Brave Browser.app/Contents/MacOS/Brave Browser"]:"win32"===process.platform?[process.env.PROGRAMFILES,process.env["PROGRAMFILES(X86)"],process.env.LOCALAPPDATA].filter(a=>!!a?.trim()).flatMap(a=>[(0,j.join)(a,"Google","Chrome","Application","chrome.exe"),(0,j.join)(a,"Chromium","Application","chrome.exe"),(0,j.join)(a,"Microsoft","Edge","Application","msedge.exe"),(0,j.join)(a,"BraveSoftware","Brave-Browser","Application","brave.exe")]):["google-chrome-stable","google-chrome","chromium-browser","chromium","microsoft-edge","brave-browser"]){if(a.includes("/")||a.includes("\\")){if((0,h.existsSync)(a))return a;continue}let b=function(a){let b="win32"===process.platform?"where":"which";try{return(0,f.execFileSync)(b,[a],{encoding:"utf8",stdio:["ignore","pipe","ignore"]}).trim().split(/\r?\n/).map(a=>a.trim()).find(Boolean)||null}catch{return null}}(a);if(b)return b}return null}();if(b)return b;throw Error("Chrome/Chromium not found. Install a supported browser or set PUPPETEER_EXECUTABLE_PATH.")}(),defaultViewport:B,args:["--disable-dev-shm-usage","--disable-background-networking","--no-first-run","--no-default-browser-check"]})),this.browserPromise}getState(a){let b=this.states.get(a);return b||(b={sessionId:a,context:null,page:null,destroying:!1,activeFrameId:null,selectedElement:null,consoleLogs:[],networkLogs:[],lastError:null,frameIds:new WeakMap,requestStarts:new WeakMap,frameSequence:0,bridgePreview:null,requestInterceptionEnabled:!1},this.states.set(a,b)),b}async ensureContext(a,b){return a.context&&!a.context.closed||(a.context=await b.createBrowserContext()),a.context}async destroySession(a,b={}){let c=this.states.get(a);if(!c||c.destroying)return;c.destroying=!0;let d=c.page,e=c.context;try{!1!==b.closePage&&d&&!d.isClosed()&&await d.close().catch(()=>{}),e&&!e.closed&&await e.close().catch(()=>{})}finally{this.states.delete(a)}}ensureFrameId(a,b){let c=a.frameIds.get(b);if(c)return c;let d=`frame-${++a.frameSequence}`;return a.frameIds.set(b,d),d}async configureBridgePreview(a,b,c){let d=this.getState(a);d.bridgePreview=b&&c?{...b,forwardedHeaders:Object.fromEntries(new Headers(c).entries())}:null,d.page&&!d.page.isClosed()&&await this.syncRequestInterception(d,d.page)}async syncRequestInterception(a,b,c){let d="bridge"===v(c??b.url(),a.bridgePreview);a.requestInterceptionEnabled!==d&&(await b.setRequestInterception(d),a.requestInterceptionEnabled=d)}async handleBridgePreviewRequest(a,b){let c,d=a.bridgePreview;if(!d)return void await b.continue();try{c=new URL(b.url())}catch{await b.abort("blockedbyclient");return}if("http:"!==c.protocol&&"https:"!==c.protocol||!d.allowedOrigins.includes(c.origin))return void await b.abort("blockedbyclient");let e="GET"===b.method()||"HEAD"===b.method()?null:b.postData()??null,f=await (0,n.LN)(d.bridgeId,d.forwardedHeaders,{sessionId:d.sessionId,method:b.method(),url:c.toString(),headers:function(a){let b={};for(let[c,d]of Object.entries(a)){let a=c.trim().toLowerCase();a&&"host"!==a&&"connection"!==a&&"proxy-connection"!==a&&"keep-alive"!==a&&"transfer-encoding"!==a&&"content-length"!==a&&"accept-encoding"!==a&&(b[a]=d)}return b}(b.headers()),bodyBase64:e?g.Buffer.from(e).toString("base64"):null});await b.respond({status:f.status,headers:f.headers,body:f.bodyBase64?g.Buffer.from(f.bodyBase64,"base64"):g.Buffer.alloc(0)})}attachListeners(a,b){b.on("console",b=>{this.captureConsole(a,b)}),b.on("pageerror",b=>{let c=b instanceof Error?b.message:String(b);x(a.consoleLogs,{id:y("pageerror"),kind:"pageerror",level:"error",message:c,timestamp:new Date().toISOString()}),a.lastError=c}),b.on("request",b=>{a.requestStarts.set(b,Date.now()),a.requestInterceptionEnabled&&this.handleBridgePreviewRequest(a,b).catch(async c=>{a.lastError=c instanceof Error?c.message:"Bridge preview request failed",x(a.networkLogs,{id:y("preview-request"),kind:"network",level:"error",message:a.lastError,timestamp:new Date().toISOString(),url:b.url(),method:b.method(),status:null,resourceType:b.resourceType()});try{await b.abort("failed")}catch{}})}),b.on("response",b=>{this.captureResponse(a,b)}),b.on("requestfailed",b=>{x(a.networkLogs,{id:y("requestfailed"),kind:"network",level:"error",message:b.failure()?.errorText??"Request failed",timestamp:new Date().toISOString(),url:b.url(),method:b.method(),status:null,resourceType:b.resourceType()})}),b.on("framenavigated",c=>{let d=this.ensureFrameId(a,c);c===b.mainFrame()&&(a.activeFrameId??=d),a.selectedElement?.frameId===d&&(a.selectedElement=null)}),b.on("close",()=>{this.destroySession(a.sessionId,{closePage:!1})})}captureConsole(a,b){let c=b.location();x(a.consoleLogs,{id:y("console"),kind:"console",level:b.type(),message:z(b.text()),timestamp:new Date().toISOString(),url:c.url??null})}captureResponse(a,b){let c=b.request();x(a.networkLogs,{id:y("network"),kind:"network",level:b.ok()?"info":"error",message:`${c.method()} ${b.status()} ${z(b.statusText())}`.trim(),timestamp:new Date().toISOString(),url:b.url(),method:c.method(),status:b.status(),resourceType:c.resourceType()})}async ensurePage(a){let b=await this.getBrowser(),c=this.getState(a);if(c.page&&!c.page.isClosed())return await this.syncRequestInterception(c,c.page),{state:c,page:c.page};let d=await this.ensureContext(c,b),e=await d.newPage();return await e.setViewport(B),e.setDefaultNavigationTimeout(3e4),e.setDefaultTimeout(15e3),this.attachListeners(c,e),await this.syncRequestInterception(c,e),c.page=e,c.activeFrameId=this.ensureFrameId(c,e.mainFrame()),c.selectedElement=null,c.lastError=null,{state:c,page:e}}collectFrames(a,b){let c=b.frames().map(c=>{let d=this.ensureFrameId(a,c),e=c.parentFrame();return{id:d,name:c.name()||(c===b.mainFrame()?"Main frame":"Untitled frame"),url:c.url(),parentId:e?this.ensureFrameId(a,e):null,isMain:c===b.mainFrame()}});return c.some(b=>b.id===a.activeFrameId)||(a.activeFrameId=c.find(a=>a.isMain)?.id??c[0]?.id??null),a.selectedElement&&!c.some(b=>b.id===a.selectedElement?.frameId)&&(a.selectedElement=null),c}resolveFrame(a,b,c){let d=c??a.activeFrameId,e=b.frames();return d?e.find(b=>this.ensureFrameId(a,b)===d)??b.mainFrame():b.mainFrame()}async navigationProducedUsablePage(a,b,c,d){if(!(d instanceof Error?d.message:String(d)).toLowerCase().includes("net::err_aborted"))return!1;let e=a.url();if("about:blank"===e||e===c&&!w(e,b)||!w(e,b))return!1;try{let b=await a.evaluate(()=>document.readyState);return"interactive"===b||"complete"===b}catch{return!1}}async snapshotElement(a,b,c){return a.evaluate(({selector:a,point:b})=>{var c,d;let e,f,g,h;function i(a){return(a??"").replace(/\s+/g," ").trim()}let j=null;return("string"==typeof a&&a.trim()?j=document.querySelector(a):b&&(j=document.elementFromPoint(b.x,b.y)),j)?(c=j,e=i(c.outerHTML).slice(0,400),f=i(c.textContent),g=c.getBoundingClientRect(),h=[...c.attributes].reduce((a,b)=>(a&&Object.keys(a).length>=12||(a[b.name]=b.value),a),{}),{selector:function(a){let b=[],c=a;for(;c&&b.length<5;){let a=function(a){let b=a.tagName.toLowerCase(),c=i(a.getAttribute("id"));if(c)return`#${CSS.escape(c)}`;let d=[...a.classList].slice(0,2).map(a=>`.${CSS.escape(a)}`).join(""),e="",f=a.parentElement;if(f){let b=[...f.children].filter(b=>b.tagName===a.tagName);b.length>1&&(e=`:nth-of-type(${b.indexOf(a)+1})`)}return`${b}${d}${e}`}(c);if(b.unshift(a),a.startsWith("#"))break;c=c.parentElement}return b.join(" > ")}(c),tag:c.tagName.toLowerCase(),text:f.slice(0,220),role:function(a){let b=i(a.getAttribute("role"));if(b)return b;let c=a.tagName.toLowerCase();return"button"===c?"button":"a"===c&&a.hasAttribute("href")?"link":"input"===c?(a.getAttribute("type")??"textbox").toLowerCase():null}(c),name:(d=f.slice(0,220),i(c.getAttribute("aria-label")??c.getAttribute("title")??c.getAttribute("placeholder")??c.getAttribute("alt")??d)||null),interactive:function(a){if(!(a instanceof HTMLElement))return!1;let b=a.tagName.toLowerCase();return!!(["button","input","select","textarea","summary"].includes(b)||"a"===b&&a.hasAttribute("href")||a.hasAttribute("contenteditable")||a.hasAttribute("onclick")||(a.getAttribute("role")??"").match(/button|link|tab|checkbox|radio|switch|textbox|menuitem/i))||a.tabIndex>=0}(c),id:i(c.getAttribute("id"))||null,classes:[...c.classList].slice(0,6),htmlPreview:e,bounds:{x:g.x,y:g.y,width:g.width,height:g.height},attributes:h}):null},{selector:b,point:c})}async connect(a,b){let{state:c,page:d}=await this.ensurePage(a),e=function(a){let b,c=!(b=a.trim())||D.test(b)?b:E.test(b)?`http://${b}`:b;try{let a=new URL(c),b=a.toString(),d=q(a.hostname),e=a.protocol.toLowerCase();if("http:"!==e&&"https:"!==e)throw Error(`Navigation blocked: only http and https URLs are allowed. Got protocol "${a.protocol}".`);if(r(d)){let a=new Set([b]);for(let c of C){let d=new URL(b);d.hostname=c,a.add(d.toString())}return[...a]}return[b]}catch(a){if(a instanceof Error&&a.message.startsWith("Navigation blocked:"))throw a;throw Error(`Navigation blocked: could not parse "${c}" as a valid URL.`)}}(b),f=null;for(let a of e){let b=v(a,c.bridgePreview);if("blocked"===b){f=Error("Bridge preview only allows navigation to the session's reported local dev server origin.");continue}let e=d.url();try{"direct"===b&&await u(a),await this.syncRequestInterception(c,d,a),await d.goto(a,{waitUntil:"domcontentloaded"}),await this.syncRequestInterception(c,d),c.selectedElement=null,c.lastError=null,c.activeFrameId=this.ensureFrameId(c,d.mainFrame());return}catch(b){if(await this.navigationProducedUsablePage(d,a,e,b)){await this.syncRequestInterception(c,d),c.selectedElement=null,c.lastError=null,c.activeFrameId=this.ensureFrameId(c,d.mainFrame());return}f=b}}throw c.lastError=f instanceof Error?f.message:"Failed to connect preview",f??Error("Failed to connect preview")}async runCommand(a,b){switch(b.command){case"connect":case"navigate":await this.connect(a,b.url);return;case"reload":{let{state:b,page:c}=await this.ensurePage(a);try{await c.reload({waitUntil:"domcontentloaded"}),b.lastError=null}catch(a){throw b.lastError=a instanceof Error?a.message:"Failed to reload preview",a}return}case"goBack":{let{state:b,page:c}=await this.ensurePage(a);try{await this.syncRequestInterception(b,c),await c.goBack({waitUntil:"domcontentloaded",timeout:1500}),await this.syncRequestInterception(b,c),b.selectedElement=null,b.lastError=null,b.activeFrameId=this.ensureFrameId(b,c.mainFrame())}catch(a){throw b.lastError=a instanceof Error?a.message:"Failed to go back",a}return}case"goForward":{let{state:b,page:c}=await this.ensurePage(a);try{await this.syncRequestInterception(b,c),await c.goForward({waitUntil:"domcontentloaded",timeout:1500}),await this.syncRequestInterception(b,c),b.selectedElement=null,b.lastError=null,b.activeFrameId=this.ensureFrameId(b,c.mainFrame())}catch(a){throw b.lastError=a instanceof Error?a.message:"Failed to go forward",a}return}case"selectFrame":{let{state:c,page:d}=await this.ensurePage(a),e=this.resolveFrame(c,d,b.frameId);c.activeFrameId=this.ensureFrameId(c,e),c.selectedElement=null,c.lastError=null;return}case"clickAtPoint":{let{state:c,page:d}=await this.ensurePage(a);c.selectedElement=null,c.lastError=null;let e=d.waitForNavigation({waitUntil:"domcontentloaded",timeout:1500}).catch(()=>null);await d.mouse.click(b.x,b.y),await e,await d.waitForNetworkIdle({idleTime:250,timeout:1e3}).catch(()=>null);return}case"typeText":{let{state:c,page:d}=await this.ensurePage(a);if(!b.text)return;await d.keyboard.type(b.text),c.lastError=null;return}case"pressKey":{let{state:c,page:d}=await this.ensurePage(a);c.lastError=null;let e=d.waitForNavigation({waitUntil:"domcontentloaded",timeout:1500}).catch(()=>null);await d.keyboard.press(b.key),await e,await d.waitForNetworkIdle({idleTime:250,timeout:1e3}).catch(()=>null);return}case"selectAtPoint":{let{state:c,page:d}=await this.ensurePage(a),e=this.resolveFrame(c,d,c.activeFrameId);if(e!==d.mainFrame())throw Error("Point selection is only available for the main frame. Pick nested frame elements from the DOM list.");let f=await this.snapshotElement(e,void 0,{x:b.x,y:b.y});if(!f)throw Error("No element found at the selected point");c.selectedElement={...f,frameId:this.ensureFrameId(c,e),frameName:e.name()||"Main frame",frameUrl:e.url()},c.lastError=null;return}case"selectBySelector":{let{state:c,page:d}=await this.ensurePage(a),e=this.resolveFrame(c,d,b.frameId),f=await this.snapshotElement(e,b.selector);if(!f)throw Error(`Element not found for selector: ${b.selector}`);c.selectedElement={...f,frameId:this.ensureFrameId(c,e),frameName:e.name()||(e===d.mainFrame()?"Main frame":"Frame"),frameUrl:e.url()},c.activeFrameId=this.ensureFrameId(c,e),c.lastError=null;return}default:return}}async inspectDom(a,b,c=!1){let{state:d,page:e}=await this.ensurePage(a),f=this.resolveFrame(d,e,b),g=await f.evaluate(({interactiveOnly:a,limit:b})=>{function c(a){return(a??"").replace(/\s+/g," ").trim()}let d=document.body??document.documentElement,e=document.createTreeWalker(d,NodeFilter.SHOW_ELEMENT),f=[],g=0;for(;e.nextNode();){g+=1;let d=e.currentNode;if(!(d instanceof Element))continue;let h=function(a){if(!(a instanceof HTMLElement))return!1;let b=a.tagName.toLowerCase();return!!(["button","input","select","textarea","summary"].includes(b)||"a"===b&&a.hasAttribute("href")||a.hasAttribute("contenteditable")||(a.getAttribute("role")??"").match(/button|link|tab|checkbox|radio|switch|textbox|menuitem/i))||a.tabIndex>=0}(d);if(a&&!h)continue;let i=c(d.textContent).slice(0,220),j=d.getBoundingClientRect();if(f.push({selector:function(a){let b=[],d=a;for(;d&&b.length<5;){let a=function(a){let b=a.tagName.toLowerCase(),d=c(a.getAttribute("id"));if(d)return`#${CSS.escape(d)}`;let e=[...a.classList].slice(0,2).map(a=>`.${CSS.escape(a)}`).join(""),f="",g=a.parentElement;if(g){let b=[...g.children].filter(b=>b.tagName===a.tagName);b.length>1&&(f=`:nth-of-type(${b.indexOf(a)+1})`)}return`${b}${e}${f}`}(d);if(b.unshift(a),a.startsWith("#"))break;d=d.parentElement}return b.join(" > ")}(d),tag:d.tagName.toLowerCase(),text:i,role:function(a){let b=c(a.getAttribute("role"));if(b)return b;let d=a.tagName.toLowerCase();return"button"===d?"button":"a"===d&&a.hasAttribute("href")?"link":"input"===d?(a.getAttribute("type")??"textbox").toLowerCase():null}(d),name:c(d.getAttribute("aria-label")??d.getAttribute("title")??d.getAttribute("placeholder")??d.getAttribute("alt")??i)||null,interactive:h,id:c(d.getAttribute("id"))||null,classes:[...d.classList].slice(0,6),htmlPreview:c(d.outerHTML).slice(0,320),bounds:{x:j.x,y:j.y,width:j.width,height:j.height}}),f.length>=b)break}return{nodes:f,truncated:f.length>=b||g>f.length}},{interactiveOnly:c,limit:250});return{frameId:this.ensureFrameId(d,f),nodes:g.nodes,truncated:g.truncated}}async takeScreenshot(a){let{page:b}=await this.ensurePage(a);return"about:blank"===b.url()?null:b.screenshot({type:"png"})}async getNavigationCapabilities(a){if(!a||a.isClosed()||"about:blank"===a.url())return{canGoBack:!1,canGoForward:!1};let b=null;try{b=await a.createCDPSession();let c=await b.send("Page.getNavigationHistory");return{canGoBack:c.currentIndex>0,canGoForward:c.currentIndex<c.entries.length-1}}catch{return{canGoBack:!1,canGoForward:!1}}finally{await b?.detach().catch(()=>null)}}async getStatus(a,b){let c=this.states.get(a)??null,d=c?.page&&!c.page.isClosed()?c.page:null,e=c&&d?this.collectFrames(c,d):[],{canGoBack:f,canGoForward:g}=await this.getNavigationCapabilities(d),h=null;if(d&&"about:blank"!==d.url())try{h=await d.title()}catch{h=null}return{connected:!!(d&&"about:blank"!==d.url()),candidateUrls:b,currentUrl:d&&"about:blank"!==d.url()?d.url():null,title:h,tunnelUrl:null,tunnelLocalOrigin:null,canGoBack:f,canGoForward:g,frames:e,activeFrameId:c?.activeFrameId??null,selectedElement:c?.selectedElement??null,consoleLogs:c?.consoleLogs??[],networkLogs:c?.networkLogs??[],lastError:c?.lastError??null,screenshotKey:`${Date.now()}`}}constructor(){this.browserPromise=null,this.states=new Map}}function A(){return!function(){let a=(0,m._)();if(!a)return!1;try{let b=new URL(a).hostname.toLowerCase();return"localhost"===b||"127.0.0.1"===b||"0.0.0.0"===b||"::1"===b||"[::1]"===b}catch{return!1}}()?(0,o.k)():(F._conductorPreviewBrowserManager||(F._conductorPreviewBrowserManager=new G),F._conductorPreviewBrowserManager)}d()}catch(a){d(a)}})},36026:(a,b,c)=>{function d(a){let b=a?.trim();if(!b)return null;try{let a=new URL(b);if("http:"!==a.protocol&&"https:"!==a.protocol)return null;return a.toString()}catch{return null}}function e(a){let b=a?.trim();if(!b)return null;let c=Number.parseInt(b,10);return!Number.isInteger(c)||c<1||c>65535?null:c}function f(){let a=d(process.env.CONDUCTOR_BACKEND_URL);if(a)return a;let b=d(process.env.NEXT_PUBLIC_CONDUCTOR_BACKEND_URL);if(b)return b;let c=e(process.env.CONDUCTOR_BACKEND_PORT);if(null!==c)return`http://127.0.0.1:${c}`;let f=e(process.env.NEXT_PUBLIC_CONDUCTOR_BACKEND_PORT);return null!==f?`http://127.0.0.1:${f}`:null}function g(){let a=f();if(!a)throw Error("Rust backend URL is not configured");return a}c.d(b,{B:()=>g,_:()=>f})},42599:(a,b,c)=>{c.d(b,{Ix:()=>q});var d=c(51455),e=c(94842),f=c(36026),g=c(91752);let h=/(?:127\.0\.0\.1|0\.0\.0\.0|localhost|::1|\[::1\])/i,i=/\bhttps?:\/\/[^\s"'<>`]+/gi,j=/^[a-z][a-z\d+.-]*:\/\//i,k=/(?<!:\/\/)(?:localhost|127\.0\.0\.1|0\.0\.0\.0|\[::1\]|::1)(?::\d+)?(?:\/[^\s"'<>`]*)?/gi,l=new Set(["previewUrl","devServerUrl","devServerURL","localUrl"]),m={devServerUrl:0,devServerURL:0,localUrl:10,previewUrl:50};function n(a,b=""){let c=(0,g.DW)(a),d=c?.sessionId??a;return`/api/sessions/${encodeURIComponent(d)}${b}`}async function o(a,b,c={}){let d=(0,g.DW)(a);if(d){if(!c.request)throw Error("Bridge preview lookup requires the incoming request context");return(0,e.nl)(c.request,d.bridgeId,b,{pathOverride:b})}return fetch(new URL(b,(0,f.B)()),{cache:"no-store",headers:c.headers})}async function p(a,b={}){let c=(0,g.DW)(a),d=await o(a,n(a),b);if(404===d.status)return null;if(!d.ok)throw Error(`Failed to fetch session ${a}: ${d.status}`);let e=await d.json();return c?(0,g.Vk)(e,c.bridgeId):e}async function q(a,b={}){try{var c,d;let e=await p(a,b);if(!e)return{session:null,candidateUrls:[],error:null,bridgePreview:null};let f=await x(e,b);return{session:e,candidateUrls:f,error:(c=e,d=f,!c.bridgeId?.trim()||d.length>0?null:[c.pr?.previewUrl??null,c.metadata.previewUrl??null,c.metadata.devServerUrl??null,c.metadata.devServerURL??null,c.metadata.localUrl??null,c.metadata.url??null,c.summary].some(a=>t(a).some(a=>u(a)))?"Bridge preview could not find a paired-device local dev server URL for this session.":"Bridge preview uses the paired device's local dev server, but this session did not report one."),bridgePreview:function(a,b){let c=a.bridgeId?.trim();if(!c)return null;let d=[...new Set(b.filter(a=>u(a)).map(a=>{try{return new URL(a).origin}catch{return null}}).filter(a=>!!a))];if(0===d.length)return null;let e=(0,g.DW)(a.id);return{bridgeId:c,sessionId:e?.sessionId??a.id,allowedOrigins:d}}(e,f)}}catch(a){return{session:null,candidateUrls:[],error:a instanceof Error?a.message:"Failed to load preview session",bridgePreview:null}}}function r(a){let b=a.trim().replace(/[),.;]+$/,""),c=j.test(b)?b:k.test(b)?`http://${b}`:b;k.lastIndex=0;try{let a=new URL(c);return"0.0.0.0"===a.hostname&&(a.hostname="127.0.0.1"),a.toString()}catch{return c}}async function s(a){try{let b=await (0,d.readFile)(a,"utf8");return t(b)}catch{return[]}}function t(a){return[...a?.match(i)??[],...a?.match(k)??[]].map(r)}function u(a){try{let b=new URL(a);return h.test(b.hostname)}catch{return!1}}function v(a,b,c,d,e=!1){if(!b?.trim())return;let f=r(b);if(!f||function(a,b){try{let c=new URL(a);if(b){let a=new URL(b);if(c.origin===a.origin)return!0}return c.pathname.startsWith("/api/")}catch{return!1}}(f,d))return;try{let a=new URL(f);if("http:"!==a.protocol&&"https:"!==a.protocol||!e&&!u(f))return}catch{return}let g=a.get(f);(void 0===g||c<g)&&a.set(f,c)}async function w(a,b={}){try{let c=await o(a,n(a,"/output?lines=400"),b);if(!c.ok)return"";let d=await c.json().catch(()=>null);return"string"==typeof d?.output?d.output:""}catch{return""}}async function x(a,b={}){let c=(0,f._)()??"",d=new Map;for(let[b,e]of(a.pr?.previewUrl?.trim()&&v(d,a.pr.previewUrl,50,c,!0),a.metadata.devServerUrl?.trim()&&v(d,a.metadata.devServerUrl,0,c,!0),Object.entries(a.metadata)))for(let a of(l.has(b)&&e.trim()&&v(d,e,m[b]??30,c,!0),t(e)))v(d,a,60,c);for(let b of t(a.summary))v(d,b,70,c);let e=a.metadata.devServerLog?.trim();if(e)for(let a of(await s(e)))v(d,a,40,c);for(let e of t(await w(a.id,b)))v(d,e,80,c);return[...d.entries()].sort(([a,b],[c,d])=>{if(b!==d)return b-d;let e=+!u(a),f=+!u(c);return e!==f?e-f:a.localeCompare(c)}).map(([a])=>a)}},59506:(a,b,c)=>{c.d(b,{k:()=>h});var d=c(4573);function e(a,b=null){return{connected:!1,candidateUrls:a,currentUrl:null,title:null,tunnelUrl:null,tunnelLocalOrigin:null,canGoBack:!1,canGoForward:!1,frames:[],activeFrameId:null,selectedElement:null,consoleLogs:[],networkLogs:[],lastError:b,screenshotKey:`${Date.now()}`}}class f{async configureBridgePreview(a,b,c){}async destroySession(a){let b=this.remoteSessionIds.get(a);if(this.remoteSessionIds.delete(a),b&&this.isConfigured())try{await fetch(`${this.workerUrl}/sessions/${encodeURIComponent(b)}`,{method:"DELETE",headers:this.buildHeaders(),cache:"no-store"})}catch{}}async runCommand(a,b){let c=await this.sendCommand(a,b,{createIfMissing:!0});if("error"===c.kind)throw Error(c.message)}async inspectDom(a,b,c=!1){let d=await this.sendCommand(a,{command:"dom",frameId:b,interactiveOnly:c},{createIfMissing:!0});if("dom"!==d.kind)throw Error("error"===d.kind?d.message:"Unexpected preview worker DOM response");return d}async takeScreenshot(a){if(!this.remoteSessionIds.has(a))return null;let b=await this.sendCommand(a,{command:"screenshot"},{createIfMissing:!1});if("error"===b.kind){if(b.message.includes("not connected"))return null;throw Error(b.message)}if("screenshot"!==b.kind)throw Error("Unexpected preview worker screenshot response");return d.Buffer.from(b.imageBase64,"base64")}async getStatus(a,b){if(!this.remoteSessionIds.has(a))return e(b,this.configurationError());try{let c=await this.sendCommand(a,{command:"status",candidateUrls:b},{createIfMissing:!1});if("status"===c.kind)return c;return e(b,"error"===c.kind?c.message:"Preview service is unavailable")}catch(a){return e(b,a instanceof Error?a.message:"Preview service is unavailable")}}async sendCommand(a,b,c){let d=this.configurationError();if(d)return{kind:"error",message:d};let e=this.remoteSessionIds.get(a)??null;if(!e){if(!c.createIfMissing)return{kind:"error",message:"Preview is not connected"};e=await this.createRemoteSession(a)}try{let d=await fetch(`${this.workerUrl}/sessions/${encodeURIComponent(e)}/command`,{method:"POST",headers:this.buildHeaders(),body:JSON.stringify(b),cache:"no-store"}),f=await d.json();if(404===d.status&&!1!==c.retry)return this.remoteSessionIds.delete(a),await this.sendCommand(a,b,{createIfMissing:c.createIfMissing,retry:!1});if(!d.ok||"error"===f.kind)return"error"===f.kind?f:{kind:"error",message:"Preview worker request failed"};return f}catch(a){throw Error(this.networkErrorMessage(a))}}async createRemoteSession(a){let b=this.configurationError();if(b)throw Error(b);try{let b=await fetch(`${this.workerUrl}/sessions`,{method:"POST",headers:this.buildHeaders(),cache:"no-store"}),c=await b.json();if(!b.ok||!c.sessionId)throw Error(c.error||"Preview worker session creation failed");return this.remoteSessionIds.set(a,c.sessionId),c.sessionId}catch(a){throw Error(this.networkErrorMessage(a))}}buildHeaders(){return{Authorization:`Bearer ${this.workerApiKey}`,"Content-Type":"application/json"}}configurationError(){return this.workerUrl&&this.workerApiKey?null:"Preview worker is not configured"}isConfigured(){return null===this.configurationError()}networkErrorMessage(a){let b=a instanceof Error?a.message:"Preview service is unavailable";return"Preview worker is not configured"===b?b:"Preview service is unavailable"}constructor(){this.workerUrl=function(a){let b=a?.trim();if(!b)return null;try{let a=new URL(b);if("http:"!==a.protocol&&"https:"!==a.protocol)return null;return a.toString().replace(/\/$/,"")}catch{return null}}(process.env.CONDUCTOR_PREVIEW_WORKER_URL),this.workerApiKey=process.env.CONDUCTOR_PREVIEW_WORKER_KEY?.trim()||null,this.remoteSessionIds=new Map}}let g=globalThis;function h(){return g._conductorPreviewWorkerClient||(g._conductorPreviewWorkerClient=new f),g._conductorPreviewWorkerClient}},70209:(a,b,c)=>{c.d(b,{X_:()=>m,Z$:()=>h,zP:()=>l});var d=c(77873),e=c(36026);let f=new Set(["connection","host","content-length","expect","upgrade","proxy-authorization","proxy-authenticate","te","trailers","transfer-encoding","accept-encoding","x-conductor-proxy-authorized","x-conductor-access-authenticated","x-conductor-access-role","x-conductor-access-email","x-conductor-access-provider","x-conductor-proxy-secret"]),g=new Set(["connection","content-length","content-encoding","keep-alive","transfer-encoding"]);function h(){return null!==(0,e._)()}function i(a){let b=new Headers;return a.headers.forEach((a,c)=>{g.has(c.toLowerCase())||b.set(c,a)}),b}async function j(a,b,c={}){let d=(0,e.B)(),g=new URL(a.url),h=new URL(b,d);h.search=g.search;let k=new Headers;a.headers.forEach((a,b)=>{f.has(b.toLowerCase())||k.set(b,a)}),c.headers&&new Headers(c.headers).forEach((a,b)=>{k.set(b,a)}),k.set("x-forwarded-proto",g.protocol.replace(":","")),k.set("x-forwarded-host",g.host);let l={method:a.method,headers:k,redirect:"manual",cache:"no-store"};if("GET"!==a.method&&"HEAD"!==a.method){let b=await a.arrayBuffer();b.byteLength>0&&(l.body=b)}let m=await fetch(h,l),n=i(m);return new Response(m.body,{status:m.status,statusText:m.statusText,headers:n})}async function k(a,b,c={}){let d,g=(0,e.B)(),h=new URL(a.url),j=new URL(b,g);j.search=h.search;let l=new Headers;a.headers.forEach((a,b)=>{f.has(b.toLowerCase())||l.set(b,a)}),c.headers&&new Headers(c.headers).forEach((a,b)=>{l.set(b,a)}),l.set("Accept","text/event-stream"),l.set("Cache-Control","no-cache"),l.set("x-forwarded-proto",h.protocol.replace(":","")),l.set("x-forwarded-host",h.host);let m=await fetch(j,{method:"GET",headers:l,redirect:"manual",cache:"no-store",signal:a.signal});return m.ok&&m.body?new Response(m.body,{status:m.status,statusText:m.statusText,headers:((d=i(m)).set("Content-Type","text/event-stream"),d.set("Cache-Control","no-cache, no-transform"),d.set("Connection","keep-alive"),d.set("X-Accel-Buffering","no"),d)}):new Response(m.body,{status:m.status,statusText:m.statusText,headers:i(m)})}async function l(a,b,c={}){if(!h())return d.NextResponse.json({error:"Rust backend URL is not configured"},{status:503});try{return await j(a,b,c)}catch(a){return d.NextResponse.json({error:a instanceof Error?a.message:"Failed to reach Rust backend"},{status:502})}}async function m(a,b,c={}){if(!h())return d.NextResponse.json({error:"Rust backend URL is not configured"},{status:503});try{return await k(a,b,c)}catch(a){return d.NextResponse.json({error:a instanceof Error?a.message:"Failed to reach Rust backend"},{status:502})}}}};
1
+ "use strict";exports.id=3990,exports.ids=[3990],exports.modules={25985:(a,b,c)=>{c.d(b,{FM:()=>g,JZ:()=>f,N7:()=>h});var d=c(32679),e=c(70209);async function f(a){let b=await (0,d.ny)(a),c=new Headers({"x-conductor-proxy-authorized":"true","x-conductor-access-authenticated":b.authenticated||"local"===b.provider?"true":"false"});b.role&&c.set("x-conductor-access-role",b.role),b.email&&c.set("x-conductor-access-email",b.email),b.provider&&c.set("x-conductor-access-provider",b.provider);let e=process.env.CONDUCTOR_PROXY_AUTH_SECRET?.trim()||null;return e&&c.set("x-conductor-proxy-secret",e),c}async function g(a,b,c={}){let h=await (0,d.sB)(a,c.role??"viewer");if(h)return h;if(c.requireActionGuard){let b=(0,d.G1)(a);if(b)return b}return(0,e.zP)(a,b,{headers:await f(a)})}async function h(a,b,c={}){let g=await (0,d.sB)(a,c.role??"viewer");if(g)return g;if(c.requireActionGuard){let b=(0,d.G1)(a);if(b)return b}return(0,e.X_)(a,b,{headers:await f(a)})}},28480:(a,b,c)=>{c.a(a,async(a,d)=>{try{c.d(b,{Ob:()=>A});var e=c(71553),f=c(31421),g=c(4573),h=c(73024),i=c(77030),j=c(76760),k=c(8856),l=c(34140),m=c(36026),n=c(94842),o=c(59506),p=a([k,l]);[k,l]=p.then?(await p)():p;let B={width:1440,height:960},C=["127.0.0.1","localhost","::1","0.0.0.0"],D=/^[a-z][a-z\d+.-]*:\/\//i,E=/^(?:localhost|127\.0\.0\.1|0\.0\.0\.0|\[::1\]|::1)(?::\d+)?(?:\/.*)?$/i;function q(a){return a.replace(/^\[(.*)\]$/,"$1").toLowerCase()}function r(a){let b=q(a);return C.includes(b)}function s(a){let b=a.split(".").map(a=>Number.parseInt(a,10));if(4!==b.length||b.some(a=>!Number.isInteger(a)||a<0||a>255))return!0;let[c,d]=b;return 0===c||10===c||127===c||100===c&&d>=64&&d<=127||169===c&&254===d||172===c&&d>=16&&d<=31||192===c&&168===d||198===c&&(18===d||19===d)||c>=224}function t(a){let b=q(a),c=(0,i.isIP)(b);if(4===c)return s(b);if(6===c){let a,c;return c=(a=q(b).toLowerCase()).startsWith("::ffff:")?a.slice(7):null,"::"===a||"::1"===a||a.startsWith("fe8")||a.startsWith("fe9")||a.startsWith("fea")||a.startsWith("feb")||a.startsWith("fc")||a.startsWith("fd")||!!c&&s(c)}return!1}async function u(a){if(process.env.CONDUCTOR_ALLOW_UNSAFE_PREVIEW_HOSTS?.trim().toLowerCase()==="true")return;let b=new URL(a);if(!r(b.hostname)){if(t(b.hostname))throw Error("Preview navigation to private network hosts is blocked. Use loopback URLs for local dev servers or set CONDUCTOR_ALLOW_UNSAFE_PREVIEW_HOSTS=true to override.");if((await (0,e.lookup)(b.hostname,{all:!0,verbatim:!0}).catch(()=>[])).some(a=>t(a.address)))throw Error("Preview navigation resolved to a private network address and was blocked. Set CONDUCTOR_ALLOW_UNSAFE_PREVIEW_HOSTS=true only if you intentionally trust that target.")}}function v(a,b){if(!b)return"direct";try{let c=new URL(a),d=r(q(c.hostname));if(b.allowedOrigins.includes(c.origin))return"bridge";return d?"blocked":"direct"}catch{return"direct"}}function w(a,b){try{let c=new URL(a),d=new URL(b);return c.origin===d.origin}catch{return a===b}}let F=globalThis;function x(a,b){a.push(b),a.length>150&&a.splice(0,a.length-150)}function y(a){return`${a}-${Date.now()}-${Math.random().toString(36).slice(2,8)}`}function z(a){return(a??"").replace(/\s+/g," ").trim()}class G{async getBrowser(){return this.browserPromise||(this.browserPromise=k.default.launch({headless:!0,executablePath:function(){let a=process.env.PUPPETEER_EXECUTABLE_PATH?.trim();if(a)return a;for(let a of[l.ChromeReleaseChannel.STABLE,l.ChromeReleaseChannel.CANARY,l.ChromeReleaseChannel.BETA,l.ChromeReleaseChannel.DEV])try{return(0,l.computeSystemExecutablePath)({browser:l.Browser.CHROME,channel:a})}catch{}let b=function(){for(let a of"darwin"===process.platform?["/Applications/Google Chrome.app/Contents/MacOS/Google Chrome","/Applications/Google Chrome Canary.app/Contents/MacOS/Google Chrome Canary","/Applications/Chromium.app/Contents/MacOS/Chromium","/Applications/Microsoft Edge.app/Contents/MacOS/Microsoft Edge","/Applications/Brave Browser.app/Contents/MacOS/Brave Browser"]:"win32"===process.platform?[process.env.PROGRAMFILES,process.env["PROGRAMFILES(X86)"],process.env.LOCALAPPDATA].filter(a=>!!a?.trim()).flatMap(a=>[(0,j.join)(a,"Google","Chrome","Application","chrome.exe"),(0,j.join)(a,"Chromium","Application","chrome.exe"),(0,j.join)(a,"Microsoft","Edge","Application","msedge.exe"),(0,j.join)(a,"BraveSoftware","Brave-Browser","Application","brave.exe")]):["google-chrome-stable","google-chrome","chromium-browser","chromium","microsoft-edge","brave-browser"]){if(a.includes("/")||a.includes("\\")){if((0,h.existsSync)(a))return a;continue}let b=function(a){let b="win32"===process.platform?"where":"which";try{return(0,f.execFileSync)(b,[a],{encoding:"utf8",stdio:["ignore","pipe","ignore"]}).trim().split(/\r?\n/).map(a=>a.trim()).find(Boolean)||null}catch{return null}}(a);if(b)return b}return null}();if(b)return b;throw Error("Chrome/Chromium not found. Install a supported browser or set PUPPETEER_EXECUTABLE_PATH.")}(),defaultViewport:B,args:["--disable-dev-shm-usage","--disable-background-networking","--no-first-run","--no-default-browser-check"]})),this.browserPromise}getState(a){let b=this.states.get(a);return b||(b={sessionId:a,context:null,page:null,destroying:!1,activeFrameId:null,selectedElement:null,consoleLogs:[],networkLogs:[],lastError:null,frameIds:new WeakMap,requestStarts:new WeakMap,frameSequence:0,bridgePreview:null,requestInterceptionEnabled:!1},this.states.set(a,b)),b}async ensureContext(a,b){return a.context&&!a.context.closed||(a.context=await b.createBrowserContext()),a.context}async destroySession(a,b={}){let c=this.states.get(a);if(!c||c.destroying)return;c.destroying=!0;let d=c.page,e=c.context;try{!1!==b.closePage&&d&&!d.isClosed()&&await d.close().catch(()=>{}),e&&!e.closed&&await e.close().catch(()=>{})}finally{this.states.delete(a)}}ensureFrameId(a,b){let c=a.frameIds.get(b);if(c)return c;let d=`frame-${++a.frameSequence}`;return a.frameIds.set(b,d),d}async configureBridgePreview(a,b,c){let d=this.getState(a);d.bridgePreview=b&&c?{...b,forwardedHeaders:Object.fromEntries(new Headers(c).entries())}:null,d.page&&!d.page.isClosed()&&await this.syncRequestInterception(d,d.page)}async syncRequestInterception(a,b,c){let d="bridge"===v(c??b.url(),a.bridgePreview);a.requestInterceptionEnabled!==d&&(await b.setRequestInterception(d),a.requestInterceptionEnabled=d)}async handleBridgePreviewRequest(a,b){let c,d=a.bridgePreview;if(!d)return void await b.continue();try{c=new URL(b.url())}catch{await b.abort("blockedbyclient");return}if("http:"!==c.protocol&&"https:"!==c.protocol||!d.allowedOrigins.includes(c.origin))return void await b.abort("blockedbyclient");let e="GET"===b.method()||"HEAD"===b.method()?null:b.postData()??null,f=await (0,n.LN)(d.bridgeId,d.forwardedHeaders,{sessionId:d.sessionId,method:b.method(),url:c.toString(),headers:function(a){let b={};for(let[c,d]of Object.entries(a)){let a=c.trim().toLowerCase();a&&"host"!==a&&"connection"!==a&&"proxy-connection"!==a&&"keep-alive"!==a&&"transfer-encoding"!==a&&"content-length"!==a&&"accept-encoding"!==a&&(b[a]=d)}return b}(b.headers()),bodyBase64:e?g.Buffer.from(e).toString("base64"):null});await b.respond({status:f.status,headers:f.headers,body:f.bodyBase64?g.Buffer.from(f.bodyBase64,"base64"):g.Buffer.alloc(0)})}attachListeners(a,b){b.on("console",b=>{this.captureConsole(a,b)}),b.on("pageerror",b=>{let c=b instanceof Error?b.message:String(b);x(a.consoleLogs,{id:y("pageerror"),kind:"pageerror",level:"error",message:c,timestamp:new Date().toISOString()}),a.lastError=c}),b.on("request",b=>{a.requestStarts.set(b,Date.now()),a.requestInterceptionEnabled&&this.handleBridgePreviewRequest(a,b).catch(async c=>{a.lastError=c instanceof Error?c.message:"Bridge preview request failed",x(a.networkLogs,{id:y("preview-request"),kind:"network",level:"error",message:a.lastError,timestamp:new Date().toISOString(),url:b.url(),method:b.method(),status:null,resourceType:b.resourceType()});try{await b.abort("failed")}catch{}})}),b.on("response",b=>{this.captureResponse(a,b)}),b.on("requestfailed",b=>{x(a.networkLogs,{id:y("requestfailed"),kind:"network",level:"error",message:b.failure()?.errorText??"Request failed",timestamp:new Date().toISOString(),url:b.url(),method:b.method(),status:null,resourceType:b.resourceType()})}),b.on("framenavigated",c=>{let d=this.ensureFrameId(a,c);c===b.mainFrame()&&(a.activeFrameId??=d),a.selectedElement?.frameId===d&&(a.selectedElement=null)}),b.on("close",()=>{this.destroySession(a.sessionId,{closePage:!1})})}captureConsole(a,b){let c=b.location();x(a.consoleLogs,{id:y("console"),kind:"console",level:b.type(),message:z(b.text()),timestamp:new Date().toISOString(),url:c.url??null})}captureResponse(a,b){let c=b.request();x(a.networkLogs,{id:y("network"),kind:"network",level:b.ok()?"info":"error",message:`${c.method()} ${b.status()} ${z(b.statusText())}`.trim(),timestamp:new Date().toISOString(),url:b.url(),method:c.method(),status:b.status(),resourceType:c.resourceType()})}async ensurePage(a){let b=await this.getBrowser(),c=this.getState(a);if(c.page&&!c.page.isClosed())return await this.syncRequestInterception(c,c.page),{state:c,page:c.page};let d=await this.ensureContext(c,b),e=await d.newPage();return await e.setViewport(B),e.setDefaultNavigationTimeout(3e4),e.setDefaultTimeout(15e3),this.attachListeners(c,e),await this.syncRequestInterception(c,e),c.page=e,c.activeFrameId=this.ensureFrameId(c,e.mainFrame()),c.selectedElement=null,c.lastError=null,{state:c,page:e}}collectFrames(a,b){let c=b.frames().map(c=>{let d=this.ensureFrameId(a,c),e=c.parentFrame();return{id:d,name:c.name()||(c===b.mainFrame()?"Main frame":"Untitled frame"),url:c.url(),parentId:e?this.ensureFrameId(a,e):null,isMain:c===b.mainFrame()}});return c.some(b=>b.id===a.activeFrameId)||(a.activeFrameId=c.find(a=>a.isMain)?.id??c[0]?.id??null),a.selectedElement&&!c.some(b=>b.id===a.selectedElement?.frameId)&&(a.selectedElement=null),c}resolveFrame(a,b,c){let d=c??a.activeFrameId,e=b.frames();return d?e.find(b=>this.ensureFrameId(a,b)===d)??b.mainFrame():b.mainFrame()}async navigationProducedUsablePage(a,b,c,d){if(!(d instanceof Error?d.message:String(d)).toLowerCase().includes("net::err_aborted"))return!1;let e=a.url();if("about:blank"===e||e===c&&!w(e,b)||!w(e,b))return!1;try{let b=await a.evaluate(()=>document.readyState);return"interactive"===b||"complete"===b}catch{return!1}}async snapshotElement(a,b,c){return a.evaluate(({selector:a,point:b})=>{var c,d;let e,f,g,h;function i(a){return(a??"").replace(/\s+/g," ").trim()}let j=null;return("string"==typeof a&&a.trim()?j=document.querySelector(a):b&&(j=document.elementFromPoint(b.x,b.y)),j)?(c=j,e=i(c.outerHTML).slice(0,400),f=i(c.textContent),g=c.getBoundingClientRect(),h=[...c.attributes].reduce((a,b)=>(a&&Object.keys(a).length>=12||(a[b.name]=b.value),a),{}),{selector:function(a){let b=[],c=a;for(;c&&b.length<5;){let a=function(a){let b=a.tagName.toLowerCase(),c=i(a.getAttribute("id"));if(c)return`#${CSS.escape(c)}`;let d=[...a.classList].slice(0,2).map(a=>`.${CSS.escape(a)}`).join(""),e="",f=a.parentElement;if(f){let b=[...f.children].filter(b=>b.tagName===a.tagName);b.length>1&&(e=`:nth-of-type(${b.indexOf(a)+1})`)}return`${b}${d}${e}`}(c);if(b.unshift(a),a.startsWith("#"))break;c=c.parentElement}return b.join(" > ")}(c),tag:c.tagName.toLowerCase(),text:f.slice(0,220),role:function(a){let b=i(a.getAttribute("role"));if(b)return b;let c=a.tagName.toLowerCase();return"button"===c?"button":"a"===c&&a.hasAttribute("href")?"link":"input"===c?(a.getAttribute("type")??"textbox").toLowerCase():null}(c),name:(d=f.slice(0,220),i(c.getAttribute("aria-label")??c.getAttribute("title")??c.getAttribute("placeholder")??c.getAttribute("alt")??d)||null),interactive:function(a){if(!(a instanceof HTMLElement))return!1;let b=a.tagName.toLowerCase();return!!(["button","input","select","textarea","summary"].includes(b)||"a"===b&&a.hasAttribute("href")||a.hasAttribute("contenteditable")||a.hasAttribute("onclick")||(a.getAttribute("role")??"").match(/button|link|tab|checkbox|radio|switch|textbox|menuitem/i))||a.tabIndex>=0}(c),id:i(c.getAttribute("id"))||null,classes:[...c.classList].slice(0,6),htmlPreview:e,bounds:{x:g.x,y:g.y,width:g.width,height:g.height},attributes:h}):null},{selector:b,point:c})}async connect(a,b){let{state:c,page:d}=await this.ensurePage(a),e=function(a){let b,c=!(b=a.trim())||D.test(b)?b:E.test(b)?`http://${b}`:b;try{let a=new URL(c),b=a.toString(),d=q(a.hostname),e=a.protocol.toLowerCase();if("http:"!==e&&"https:"!==e)throw Error(`Navigation blocked: only http and https URLs are allowed. Got protocol "${a.protocol}".`);if(r(d)){let a=new Set([b]);for(let c of C){let d=new URL(b);d.hostname=c,a.add(d.toString())}return[...a]}return[b]}catch(a){if(a instanceof Error&&a.message.startsWith("Navigation blocked:"))throw a;throw Error(`Navigation blocked: could not parse "${c}" as a valid URL.`)}}(b),f=null;for(let a of e){let b=v(a,c.bridgePreview);if("blocked"===b){f=Error("Bridge preview only allows navigation to the session's reported local dev server origin.");continue}let e=d.url();try{"direct"===b&&await u(a),await this.syncRequestInterception(c,d,a),await d.goto(a,{waitUntil:"domcontentloaded"}),await this.syncRequestInterception(c,d),c.selectedElement=null,c.lastError=null,c.activeFrameId=this.ensureFrameId(c,d.mainFrame());return}catch(b){if(await this.navigationProducedUsablePage(d,a,e,b)){await this.syncRequestInterception(c,d),c.selectedElement=null,c.lastError=null,c.activeFrameId=this.ensureFrameId(c,d.mainFrame());return}f=b}}throw c.lastError=f instanceof Error?f.message:"Failed to connect preview",f??Error("Failed to connect preview")}async runCommand(a,b){switch(b.command){case"connect":case"navigate":await this.connect(a,b.url);return;case"reload":{let{state:b,page:c}=await this.ensurePage(a);try{await c.reload({waitUntil:"domcontentloaded"}),b.lastError=null}catch(a){throw b.lastError=a instanceof Error?a.message:"Failed to reload preview",a}return}case"goBack":{let{state:b,page:c}=await this.ensurePage(a);try{await this.syncRequestInterception(b,c),await c.goBack({waitUntil:"domcontentloaded",timeout:1500}),await this.syncRequestInterception(b,c),b.selectedElement=null,b.lastError=null,b.activeFrameId=this.ensureFrameId(b,c.mainFrame())}catch(a){throw b.lastError=a instanceof Error?a.message:"Failed to go back",a}return}case"goForward":{let{state:b,page:c}=await this.ensurePage(a);try{await this.syncRequestInterception(b,c),await c.goForward({waitUntil:"domcontentloaded",timeout:1500}),await this.syncRequestInterception(b,c),b.selectedElement=null,b.lastError=null,b.activeFrameId=this.ensureFrameId(b,c.mainFrame())}catch(a){throw b.lastError=a instanceof Error?a.message:"Failed to go forward",a}return}case"selectFrame":{let{state:c,page:d}=await this.ensurePage(a),e=this.resolveFrame(c,d,b.frameId);c.activeFrameId=this.ensureFrameId(c,e),c.selectedElement=null,c.lastError=null;return}case"clickAtPoint":{let{state:c,page:d}=await this.ensurePage(a);c.selectedElement=null,c.lastError=null;let e=d.waitForNavigation({waitUntil:"domcontentloaded",timeout:1500}).catch(()=>null);await d.mouse.click(b.x,b.y),await e,await d.waitForNetworkIdle({idleTime:250,timeout:1e3}).catch(()=>null);return}case"typeText":{let{state:c,page:d}=await this.ensurePage(a);if(!b.text)return;await d.keyboard.type(b.text),c.lastError=null;return}case"pressKey":{let{state:c,page:d}=await this.ensurePage(a);c.lastError=null;let e=d.waitForNavigation({waitUntil:"domcontentloaded",timeout:1500}).catch(()=>null);await d.keyboard.press(b.key),await e,await d.waitForNetworkIdle({idleTime:250,timeout:1e3}).catch(()=>null);return}case"selectAtPoint":{let{state:c,page:d}=await this.ensurePage(a),e=this.resolveFrame(c,d,c.activeFrameId);if(e!==d.mainFrame())throw Error("Point selection is only available for the main frame. Pick nested frame elements from the DOM list.");let f=await this.snapshotElement(e,void 0,{x:b.x,y:b.y});if(!f)throw Error("No element found at the selected point");c.selectedElement={...f,frameId:this.ensureFrameId(c,e),frameName:e.name()||"Main frame",frameUrl:e.url()},c.lastError=null;return}case"selectBySelector":{let{state:c,page:d}=await this.ensurePage(a),e=this.resolveFrame(c,d,b.frameId),f=await this.snapshotElement(e,b.selector);if(!f)throw Error(`Element not found for selector: ${b.selector}`);c.selectedElement={...f,frameId:this.ensureFrameId(c,e),frameName:e.name()||(e===d.mainFrame()?"Main frame":"Frame"),frameUrl:e.url()},c.activeFrameId=this.ensureFrameId(c,e),c.lastError=null;return}default:return}}async inspectDom(a,b,c=!1){let{state:d,page:e}=await this.ensurePage(a),f=this.resolveFrame(d,e,b),g=await f.evaluate(({interactiveOnly:a,limit:b})=>{function c(a){return(a??"").replace(/\s+/g," ").trim()}let d=document.body??document.documentElement,e=document.createTreeWalker(d,NodeFilter.SHOW_ELEMENT),f=[],g=0;for(;e.nextNode();){g+=1;let d=e.currentNode;if(!(d instanceof Element))continue;let h=function(a){if(!(a instanceof HTMLElement))return!1;let b=a.tagName.toLowerCase();return!!(["button","input","select","textarea","summary"].includes(b)||"a"===b&&a.hasAttribute("href")||a.hasAttribute("contenteditable")||(a.getAttribute("role")??"").match(/button|link|tab|checkbox|radio|switch|textbox|menuitem/i))||a.tabIndex>=0}(d);if(a&&!h)continue;let i=c(d.textContent).slice(0,220),j=d.getBoundingClientRect();if(f.push({selector:function(a){let b=[],d=a;for(;d&&b.length<5;){let a=function(a){let b=a.tagName.toLowerCase(),d=c(a.getAttribute("id"));if(d)return`#${CSS.escape(d)}`;let e=[...a.classList].slice(0,2).map(a=>`.${CSS.escape(a)}`).join(""),f="",g=a.parentElement;if(g){let b=[...g.children].filter(b=>b.tagName===a.tagName);b.length>1&&(f=`:nth-of-type(${b.indexOf(a)+1})`)}return`${b}${e}${f}`}(d);if(b.unshift(a),a.startsWith("#"))break;d=d.parentElement}return b.join(" > ")}(d),tag:d.tagName.toLowerCase(),text:i,role:function(a){let b=c(a.getAttribute("role"));if(b)return b;let d=a.tagName.toLowerCase();return"button"===d?"button":"a"===d&&a.hasAttribute("href")?"link":"input"===d?(a.getAttribute("type")??"textbox").toLowerCase():null}(d),name:c(d.getAttribute("aria-label")??d.getAttribute("title")??d.getAttribute("placeholder")??d.getAttribute("alt")??i)||null,interactive:h,id:c(d.getAttribute("id"))||null,classes:[...d.classList].slice(0,6),htmlPreview:c(d.outerHTML).slice(0,320),bounds:{x:j.x,y:j.y,width:j.width,height:j.height}}),f.length>=b)break}return{nodes:f,truncated:f.length>=b||g>f.length}},{interactiveOnly:c,limit:250});return{frameId:this.ensureFrameId(d,f),nodes:g.nodes,truncated:g.truncated}}async takeScreenshot(a){let{page:b}=await this.ensurePage(a);return"about:blank"===b.url()?null:b.screenshot({type:"png"})}async getNavigationCapabilities(a){if(!a||a.isClosed()||"about:blank"===a.url())return{canGoBack:!1,canGoForward:!1};let b=null;try{b=await a.createCDPSession();let c=await b.send("Page.getNavigationHistory");return{canGoBack:c.currentIndex>0,canGoForward:c.currentIndex<c.entries.length-1}}catch{return{canGoBack:!1,canGoForward:!1}}finally{await b?.detach().catch(()=>null)}}async getStatus(a,b){let c=this.states.get(a)??null,d=c?.page&&!c.page.isClosed()?c.page:null,e=c&&d?this.collectFrames(c,d):[],{canGoBack:f,canGoForward:g}=await this.getNavigationCapabilities(d),h=null;if(d&&"about:blank"!==d.url())try{h=await d.title()}catch{h=null}return{connected:!!(d&&"about:blank"!==d.url()),candidateUrls:b,currentUrl:d&&"about:blank"!==d.url()?d.url():null,title:h,tunnelUrl:null,tunnelLocalOrigin:null,canGoBack:f,canGoForward:g,frames:e,activeFrameId:c?.activeFrameId??null,selectedElement:c?.selectedElement??null,consoleLogs:c?.consoleLogs??[],networkLogs:c?.networkLogs??[],lastError:c?.lastError??null,screenshotKey:`${Date.now()}`}}constructor(){this.browserPromise=null,this.states=new Map}}function A(){return!function(){let a=(0,m._)();if(!a)return!1;try{let b=new URL(a).hostname.toLowerCase();return"localhost"===b||"127.0.0.1"===b||"0.0.0.0"===b||"::1"===b||"[::1]"===b}catch{return!1}}()?(0,o.k)():(F._conductorPreviewBrowserManager||(F._conductorPreviewBrowserManager=new G),F._conductorPreviewBrowserManager)}d()}catch(a){d(a)}})},36026:(a,b,c)=>{function d(a){let b=a?.trim();if(!b)return null;try{let a=new URL(b);if("http:"!==a.protocol&&"https:"!==a.protocol)return null;return a.toString()}catch{return null}}function e(a){let b=a?.trim();if(!b)return null;let c=Number.parseInt(b,10);return!Number.isInteger(c)||c<1||c>65535?null:c}function f(){let a=d(process.env.CONDUCTOR_BACKEND_URL);if(a)return a;let b=d(process.env.NEXT_PUBLIC_CONDUCTOR_BACKEND_URL);if(b)return b;let c=e(process.env.CONDUCTOR_BACKEND_PORT);if(null!==c)return`http://127.0.0.1:${c}`;let f=e(process.env.NEXT_PUBLIC_CONDUCTOR_BACKEND_PORT);return null!==f?`http://127.0.0.1:${f}`:null}function g(){let a=f();if(!a)throw Error("Rust backend URL is not configured");return a}c.d(b,{B:()=>g,_:()=>f})},42599:(a,b,c)=>{c.d(b,{Ix:()=>q});var d=c(51455),e=c(94842),f=c(36026),g=c(91752);let h=/(?:127\.0\.0\.1|0\.0\.0\.0|localhost|::1|\[::1\])/i,i=/\bhttps?:\/\/[^\s"'<>`]+/gi,j=/^[a-z][a-z\d+.-]*:\/\//i,k=/(?<!:\/\/)(?:localhost|127\.0\.0\.1|0\.0\.0\.0|\[::1\]|::1)(?::\d+)?(?:\/[^\s"'<>`]*)?/gi,l=new Set(["previewUrl","devServerUrl","devServerURL","localUrl"]),m={devServerUrl:0,devServerURL:0,localUrl:10,previewUrl:50};function n(a,b=""){let c=(0,g.DW)(a),d=c?.sessionId??a;return`/api/sessions/${encodeURIComponent(d)}${b}`}async function o(a,b,c={}){let d=(0,g.DW)(a);if(d){if(!c.request)throw Error("Bridge preview lookup requires the incoming request context");return(0,e.nl)(c.request,d.bridgeId,b,{pathOverride:b})}return fetch(new URL(b,(0,f.B)()),{cache:"no-store",headers:c.headers})}async function p(a,b={}){let c=(0,g.DW)(a),d=await o(a,n(a),b);if(404===d.status)return null;if(!d.ok)throw Error(`Failed to fetch session ${a}: ${d.status}`);let e=await d.json();return c?(0,g.Vk)(e,c.bridgeId):e}async function q(a,b={}){try{var c,d;let e=await p(a,b);if(!e)return{session:null,candidateUrls:[],error:null,bridgePreview:null};let f=await x(e,b);return{session:e,candidateUrls:f,error:(c=e,d=f,!c.bridgeId?.trim()||d.length>0?null:[c.pr?.previewUrl??null,c.metadata.previewUrl??null,c.metadata.devServerUrl??null,c.metadata.devServerURL??null,c.metadata.localUrl??null,c.metadata.url??null,c.summary].some(a=>t(a).some(a=>u(a)))?"Bridge preview could not find a paired-device local dev server URL for this session.":"Bridge preview uses the paired device's local dev server, but this session did not report one."),bridgePreview:function(a,b){let c=a.bridgeId?.trim();if(!c)return null;let d=[...new Set(b.filter(a=>u(a)).map(a=>{try{return new URL(a).origin}catch{return null}}).filter(a=>!!a))];if(0===d.length)return null;let e=(0,g.DW)(a.id);return{bridgeId:c,sessionId:e?.sessionId??a.id,allowedOrigins:d}}(e,f)}}catch(a){return{session:null,candidateUrls:[],error:a instanceof Error?a.message:"Failed to load preview session",bridgePreview:null}}}function r(a){let b=a.trim().replace(/[),.;]+$/,""),c=j.test(b)?b:k.test(b)?`http://${b}`:b;k.lastIndex=0;try{let a=new URL(c);return"0.0.0.0"===a.hostname&&(a.hostname="127.0.0.1"),a.toString()}catch{return c}}async function s(a){try{let b=await (0,d.readFile)(a,"utf8");return t(b)}catch{return[]}}function t(a){return[...a?.match(i)??[],...a?.match(k)??[]].map(r)}function u(a){try{let b=new URL(a);return h.test(b.hostname)}catch{return!1}}function v(a,b,c,d,e=!1){if(!b?.trim())return;let f=r(b);if(!f||function(a,b){try{let c=new URL(a);if(b){let a=new URL(b);if(c.origin===a.origin)return!0}return c.pathname.startsWith("/api/")}catch{return!1}}(f,d))return;try{let a=new URL(f);if("http:"!==a.protocol&&"https:"!==a.protocol||!e&&!u(f))return}catch{return}let g=a.get(f);(void 0===g||c<g)&&a.set(f,c)}async function w(a,b={}){try{let c=await o(a,n(a,"/output?lines=400"),b);if(!c.ok)return"";let d=await c.json().catch(()=>null);return"string"==typeof d?.output?d.output:""}catch{return""}}async function x(a,b={}){let c=(0,f._)()??"",d=new Map;for(let[b,e]of(a.pr?.previewUrl?.trim()&&v(d,a.pr.previewUrl,50,c,!0),a.metadata.devServerUrl?.trim()&&v(d,a.metadata.devServerUrl,0,c,!0),Object.entries(a.metadata)))for(let a of(l.has(b)&&e.trim()&&v(d,e,m[b]??30,c,!0),t(e)))v(d,a,60,c);for(let b of t(a.summary))v(d,b,70,c);let e=a.metadata.devServerLog?.trim();if(e)for(let a of(await s(e)))v(d,a,40,c);for(let e of t(await w(a.id,b)))v(d,e,80,c);return[...d.entries()].sort(([a,b],[c,d])=>{if(b!==d)return b-d;let e=+!u(a),f=+!u(c);return e!==f?e-f:a.localeCompare(c)}).map(([a])=>a)}},59506:(a,b,c)=>{c.d(b,{k:()=>i});var d=c(4573),e=c(46224);function f(a,b=null){return{connected:!1,candidateUrls:a,currentUrl:null,title:null,tunnelUrl:null,tunnelLocalOrigin:null,canGoBack:!1,canGoForward:!1,frames:[],activeFrameId:null,selectedElement:null,consoleLogs:[],networkLogs:[],lastError:b,screenshotKey:`${Date.now()}`}}class g{async configureBridgePreview(a,b,c){let d=(0,e.y)(),f=b&&c&&d?{...b,relayUrl:d,forwardedHeaders:Object.fromEntries(new Headers(c).entries())}:null;if(JSON.stringify(this.bridgePreviewConfigs.get(a)??null)===JSON.stringify(f))return;this.bridgePreviewConfigs.set(a,f);let g=this.remoteSessionIds.get(a);if(g&&this.isConfigured()){this.remoteSessionIds.delete(a);try{await fetch(`${this.workerUrl}/sessions/${encodeURIComponent(g)}`,{method:"DELETE",headers:this.buildHeaders(),cache:"no-store"})}catch{}}}async destroySession(a){let b=this.remoteSessionIds.get(a);if(this.remoteSessionIds.delete(a),this.bridgePreviewConfigs.delete(a),b&&this.isConfigured())try{await fetch(`${this.workerUrl}/sessions/${encodeURIComponent(b)}`,{method:"DELETE",headers:this.buildHeaders(),cache:"no-store"})}catch{}}async runCommand(a,b){let c=await this.sendCommand(a,b,{createIfMissing:!0});if("error"===c.kind)throw Error(c.message)}async inspectDom(a,b,c=!1){let d=await this.sendCommand(a,{command:"dom",frameId:b,interactiveOnly:c},{createIfMissing:!0});if("dom"!==d.kind)throw Error("error"===d.kind?d.message:"Unexpected preview worker DOM response");return d}async takeScreenshot(a){if(!this.remoteSessionIds.has(a))return null;let b=await this.sendCommand(a,{command:"screenshot"},{createIfMissing:!1});if("error"===b.kind){if(b.message.includes("not connected"))return null;throw Error(b.message)}if("screenshot"!==b.kind)throw Error("Unexpected preview worker screenshot response");return d.Buffer.from(b.imageBase64,"base64")}async getStatus(a,b){if(!this.remoteSessionIds.has(a))return f(b,this.configurationError());try{let c=await this.sendCommand(a,{command:"status",candidateUrls:b},{createIfMissing:!1});if("status"===c.kind)return c;return f(b,"error"===c.kind?c.message:"Preview service is unavailable")}catch(a){return f(b,a instanceof Error?a.message:"Preview service is unavailable")}}async sendCommand(a,b,c){let d=this.configurationError();if(d)return{kind:"error",message:d};let e=this.remoteSessionIds.get(a)??null;if(!e){if(!c.createIfMissing)return{kind:"error",message:"Preview is not connected"};e=await this.createRemoteSession(a)}try{let d=await fetch(`${this.workerUrl}/sessions/${encodeURIComponent(e)}/command`,{method:"POST",headers:this.buildHeaders(),body:JSON.stringify(b),cache:"no-store"}),f=await d.json();if(404===d.status&&!1!==c.retry)return this.remoteSessionIds.delete(a),await this.sendCommand(a,b,{createIfMissing:c.createIfMissing,retry:!1});if(!d.ok||"error"===f.kind)return"error"===f.kind?f:{kind:"error",message:"Preview worker request failed"};return f}catch(a){throw Error(this.networkErrorMessage(a))}}async createRemoteSession(a){let b=this.configurationError();if(b)throw Error(b);let c={bridgePreview:this.bridgePreviewConfigs.get(a)??null};try{let b=await fetch(`${this.workerUrl}/sessions`,{method:"POST",headers:this.buildHeaders(),body:JSON.stringify(c),cache:"no-store"}),d=await b.json();if(!b.ok||!d.sessionId)throw Error(d.error||"Preview worker session creation failed");return this.remoteSessionIds.set(a,d.sessionId),d.sessionId}catch(a){throw Error(this.networkErrorMessage(a))}}buildHeaders(){return{Authorization:`Bearer ${this.workerApiKey}`,"Content-Type":"application/json"}}configurationError(){return this.workerUrl&&this.workerApiKey?null:"Preview worker is not configured"}isConfigured(){return null===this.configurationError()}networkErrorMessage(a){let b=a instanceof Error?a.message:"Preview service is unavailable";return"Preview worker is not configured"===b?b:"Preview service is unavailable"}constructor(){this.workerUrl=function(a){let b=a?.trim();if(!b)return null;try{let a=new URL(b);if("http:"!==a.protocol&&"https:"!==a.protocol)return null;return a.toString().replace(/\/$/,"")}catch{return null}}(process.env.CONDUCTOR_PREVIEW_WORKER_URL),this.workerApiKey=process.env.CONDUCTOR_PREVIEW_WORKER_KEY?.trim()||null,this.remoteSessionIds=new Map,this.bridgePreviewConfigs=new Map}}let h=globalThis;function i(){return h._conductorPreviewWorkerClient||(h._conductorPreviewWorkerClient=new g),h._conductorPreviewWorkerClient}},70209:(a,b,c)=>{c.d(b,{X_:()=>m,Z$:()=>h,zP:()=>l});var d=c(77873),e=c(36026);let f=new Set(["connection","host","content-length","expect","upgrade","proxy-authorization","proxy-authenticate","te","trailers","transfer-encoding","accept-encoding","x-conductor-proxy-authorized","x-conductor-access-authenticated","x-conductor-access-role","x-conductor-access-email","x-conductor-access-provider","x-conductor-proxy-secret"]),g=new Set(["connection","content-length","content-encoding","keep-alive","transfer-encoding"]);function h(){return null!==(0,e._)()}function i(a){let b=new Headers;return a.headers.forEach((a,c)=>{g.has(c.toLowerCase())||b.set(c,a)}),b}async function j(a,b,c={}){let d=(0,e.B)(),g=new URL(a.url),h=new URL(b,d);h.search=g.search;let k=new Headers;a.headers.forEach((a,b)=>{f.has(b.toLowerCase())||k.set(b,a)}),c.headers&&new Headers(c.headers).forEach((a,b)=>{k.set(b,a)}),k.set("x-forwarded-proto",g.protocol.replace(":","")),k.set("x-forwarded-host",g.host);let l={method:a.method,headers:k,redirect:"manual",cache:"no-store"};if("GET"!==a.method&&"HEAD"!==a.method){let b=await a.arrayBuffer();b.byteLength>0&&(l.body=b)}let m=await fetch(h,l),n=i(m);return new Response(m.body,{status:m.status,statusText:m.statusText,headers:n})}async function k(a,b,c={}){let d,g=(0,e.B)(),h=new URL(a.url),j=new URL(b,g);j.search=h.search;let l=new Headers;a.headers.forEach((a,b)=>{f.has(b.toLowerCase())||l.set(b,a)}),c.headers&&new Headers(c.headers).forEach((a,b)=>{l.set(b,a)}),l.set("Accept","text/event-stream"),l.set("Cache-Control","no-cache"),l.set("x-forwarded-proto",h.protocol.replace(":","")),l.set("x-forwarded-host",h.host);let m=await fetch(j,{method:"GET",headers:l,redirect:"manual",cache:"no-store",signal:a.signal});return m.ok&&m.body?new Response(m.body,{status:m.status,statusText:m.statusText,headers:((d=i(m)).set("Content-Type","text/event-stream"),d.set("Cache-Control","no-cache, no-transform"),d.set("Connection","keep-alive"),d.set("X-Accel-Buffering","no"),d)}):new Response(m.body,{status:m.status,statusText:m.statusText,headers:i(m)})}async function l(a,b,c={}){if(!h())return d.NextResponse.json({error:"Rust backend URL is not configured"},{status:503});try{return await j(a,b,c)}catch(a){return d.NextResponse.json({error:a instanceof Error?a.message:"Failed to reach Rust backend"},{status:502})}}async function m(a,b,c={}){if(!h())return d.NextResponse.json({error:"Rust backend URL is not configured"},{status:503});try{return await k(a,b,c)}catch(a){return d.NextResponse.json({error:a instanceof Error?a.message:"Failed to reach Rust backend"},{status:502})}}}};
@@ -0,0 +1 @@
1
+ exports.id=60,exports.ids=[60],exports.modules={14276:()=>{},14533:(a,b,c)=>{"use strict";c.d(b,{y:()=>e});var d=c(85660);let e=(0,d.createServerReference)("00927a55359fd3edee8b795e6b31bf6af5db9598de",d.callServer,void 0,d.findSourceMapURL,"invalidateCacheAction")},22675:(a,b,c)=>{Promise.resolve().then(c.bind(c,3074)),Promise.resolve().then(c.bind(c,82099)),Promise.resolve().then(c.bind(c,6932)),Promise.resolve().then(c.bind(c,66185)),Promise.resolve().then(c.bind(c,87839)),Promise.resolve().then(c.bind(c,53759)),Promise.resolve().then(c.bind(c,90075)),Promise.resolve().then(c.bind(c,66504)),Promise.resolve().then(c.bind(c,46208))},24868:(a,b,c)=>{"use strict";c.r(b),c.d(b,{"0005627dae176089d2332690516eb3e8888d19d434":()=>d.i,"0020ee235bab230e8215f50c6c37aaff8bd82b18e7":()=>e.at,"0056a043e7b275ff1a94e951b504cb5d5b7fea4808":()=>e.ai,"009396d30a8813ef0f7a2827d302825e6ee64e6f52":()=>e.AZ,"40284f0c8c951ac1e4c6b06efd2067d48e9027c33b":()=>d.$,"402ce17edc7360e1763794c2b2af42c153477dcb07":()=>e.ot});var d=c(35515),e=c(78113)},36026:(a,b,c)=>{"use strict";function d(a){let b=a?.trim();if(!b)return null;try{let a=new URL(b);if("http:"!==a.protocol&&"https:"!==a.protocol)return null;return a.toString()}catch{return null}}function e(a){let b=a?.trim();if(!b)return null;let c=Number.parseInt(b,10);return!Number.isInteger(c)||c<1||c>65535?null:c}function f(){let a=d(process.env.CONDUCTOR_BACKEND_URL);if(a)return a;let b=d(process.env.NEXT_PUBLIC_CONDUCTOR_BACKEND_URL);if(b)return b;let c=e(process.env.CONDUCTOR_BACKEND_PORT);if(null!==c)return`http://127.0.0.1:${c}`;let f=e(process.env.NEXT_PUBLIC_CONDUCTOR_BACKEND_PORT);return null!==f?`http://127.0.0.1:${f}`:null}function g(){let a=f();if(!a)throw Error("Rust backend URL is not configured");return a}c.d(b,{B:()=>g,_:()=>f})},37806:(a,b,c)=>{"use strict";c.d(b,{ThemeProvider:()=>g});var d=c(92692),e=c(71277);let f=(0,e.createContext)({theme:"dark",toggleTheme:()=>{}});function g({children:a}){let[b,c]=(0,e.useState)("dark"),h=(0,e.useCallback)(()=>{c(a=>{let b,c="dark"===a?"light":"dark";return localStorage.setItem("conductor-theme",c),(b=document.documentElement).classList.remove("dark","light"),b.classList.add(c),c})},[]);return(0,d.jsx)(f.Provider,{value:{theme:b,toggleTheme:h},children:a})}},43894:(a,b,c)=>{"use strict";c.d(b,{TooltipProvider:()=>h});var d=c(92692),e=c(49588),f=c(71277),g=c(93544);let h=e.Kq;e.bL,e.l9,(0,f.forwardRef)(({className:a,sideOffset:b=8,...c},f)=>(0,d.jsx)(e.ZL,{children:(0,d.jsx)(e.UC,{ref:f,sideOffset:b,className:(0,g.cn)("z-50 rounded-[var(--radius-xs)] border border-[var(--border-strong)] bg-[var(--bg-panel)] px-2 py-1.5","text-[11px] text-[var(--text-normal)] shadow-[var(--shadow-soft)]","animate-in fade-in-0 zoom-in-95",a),...c})})).displayName="TooltipContent"},46208:(a,b,c)=>{"use strict";c.d(b,{TooltipProvider:()=>e});var d=c(30274);let e=(0,d.registerClientReference)(function(){throw Error("Attempted to call TooltipProvider() from the server but TooltipProvider is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"/home/runner/work/conductor-oss/conductor-oss/packages/web/src/components/ui/Tooltip.tsx","TooltipProvider");(0,d.registerClientReference)(function(){throw Error("Attempted to call Tooltip() from the server but Tooltip is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"/home/runner/work/conductor-oss/conductor-oss/packages/web/src/components/ui/Tooltip.tsx","Tooltip"),(0,d.registerClientReference)(function(){throw Error("Attempted to call TooltipTrigger() from the server but TooltipTrigger is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"/home/runner/work/conductor-oss/conductor-oss/packages/web/src/components/ui/Tooltip.tsx","TooltipTrigger"),(0,d.registerClientReference)(function(){throw Error("Attempted to call TooltipContent() from the server but TooltipContent is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"/home/runner/work/conductor-oss/conductor-oss/packages/web/src/components/ui/Tooltip.tsx","TooltipContent"),(0,d.registerClientReference)(function(){throw Error("Attempted to call SimpleTooltip() from the server but SimpleTooltip is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"/home/runner/work/conductor-oss/conductor-oss/packages/web/src/components/ui/Tooltip.tsx","SimpleTooltip")},58498:(a,b,c)=>{"use strict";c.r(b),c.d(b,{"00927a55359fd3edee8b795e6b31bf6af5db9598de":()=>d.y});var d=c(30254)},59627:(a,b,c)=>{Promise.resolve().then(c.bind(c,33996)),Promise.resolve().then(c.bind(c,16413)),Promise.resolve().then(c.bind(c,58002)),Promise.resolve().then(c.bind(c,19867)),Promise.resolve().then(c.bind(c,89833)),Promise.resolve().then(c.bind(c,99896)),Promise.resolve().then(c.bind(c,12589)),Promise.resolve().then(c.bind(c,37806)),Promise.resolve().then(c.bind(c,43894))},66504:(a,b,c)=>{"use strict";c.d(b,{ThemeProvider:()=>e});var d=c(30274);let e=(0,d.registerClientReference)(function(){throw Error("Attempted to call ThemeProvider() from the server but ThemeProvider is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"/home/runner/work/conductor-oss/conductor-oss/packages/web/src/components/ThemeProvider.tsx","ThemeProvider");(0,d.registerClientReference)(function(){throw Error("Attempted to call useTheme() from the server but useTheme is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"/home/runner/work/conductor-oss/conductor-oss/packages/web/src/components/ThemeProvider.tsx","useTheme")},72567:(a,b,c)=>{Promise.resolve().then(c.t.bind(c,25696,23))},78143:(a,b,c)=>{Promise.resolve().then(c.t.bind(c,32594,23))},89257:(a,b,c)=>{Promise.resolve().then(c.t.bind(c,25696,23)),Promise.resolve().then(c.t.bind(c,69411,23)),Promise.resolve().then(c.t.bind(c,8447,23)),Promise.resolve().then(c.t.bind(c,50674,23)),Promise.resolve().then(c.t.bind(c,78886,23)),Promise.resolve().then(c.t.bind(c,24194,23)),Promise.resolve().then(c.t.bind(c,93431,23)),Promise.resolve().then(c.bind(c,23858))},89891:(a,b,c)=>{"use strict";c.d(b,{A:()=>e});var d=c(85660);let e=(0,d.createServerReference)("009396d30a8813ef0f7a2827d302825e6ee64e6f52",d.callServer,void 0,d.findSourceMapURL,"detectKeylessEnvDriftAction")},91946:(a,b,c)=>{"use strict";c.r(b),c.d(b,{default:()=>e});var d=c(42131);let e=async a=>[{type:"image/svg+xml",sizes:"any",url:(0,d.fillMetadataSegment)(".",await a.params,"icon.svg",!0)+"?270c676221766b43"}]},93544:(a,b,c)=>{"use strict";c.d(b,{cn:()=>f});var d=c(9537),e=c(43165);function f(...a){return(0,e.QP)((0,d.$)(a))}},95235:(a,b,c)=>{"use strict";c.r(b),c.d(b,{default:()=>y,metadata:()=>v,viewport:()=>w});var d=c(2474),e=c(26543),f=c.n(e),g=c(27897),h=c.n(g),i=c(56004),j=c.n(i),k=c(62078),l=c.n(k),m=c(76323),n=c(90075),o=c(9330),p=c(66504),q=c(46208),r=c(36026),s=c(72460);c(14276);let t=`${j().variable} ${f().variable} ${h().variable} ${l().variable}`,u="1"===process.env.VERCEL||"true"===process.env.VERCEL,v={title:"Conductor",description:"Multi-agent orchestrator dashboard"},w={width:"device-width",initialScale:1};function x({children:a}){let b=(0,r._)()??"";return(0,d.jsxs)("html",{lang:"en",className:`${t} dark`,suppressHydrationWarning:!0,children:[(0,d.jsxs)("head",{children:[(0,d.jsx)("meta",{name:"conductor-backend-url",content:b}),(0,d.jsx)("script",{dangerouslySetInnerHTML:{__html:'try{var t=localStorage.getItem("conductor-theme");var e=document.documentElement;e.classList.remove("light","dark");e.classList.add(t==="light"||t==="dark"?t:"dark")}catch{}'}})]}),(0,d.jsx)("body",{className:"bg-[var(--bg-canvas)] text-[var(--text-strong)] antialiased",children:(0,d.jsx)(q.TooltipProvider,{children:(0,d.jsxs)(p.ThemeProvider,{children:[a,u?(0,d.jsx)(n.Analytics,{}):null]})})})]})}async function y({children:a}){let b=await (0,o.headers)(),c=(0,s.Pn)(b),e=(0,s.kE)(b),f=(0,s.EO)(c,e);return f.enabled&&f.publishableKey?(0,d.jsx)(m.lJ,{publishableKey:f.publishableKey,proxyUrl:f.proxyUrl??void 0,clerkJSUrl:f.clerkJSUrl??void 0,signInUrl:f.signInUrl??void 0,signUpUrl:f.signUpUrl??void 0,allowedRedirectOrigins:f.allowedRedirectOrigins.length>0?f.allowedRedirectOrigins:void 0,appearance:{cssLayerName:"clerk"},children:(0,d.jsx)(x,{children:a})}):(0,d.jsx)(x,{children:a})}},98985:(a,b,c)=>{Promise.resolve().then(c.t.bind(c,32594,23)),Promise.resolve().then(c.t.bind(c,6413,23)),Promise.resolve().then(c.t.bind(c,61437,23)),Promise.resolve().then(c.t.bind(c,99476,23)),Promise.resolve().then(c.t.bind(c,41452,23)),Promise.resolve().then(c.t.bind(c,86792,23)),Promise.resolve().then(c.t.bind(c,48465,23)),Promise.resolve().then(c.t.bind(c,13592,23))}};
@@ -1 +1 @@
1
- "use strict";exports.id=9455,exports.ids=[9455],exports.modules={9455:(a,b,c)=>{c.r(b),c.d(b,{KeylessCreatorOrReader:()=>h});var d=c(67994),e=c(71277),f=c.n(e),g=c(54312);let h=a=>{var b;let{children:c}=a,h=(null==(b=(0,d.useSelectedLayoutSegments)()[0])?void 0:b.startsWith("/_not-found"))||!1,[i,j]=f().useActionState(g.a,null);return((0,e.useEffect)(()=>{h||f().startTransition(()=>{j()})},[h]),f().isValidElement(c))?f().cloneElement(c,{key:null==i?void 0:i.publishableKey,publishableKey:null==i?void 0:i.publishableKey,__internal_keyless_claimKeylessApplicationUrl:null==i?void 0:i.claimUrl,__internal_keyless_copyInstanceKeysUrl:null==i?void 0:i.apiKeysUrl,__internal_bypassMissingPublishableKey:!0}):c}},54312:(a,b,c)=>{c.d(b,{a:()=>e});var d=c(85660);let e=(0,d.createServerReference)("009ed4762d0be7e46d5793d30a2572312006ef1919",d.callServer,void 0,d.findSourceMapURL,"createOrReadKeylessAction")}};
1
+ "use strict";exports.id=9455,exports.ids=[9455],exports.modules={9455:(a,b,c)=>{c.r(b),c.d(b,{KeylessCreatorOrReader:()=>h});var d=c(67994),e=c(71277),f=c.n(e),g=c(21292);let h=a=>{var b;let{children:c}=a,h=(null==(b=(0,d.useSelectedLayoutSegments)()[0])?void 0:b.startsWith("/_not-found"))||!1,[i,j]=f().useActionState(g.a,null);return((0,e.useEffect)(()=>{h||f().startTransition(()=>{j()})},[h]),f().isValidElement(c))?f().cloneElement(c,{key:null==i?void 0:i.publishableKey,publishableKey:null==i?void 0:i.publishableKey,__internal_keyless_claimKeylessApplicationUrl:null==i?void 0:i.claimUrl,__internal_keyless_copyInstanceKeysUrl:null==i?void 0:i.apiKeysUrl,__internal_bypassMissingPublishableKey:!0}):c}},21292:(a,b,c)=>{c.d(b,{a:()=>e});var d=c(85660);let e=(0,d.createServerReference)("0056a043e7b275ff1a94e951b504cb5d5b7fea4808",d.callServer,void 0,d.findSourceMapURL,"createOrReadKeylessAction")}};
@@ -1 +1 @@
1
- globalThis.__BUILD_MANIFEST={polyfillFiles:["static/chunks/polyfills-42372ed130431b0a.js"],devFiles:[],lowPriorityFiles:["static/wSKJfeGluep6ETJsfyTGv/_buildManifest.js","static/wSKJfeGluep6ETJsfyTGv/_ssgManifest.js"],rootMainFiles:["static/chunks/webpack-cc708b43e5621559.js","static/chunks/87c73c54-014124adcece3495.js","static/chunks/1968-281077ad765d1294.js","static/chunks/main-app-d6167a36ed763f15.js"],rootMainFilesTree:{},pages:{"/_app":[]}};
1
+ globalThis.__BUILD_MANIFEST={polyfillFiles:["static/chunks/polyfills-42372ed130431b0a.js"],devFiles:[],lowPriorityFiles:["static/W7Ix_gUgmq_cKa_iZEKIf/_buildManifest.js","static/W7Ix_gUgmq_cKa_iZEKIf/_ssgManifest.js"],rootMainFiles:["static/chunks/webpack-b8e6b1ccb85a3faa.js","static/chunks/87c73c54-014124adcece3495.js","static/chunks/1968-281077ad765d1294.js","static/chunks/main-app-d6167a36ed763f15.js"],rootMainFilesTree:{},pages:{"/_app":[]}};