@useorgx/openclaw-plugin 0.7.16 → 0.7.17
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dashboard/dist/assets/{C3PrI8L7.js → 05zHA1Am.js} +1 -1
- package/dashboard/dist/assets/05zHA1Am.js.br +0 -0
- package/dashboard/dist/assets/05zHA1Am.js.gz +0 -0
- package/dashboard/dist/assets/{JDPvhd68.js → 0uYJrBLl.js} +1 -1
- package/dashboard/dist/assets/0uYJrBLl.js.br +0 -0
- package/dashboard/dist/assets/0uYJrBLl.js.gz +0 -0
- package/dashboard/dist/assets/{8pbG6uLK.js → 8nr6IqT4.js} +1 -1
- package/dashboard/dist/assets/8nr6IqT4.js.br +0 -0
- package/dashboard/dist/assets/8nr6IqT4.js.gz +0 -0
- package/dashboard/dist/assets/{R6N_VVqm.js → B7kFLPiD.js} +1 -1
- package/dashboard/dist/assets/B7kFLPiD.js.br +0 -0
- package/dashboard/dist/assets/B7kFLPiD.js.gz +0 -0
- package/dashboard/dist/assets/{Cn8sRTkO.js → B8NuBCcY.js} +1 -1
- package/dashboard/dist/assets/B8NuBCcY.js.br +0 -0
- package/dashboard/dist/assets/B8NuBCcY.js.gz +0 -0
- package/dashboard/dist/assets/{D5IgXoTj.js → BDlKSbsp.js} +1 -1
- package/dashboard/dist/assets/BDlKSbsp.js.br +0 -0
- package/dashboard/dist/assets/BDlKSbsp.js.gz +0 -0
- package/dashboard/dist/assets/C8AYbjlq.js +212 -0
- package/dashboard/dist/assets/C8AYbjlq.js.br +0 -0
- package/dashboard/dist/assets/C8AYbjlq.js.gz +0 -0
- package/dashboard/dist/assets/{BkMrrjAv.js → CMir7ekf.js} +1 -1
- package/dashboard/dist/assets/CMir7ekf.js.br +0 -0
- package/dashboard/dist/assets/CMir7ekf.js.gz +0 -0
- package/dashboard/dist/assets/{cEP7N1dn.js → CWXk6UZl.js} +1 -1
- package/dashboard/dist/assets/CWXk6UZl.js.br +0 -0
- package/dashboard/dist/assets/CWXk6UZl.js.gz +0 -0
- package/dashboard/dist/assets/{konqMbVI.js → CoDun8X6.js} +1 -1
- package/dashboard/dist/assets/CoDun8X6.js.br +0 -0
- package/dashboard/dist/assets/CoDun8X6.js.gz +0 -0
- package/dashboard/dist/assets/{CUXb_4F3.js → Crj3jKHE.js} +1 -1
- package/dashboard/dist/assets/Crj3jKHE.js.br +0 -0
- package/dashboard/dist/assets/Crj3jKHE.js.gz +0 -0
- package/dashboard/dist/assets/{wc6cgXzV.js → CyUpNSKv.js} +1 -1
- package/dashboard/dist/assets/CyUpNSKv.js.br +0 -0
- package/dashboard/dist/assets/CyUpNSKv.js.gz +0 -0
- package/dashboard/dist/assets/{Bv_86bUY.js → D8mvKY2h.js} +1 -1
- package/dashboard/dist/assets/D8mvKY2h.js.br +0 -0
- package/dashboard/dist/assets/D8mvKY2h.js.gz +0 -0
- package/dashboard/dist/assets/{C6AqbA9J.js → DBRLnKWw.js} +1 -1
- package/dashboard/dist/assets/DBRLnKWw.js.br +0 -0
- package/dashboard/dist/assets/DBRLnKWw.js.gz +0 -0
- package/dashboard/dist/assets/{BpF7v1Dk.js → DBct8HLW.js} +1 -1
- package/dashboard/dist/assets/DBct8HLW.js.br +0 -0
- package/dashboard/dist/assets/DBct8HLW.js.gz +0 -0
- package/dashboard/dist/assets/{BM75sh1f.js → DLNTxNX-.js} +1 -1
- package/dashboard/dist/assets/DLNTxNX-.js.br +0 -0
- package/dashboard/dist/assets/DLNTxNX-.js.gz +0 -0
- package/dashboard/dist/assets/{BYVYH9CH.js → DdYkuATV.js} +1 -1
- package/dashboard/dist/assets/DdYkuATV.js.br +0 -0
- package/dashboard/dist/assets/DdYkuATV.js.gz +0 -0
- package/dashboard/dist/assets/{DXzpQUC0.js → DvFumX8R.js} +1 -1
- package/dashboard/dist/assets/DvFumX8R.js.br +0 -0
- package/dashboard/dist/assets/DvFumX8R.js.gz +0 -0
- package/dashboard/dist/assets/RZkbqlJk.css +1 -0
- package/dashboard/dist/assets/RZkbqlJk.css.br +0 -0
- package/dashboard/dist/assets/RZkbqlJk.css.gz +0 -0
- package/dashboard/dist/index.html +2 -2
- package/dashboard/dist/index.html.br +0 -0
- package/dashboard/dist/index.html.gz +0 -0
- package/package.json +1 -1
- package/dashboard/dist/assets/8pbG6uLK.js.br +0 -0
- package/dashboard/dist/assets/8pbG6uLK.js.gz +0 -0
- package/dashboard/dist/assets/B1LENRC8.js +0 -212
- package/dashboard/dist/assets/B1LENRC8.js.br +0 -0
- package/dashboard/dist/assets/B1LENRC8.js.gz +0 -0
- package/dashboard/dist/assets/BM75sh1f.js.br +0 -0
- package/dashboard/dist/assets/BM75sh1f.js.gz +0 -0
- package/dashboard/dist/assets/BYVYH9CH.js.br +0 -0
- package/dashboard/dist/assets/BYVYH9CH.js.gz +0 -0
- package/dashboard/dist/assets/BkMrrjAv.js.br +0 -0
- package/dashboard/dist/assets/BkMrrjAv.js.gz +0 -0
- package/dashboard/dist/assets/BpF7v1Dk.js.br +0 -0
- package/dashboard/dist/assets/BpF7v1Dk.js.gz +0 -0
- package/dashboard/dist/assets/Bv_86bUY.js.br +0 -0
- package/dashboard/dist/assets/Bv_86bUY.js.gz +0 -0
- package/dashboard/dist/assets/C3PrI8L7.js.br +0 -0
- package/dashboard/dist/assets/C3PrI8L7.js.gz +0 -0
- package/dashboard/dist/assets/C6AqbA9J.js.br +0 -0
- package/dashboard/dist/assets/C6AqbA9J.js.gz +0 -0
- package/dashboard/dist/assets/CUXb_4F3.js.br +0 -0
- package/dashboard/dist/assets/CUXb_4F3.js.gz +0 -0
- package/dashboard/dist/assets/Cn8sRTkO.js.br +0 -0
- package/dashboard/dist/assets/Cn8sRTkO.js.gz +0 -0
- package/dashboard/dist/assets/D5IgXoTj.js.br +0 -0
- package/dashboard/dist/assets/D5IgXoTj.js.gz +0 -0
- package/dashboard/dist/assets/DXzpQUC0.js.br +0 -0
- package/dashboard/dist/assets/DXzpQUC0.js.gz +0 -0
- package/dashboard/dist/assets/JDPvhd68.js.br +0 -0
- package/dashboard/dist/assets/JDPvhd68.js.gz +0 -0
- package/dashboard/dist/assets/R6N_VVqm.js.br +0 -0
- package/dashboard/dist/assets/R6N_VVqm.js.gz +0 -0
- package/dashboard/dist/assets/cEP7N1dn.js.br +0 -0
- package/dashboard/dist/assets/cEP7N1dn.js.gz +0 -0
- package/dashboard/dist/assets/iLnvdWmW.css +0 -1
- package/dashboard/dist/assets/iLnvdWmW.css.br +0 -0
- package/dashboard/dist/assets/iLnvdWmW.css.gz +0 -0
- package/dashboard/dist/assets/konqMbVI.js.br +0 -0
- package/dashboard/dist/assets/konqMbVI.js.gz +0 -0
- package/dashboard/dist/assets/wc6cgXzV.js.br +0 -0
- package/dashboard/dist/assets/wc6cgXzV.js.gz +0 -0
|
Binary file
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{r as o,j as e}from"./Dj2k1r16.js";import{E as ie,e as T,y as qe,a0 as H,v as De,a1 as Be,a2 as Oe,M as ze,h as Le,P as Ue,B as oe}from"./B1LENRC8.js";import{E as Ge}from"./C6AqbA9J.js";import{A as Re,m as ce,u as Ke}from"./eeHXe_OQ.js";import{u as Xe}from"./Bv_86bUY.js";import"./DMKyYAtD.js";import"./cX2e-TLi.js";import"./BjK42gtU.js";import"./BV0BcV1u.js";const Je={pr:"⎋",file:"◇",artifact:"▪",log:"▸",decision:"◈"};function Ve(a){return a>=.8?"#BFFF00":a>=.5?"#F5B700":"#FF6B88"}function Ze(a){const t=a.match(/https?:\/\/\S+/);return t?t[0]:null}function Qe({evidenceType:a,title:t,summary:u,sourceUrl:p,confidence:b,payload:v,icon:R,label:w,onOpenTerminal:k}){const[N,B]=o.useState(!1),O=t??w??null,E=a??(R?R.toUpperCase():null),_=R?Je[R]:null,M=R==="pr"&&w?Ze(w):null;return e.jsxs("div",{className:"rounded-xl border border-white/[0.06] bg-white/[0.02] px-3 py-2.5",children:[e.jsxs("div",{className:"flex items-start gap-2.5 cursor-pointer",onClick:()=>B(y=>!y),children:[(E||_)&&e.jsxs("span",{className:"mt-0.5 flex-shrink-0 rounded bg-white/[0.06] px-1.5 py-0.5 text-[10px] font-semibold uppercase tracking-wider text-secondary",children:[_?e.jsx("span",{className:"mr-1",children:_}):null,E]}),e.jsxs("div",{className:"min-w-0 flex-1",children:[O&&e.jsx("p",{className:"text-body font-medium text-primary",children:p?e.jsx("a",{href:p,target:"_blank",rel:"noopener noreferrer",className:"text-[#D8FFA1] hover:underline",onClick:y=>y.stopPropagation(),children:O}):M?e.jsx("a",{href:M,target:"_blank",rel:"noopener noreferrer",className:"text-[#D8FFA1] hover:underline",onClick:y=>y.stopPropagation(),children:O}):O}),u&&e.jsx("p",{className:`mt-0.5 text-caption text-secondary ${N?"":"line-clamp-2"}`,children:u})]}),e.jsx("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",className:`mt-1 flex-shrink-0 text-muted transition-transform ${N?"rotate-180":""}`,children:e.jsx("path",{d:"m6 9 6 6 6-6"})})]}),b!=null&&e.jsxs("div",{className:"mt-2 flex items-center gap-2",children:[e.jsx("div",{className:"h-1 flex-1 overflow-hidden rounded-full bg-white/[0.06]",children:e.jsx("div",{className:"h-full rounded-full transition-all",style:{width:`${Math.round(b*100)}%`,backgroundColor:Ve(b)}})}),e.jsxs("span",{className:"text-micro text-muted tabular-nums",children:[Math.round(b*100),"%"]})]}),e.jsx(Re,{children:N&&e.jsx(ce.div,{initial:{height:0,opacity:0},animate:{height:"auto",opacity:1},exit:{height:0,opacity:0},transition:{duration:.2},className:"overflow-hidden",children:e.jsxs("div",{className:"mt-2 space-y-2",children:[R==="log"&&k&&e.jsxs("button",{type:"button",onClick:y=>{y.stopPropagation(),k()},className:"inline-flex items-center gap-1.5 rounded-lg border border-white/[0.12] bg-white/[0.04] px-3 py-1.5 text-caption font-semibold text-primary transition-colors hover:bg-white/[0.08]",children:[e.jsx("span",{className:"font-mono text-micro",children:">_"}),"Open in terminal"]}),v&&Object.keys(v).length>0&&e.jsx("pre",{className:"max-h-40 overflow-auto rounded-lg bg-black/40 p-2.5 text-micro text-secondary font-mono",children:JSON.stringify(v,null,2)})]})})})]})}function Ye({segments:a}){return a.length===0?null:e.jsx("nav",{className:"flex items-center gap-1.5 min-w-0 text-caption text-secondary",children:a.map((t,u)=>e.jsxs("span",{className:"flex items-center gap-1.5 min-w-0",children:[u>0&&e.jsx("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",className:"flex-shrink-0 text-faint",children:e.jsx("path",{d:"m9 18 6-6-6-6"})}),t.icon&&e.jsx(ie,{type:t.icon,size:11,className:"flex-shrink-0 opacity-80"}),t.onClick?e.jsx("button",{type:"button",onClick:t.onClick,className:"truncate transition-colors hover:text-primary",children:t.label}):e.jsx("span",{className:"truncate",children:t.label})]},u))})}const ye={label:"Retry this workstream",description:"Re-run with the same configuration. Recommended if this was a transient issue.",impliedStatus:"approved"},K={label:"Skip and continue",description:"Mark as accepted and move to the next workstream.",impliedStatus:"approved"},He=[{test:/Worker exited without structured output.*?code=(\S+?),\s*signal=(\S+?)\)/i,headline:"Agent work stopped unexpectedly",explain:(a,t)=>{const u=t[1]==="null"?"none":t[1],p=t[2]==="null"?"none":t[2];return`The agent process exited before producing results. Exit code: ${u}. Signal: ${p}. This usually means the worker was terminated externally or ran out of resources.`},severity:"critical",options:[ye,{label:"Retry with more resources",description:"Increase token budget before re-running.",impliedStatus:"approved"},K],extractDetails:(a,t)=>({exitCode:t[1]==="null"?void 0:t[1],signal:t[2]==="null"?void 0:t[2]})},{test:/MCP handshake failed(?:\s+for\s+(\S+))?/i,headline:"Agent couldn't connect to tools",explain:(a,t)=>`The agent failed to connect to its tool server${t[1]?` (${t[1]})`:""}. This typically means the MCP server is unreachable or took too long to respond.`,severity:"critical",options:[ye,{label:"Check MCP server",description:"Investigate the tool server connection before retrying.",impliedStatus:"approved"},K],extractDetails:(a,t)=>({server:t[1]||void 0})},{test:/(?:Slice|Autopilot slice) timed out after (\d+)/i,headline:"Agent ran out of time",explain:(a,t)=>{const u=Math.round(parseInt(t[1],10)/6e4);return`The agent exceeded its ${u>0?`${u}-minute`:`${t[1]}ms`} time limit. Consider breaking the work into smaller steps or increasing the time budget.`},severity:"warning",options:[{label:"Retry with more time",description:"Increase the timeout before re-running.",impliedStatus:"approved"},{label:"Break into smaller tasks",description:"Split the workstream into smaller pieces that fit the time budget.",impliedStatus:"approved"},K],extractDetails:(a,t)=>({elapsedMs:t[1]})},{test:/(?:Slice|Autopilot slice) stalled/i,headline:"Agent stopped making progress",explain:()=>"The agent stopped producing output. It may be stuck in a loop, waiting on an unresponsive resource, or unable to proceed with the current approach.",severity:"warning",options:[ye,{label:"Review logs",description:"Check the session logs to understand why the agent stalled.",impliedStatus:"approved"},K]},{test:/blocked.*?(?:needs|requires?) intervention/i,headline:"Agent needs your help to continue",explain:()=>"The agent reached a point where it cannot proceed without human guidance. This may be a question about requirements, a permission needed, or an ambiguity.",severity:"warning",options:[{label:"Review blocker",description:"Look at what the agent needs and provide guidance.",impliedStatus:"approved"},{label:"Provide guidance",description:"Add a note with instructions for the agent.",impliedStatus:"approved"},K]},{test:/completed.*?(?:without|no) (?:verifiable )?(?:outcomes?|artifacts?)/i,headline:"Agent finished but produced no outputs",explain:()=>"The agent reported completion but produced no artifacts or status updates. The work may have been done informally, or the agent could not find actionable work.",severity:"info",options:[{label:"Accept as-is",description:"The work was done informally or no output was needed.",impliedStatus:"approved"},{label:"Retry with stronger output requirements",description:"Re-run and require the agent to produce structured artifacts.",impliedStatus:"approved"},K]},{test:/Spawn guard denied/i,headline:"Agent dispatch was blocked by safety check",explain:()=>"The system's safety checks prevented this agent from starting. This is typically due to capacity limits or quality gate requirements.",severity:"warning",options:[{label:"Approve exception",description:"Override the safety check and allow dispatch.",impliedStatus:"approved"},{label:"Investigate quality gate",description:"Review what safety check failed before proceeding.",impliedStatus:"approved"},K]},{test:/code=(\d+)/i,headline:"Agent encountered an error",explain:(a,t)=>`The agent process exited with error code ${t[1]}. Reviewing the session logs will show what operation failed.`,severity:"critical",options:[ye,{label:"Review error logs",description:"Check session logs to understand the error before retrying.",impliedStatus:"approved"},K],extractDetails:(a,t)=>({exitCode:t[1]})}];function et(a){var u;const t=a.context||a.title||"";for(const p of He){const b=t.match(p.test);if(b)return{headline:p.headline,explanation:p.explain(t,b),structuredDetails:((u=p.extractDetails)==null?void 0:u.call(p,t,b))??{},suggestedOptions:p.options,severity:p.severity}}return a.decisionType==="autopilot_failure"?{headline:"Agent work needs attention",explanation:t||"An issue occurred during autopilot execution that requires review.",structuredDetails:{},suggestedOptions:[ye,K],severity:"warning"}:{headline:a.title||"Decision needed",explanation:t||"Review the details and choose an action.",structuredDetails:{},suggestedOptions:[],severity:"info"}}function tt(a){return a.map((t,u)=>({id:`suggested-${u}`,label:t.label,description:t.description,impliedStatus:t.impliedStatus,actionType:null,requiresNote:!1}))}function rt(a,t){var w;if(!t||!a.workstreamId||!t.nodes.find(k=>k.id===a.workstreamId&&k.entityType==="workstream"))return null;const p=new Set(t.edges.filter(k=>k.source===a.workstreamId).map(k=>k.target)),b=[];for(const k of p){const N=t.nodes.find(B=>B.id===k);N&&b.push({id:N.id,title:N.title,taskCount:((w=N.children)==null?void 0:w.length)??0,status:N.status})}if(b.length===0)return null;const v=b.reduce((k,N)=>k+N.taskCount,0),R=b.some(k=>t.edges.some(N=>N.source===k.id));return{blockedWorkstreams:b,totalBlockedTasks:v,criticalPath:R}}function st(a){const t=a.blockedWorkstreams.length,u=a.blockedWorkstreams.map(p=>p.title);return t===1?`Resolving this unblocks 1 downstream workstream: ${u[0]}.`:t<=3?`Resolving this unblocks ${t} downstream workstreams: ${u.join(", ")}.`:`Resolving this unblocks ${t} downstream workstreams including ${u[0]} and ${u[1]}.`}const Pe=typeof navigator<"u"&&/Mac|iPhone|iPad/.test(navigator.userAgent);function nt(a){try{return JSON.stringify(a,null,2)}catch{return null}}function Fe(a){if(typeof a!="string")return null;const t=a.trim().toLowerCase();return t==="rejected"?"declined":t==="approved"||t==="declined"||t==="cancelled"?t:null}function Ce(a,t){return!a||a.trim().length===0?t:Le(a.trim())||t}function it(a){switch(a){case"spawn_guard_blocked":return"Spawn Guard";case"autopilot_failure":return"Autopilot Failure";case"budget_exceeded":return"Budget Exceeded";case"scope_change":return"Scope Change";case"conflict_resolution":return"Conflict Resolution";case"approval_required":return"Approval Required";case"review_required":return"Review Required";case"permission_request":return"Permission Request";default:return a.replace(/[_-]/g," ").replace(/\b\w/g,t=>t.toUpperCase())}}function at(a){const t=a.toLowerCase();return t==="critical"||t==="p0"?T.red:t==="high"||t==="p1"?T.amber:t==="medium"||t==="p2"?T.iris:"rgba(255,255,255,0.5)"}function lt({open:a,decision:t,onClose:u,onApprove:p,onReject:b,initiativeTitle:v,workstreamTitle:R,onNavigate:w,currentIndex:k,totalCount:N,onFocusRunId:B,graph:O}){const[E,_]=o.useState("idle"),[M,y]=o.useState(null),[P,F]=o.useState(null),[C,X]=o.useState(""),[ve,ee]=o.useState(!1),[de,je]=o.useState(!1),J=o.useRef(null),ae=o.useRef(),ue=o.useRef(u);ue.current=u,o.useEffect(()=>{if(a){_("idle"),y(null);const i=(t==null?void 0:t.selectedOptionId)??(t!=null&&t.options&&t.options.length===1?t.options[0].id:null);F(i),X(""),ee(!1),je(!1)}return()=>{ae.current&&clearTimeout(ae.current)}},[a,t==null?void 0:t.id]);const z=t==null?void 0:t.metadata,W=o.useMemo(()=>{if(!z)return[];const i=z,l=i.decision_options??i.options??i.actions??null;if(!Array.isArray(l))return[];const j=[],D=new Set;for(let L=0;L<l.length;L+=1){const Q=l[L];if(typeof Q=="string"){const s=Q.trim();if(!s)continue;const r=`option-${L+1}`;if(D.has(r))continue;D.add(r),j.push({id:r,label:s,description:null,impliedStatus:null,actionType:null,requiresNote:!1});continue}if(!Q||typeof Q!="object")continue;const g=Q,be=typeof g.id=="string"&&g.id.trim()||typeof g.option_id=="string"&&g.option_id.trim()||typeof g.action_id=="string"&&g.action_id.trim()||`option-${L+1}`;if(D.has(be))continue;const we=typeof g.label=="string"&&g.label.trim()||typeof g.title=="string"&&g.title.trim()||typeof g.name=="string"&&g.name.trim()||typeof g.action=="string"&&g.action.trim()||null;we&&(D.add(be),j.push({id:be,label:we,description:typeof g.description=="string"?g.description:null,impliedStatus:Fe(g.implied_status)??Fe(g.status),actionType:typeof g.action_type=="string"&&g.action_type||typeof g.type=="string"&&g.type||null,requiresNote:g.requires_note===!0||g.requiresNote===!0||g.note_required===!0}))}return j.slice(0,12)},[z]),f=o.useMemo(()=>t?et(t):null,[t==null?void 0:t.context,t==null?void 0:t.title,t==null?void 0:t.decisionType]),te=o.useMemo(()=>t?rt(t,O??null):null,[t==null?void 0:t.workstreamId,t==null?void 0:t.initiativeId,O]),le=((t==null?void 0:t.waitingMinutes)??0)>1440,A=o.useMemo(()=>t!=null&&t.options&&t.options.length>0?t.options:W.length>0?W:f&&f.suggestedOptions.length>0?tt(f.suggestedOptions):[],[t==null?void 0:t.options,W,f]),x=o.useMemo(()=>A.find(i=>i.id===P)??null,[A,P]),pe=(x==null?void 0:x.requiresNote)===!0,h=o.useMemo(()=>{const i=((t==null?void 0:t.context)??"").trim();if(i)return i;if(!z)return"";const l=z,j=(typeof l.summary=="string"?l.summary:null)??(typeof l.description=="string"?l.description:null)??"";return String(j??"").trim()},[t==null?void 0:t.context,z]),V=o.useMemo(()=>{const i=(t==null?void 0:t.waitingMinutes)??0;return i>=15?T.red:i>=5?T.amber:T.teal},[t==null?void 0:t.waitingMinutes]),q=o.useCallback(async()=>{if(!t)return;const i=nt({decision:t,metadata:z});if(i)try{await navigator.clipboard.writeText(i),ee(!0),setTimeout(()=>ee(!1),2e3)}catch{}},[t,z]),U=o.useCallback(()=>{const i=C.trim(),l=x==null?void 0:x.id;if(!(!i&&!l))return{note:i.length>0?i:void 0,optionId:l??void 0}},[C,x]),re=o.useCallback(async()=>{if(!t||!p)return;if(A.length>0&&!x){y("Select an option before approving this decision.");return}if(x!=null&&x.requiresNote&&C.trim().length===0){y("A note is required for the selected option."),requestAnimationFrame(()=>{var l;return(l=J.current)==null?void 0:l.focus()});return}let i=!1;if(_(l=>l==="approving"||l==="rejecting"?l:(i=!0,"approving")),!!i){y(null);try{const l=await p(t.id,U());l.failed>0?(_("error"),y(Ce(l.firstError,"Approval failed. Please try again."))):(_("success"),ae.current=setTimeout(()=>ue.current(),800))}catch(l){_("error");const j=l instanceof Error?l.message:"";y(Ce(j,"Approval failed."))}}},[U,t,C,p,A.length,x]),me=o.useCallback(async()=>{if(!t||!b)return;if(A.length>0&&!x){y("Select an option before rejecting this decision.");return}if(x!=null&&x.requiresNote&&C.trim().length===0){y("A note is required for the selected option."),requestAnimationFrame(()=>{var l;return(l=J.current)==null?void 0:l.focus()});return}let i=!1;if(_(l=>l==="approving"||l==="rejecting"?l:(i=!0,"rejecting")),!!i){y(null);try{const l=await b(t.id,U());l.failed>0?(_("error"),y(Ce(l.firstError,"Rejection failed. Please try again."))):(_("rejected"),ae.current=setTimeout(()=>ue.current(),800))}catch(l){_("error");const j=l instanceof Error?l.message:"";y(Ce(j,"Rejection failed."))}}},[U,t,C,b,A.length,x]);if(o.useEffect(()=>{if(!a)return;const i=l=>{var D,L;if((l.metaKey||l.ctrlKey)&&l.key==="Enter"){l.preventDefault(),re();return}const j=(D=l.target)==null?void 0:D.tagName;if(!(j==="INPUT"||j==="TEXTAREA"))switch(l.key){case"j":l.preventDefault(),w==null||w(1);break;case"k":l.preventDefault(),w==null||w(-1);break;case"a":l.preventDefault(),re();break;case"r":l.preventDefault(),me();break;case"n":l.preventDefault(),(L=J.current)==null||L.focus();break}};return document.addEventListener("keydown",i),()=>document.removeEventListener("keydown",i)},[a,re,me,w]),!a||!t)return null;const Z=E==="approving"||E==="rejecting",Me=E==="success"||E==="rejected",se=(t.status??"pending").toLowerCase(),ke=!se.includes("approved")&&!se.includes("resolved")&&!se.includes("rejected")&&!se.includes("declined")&&!se.includes("cancelled"),Ne=A.length>0&&!x,$e=(x==null?void 0:x.requiresNote)===!0&&C.trim().length===0,G=Z||Ne||$e,$=t.evidenceRefs??[],Ie=$.length>0,Se=t.recommendedAction??null,xe=t.decisionType??null,he=t.priority??null,fe=t.occurrenceCount??null,I=t.sourceRunId??null,ne=[];v&&ne.push({label:v,icon:"initiative"}),R&&ne.push({label:R,icon:"workstream"});const ge=[["ID",t.id],["Type",t.decisionType],["Dedupe key",t.dedupeKey],["Source system",t.sourceSystem],["Conflict source",t.conflictSource],["Agent ID",t.agentId],["Source run",t.sourceRunId],["Source session",t.sourceSessionId],["Source stream",t.sourceStreamId]].filter(([,i])=>i!=null);if(Me){const i=E==="success",l=i?T.lime:T.red;return e.jsx(qe,{open:a,onClose:u,maxWidth:"max-w-xl",fitContent:!0,children:e.jsxs("div",{className:"flex flex-col items-center justify-center px-8 py-12",children:[e.jsx("div",{className:"mb-4 flex h-16 w-16 items-center justify-center rounded-full",style:{backgroundColor:`${l}18`,border:`1.5px solid ${l}40`},children:i?e.jsx("svg",{width:"28",height:"28",viewBox:"0 0 24 24",fill:"none",stroke:l,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:e.jsx("polyline",{points:"20 6 9 17 4 12"})}):e.jsxs("svg",{width:"28",height:"28",viewBox:"0 0 24 24",fill:"none",stroke:l,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[e.jsx("path",{d:"M18 6L6 18"}),e.jsx("path",{d:"M6 6l12 12"})]})}),e.jsx("p",{className:"text-heading font-semibold text-white",children:i?"Approved":"Rejected"}),e.jsx("p",{className:"mt-1 text-body text-secondary",children:t.title})]})})}return e.jsx(qe,{open:a,onClose:u,maxWidth:"max-w-xl",children:e.jsxs("div",{className:"flex h-full min-h-0 w-full flex-col",style:le?{boxShadow:`inset 0 0 0 1px ${T.amber}30`,borderRadius:"inherit"}:void 0,children:[e.jsx("div",{className:"h-[2px] w-full flex-shrink-0",style:{background:`linear-gradient(90deg, ${V}60, ${V}20, transparent)`}}),w&&e.jsxs("div",{className:"flex items-center justify-between px-6 pt-3 pb-0",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx("button",{type:"button",onClick:()=>w(-1),className:"rounded p-1 text-muted hover:text-secondary hover:bg-white/[0.06] transition-colors",title:"Previous (k)",children:e.jsx("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:e.jsx("path",{d:"m15 18-6-6 6-6"})})}),e.jsx("button",{type:"button",onClick:()=>w(1),className:"rounded p-1 text-muted hover:text-secondary hover:bg-white/[0.06] transition-colors",title:"Next (j)",children:e.jsx("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:e.jsx("path",{d:"m9 18 6-6-6-6"})})}),k!=null&&N!=null&&e.jsxs("span",{className:"text-micro text-muted tabular-nums",children:[k+1," of ",N,e.jsx("span",{className:"ml-1 hidden sm:inline",children:"· Longest waiting first"})]})]}),e.jsx("button",{type:"button",onClick:u,"aria-label":"Close",className:"rounded p-1 text-muted hover:text-secondary hover:bg-white/[0.06] transition-colors",children:e.jsx("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:e.jsx("path",{d:"M18 6 6 18M6 6l12 12"})})})]}),ne.length>0&&e.jsx("div",{className:"px-6 pt-2",children:e.jsx(Ye,{segments:ne})}),e.jsxs("div",{className:"flex items-start justify-between gap-3 px-6 pt-4 pb-4",children:[e.jsx("div",{className:"min-w-0 flex-1",children:e.jsxs("div",{className:"flex items-center gap-2.5",children:[e.jsx("div",{className:"flex h-8 w-8 flex-shrink-0 items-center justify-center rounded-lg",style:{backgroundColor:`${V}14`,border:`1px solid ${V}30`},children:e.jsx(ie,{type:"decision",size:14})}),e.jsxs("div",{className:"min-w-0",children:[e.jsx("h2",{className:"text-title font-medium leading-tight text-white mb-2",children:t.title||"Decision Required"}),e.jsxs("div",{className:"flex flex-wrap items-center gap-2 text-body text-secondary",children:[e.jsx("span",{children:t.agentName||"OrgX Autopilot"}),e.jsx("span",{className:"text-white/[0.15]",children:"|"}),e.jsx("span",{className:le?"font-semibold text-red-300":"",children:H(t.waitingMinutes).text}),xe&&e.jsxs(e.Fragment,{children:[e.jsx("span",{className:"text-white/[0.15]",children:"|"}),e.jsx("span",{className:"text-primary",children:it(xe)})]}),he&&e.jsxs(e.Fragment,{children:[e.jsx("span",{className:"text-white/[0.15]",children:"|"}),e.jsx("span",{className:"font-medium",style:{color:at(he)},children:he})]})]}),fe!=null&&fe>1&&e.jsxs("p",{className:"mt-2 text-caption text-muted",children:["Seen ",fe," times",t.firstSeenAt&&e.jsxs(e.Fragment,{children:[" · first ",De(t.firstSeenAt)]}),t.lastSeenAt&&e.jsxs(e.Fragment,{children:[" · last ",De(t.lastSeenAt)]})]})]})]})}),!w&&e.jsx("button",{type:"button",onClick:u,"aria-label":"Close",className:"mt-0.5 flex h-8 w-8 flex-shrink-0 items-center justify-center rounded-lg text-muted transition-colors hover:bg-white/[0.06] hover:text-white",children:e.jsxs("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[e.jsx("path",{d:"M18 6L6 18"}),e.jsx("path",{d:"M6 6l12 12"})]})})]}),e.jsxs("div",{className:"min-h-0 flex-1 overflow-y-auto px-6 pb-4",children:[(t.initiativeId||t.workstreamId)&&e.jsx("div",{className:"mb-4",children:e.jsx(Be,{nodes:Oe({initiativeId:t.initiativeId,initiativeTitle:v,workstreamId:t.workstreamId,workstreamTitle:R,agentName:t.agentName,agentId:t.agentId}),activeId:t.workstreamId,compact:!0})}),Se&&e.jsxs("div",{className:"mb-4 rounded-xl border border-cyan-300/[0.28] bg-cyan-500/[0.12] px-4 py-3",children:[e.jsx("p",{className:"text-micro font-semibold uppercase tracking-wider text-cyan-200 mb-1",children:"Recommended"}),e.jsx("p",{className:"text-body text-cyan-100",children:Se})]}),Ie&&e.jsxs("div",{className:"mb-4",children:[e.jsx("p",{className:"mb-2 px-1 text-micro font-semibold uppercase tracking-wider text-muted",children:"Evidence"}),e.jsx("div",{className:"space-y-1.5",children:$.map((i,l)=>e.jsx(Qe,{evidenceType:i.evidenceType,title:i.title,summary:i.summary,sourceUrl:i.sourceUrl,confidence:i.confidence,payload:i.payload},l))})]}),le&&e.jsx("div",{className:"mb-4 rounded-xl border border-amber-400/[0.3] bg-amber-500/[0.08] px-4 py-3",children:e.jsxs("p",{className:"text-body text-amber-200",children:["This decision has been waiting"," ",e.jsx("span",{className:"font-semibold text-amber-100",children:H(t.waitingMinutes).text}),". Downstream work is paused."]})}),f&&f.headline!==t.title?e.jsxs("div",{className:"rounded-xl border border-white/[0.06] bg-white/[0.02] px-4 py-3",children:[e.jsx("p",{className:"text-micro font-semibold uppercase tracking-wider text-muted mb-2",children:"What happened"}),e.jsx("p",{className:"text-body text-primary leading-relaxed",children:f.explanation}),Object.keys(f.structuredDetails).length>0&&e.jsx("div",{className:"mt-3 flex flex-wrap gap-x-4 gap-y-1 text-caption text-secondary",children:Object.entries(f.structuredDetails).filter(([,i])=>i!=null).map(([i,l])=>e.jsxs("span",{children:[i.replace(/([A-Z])/g," $1").replace(/^./,j=>j.toUpperCase()),": ",l]},i))})]}):h?e.jsx("div",{className:"rounded-xl border border-white/[0.06] bg-white/[0.02] px-4 py-3",children:e.jsx(ze,{text:h,mode:"block"})}):e.jsx("p",{className:"px-1 text-body text-muted italic",children:"No additional context provided."}),A.length>0&&e.jsxs("div",{className:"mt-8",children:[e.jsx("p",{className:"mb-3 px-1 text-[11px] font-semibold uppercase tracking-widest text-muted",children:"Options"}),e.jsx("div",{className:"space-y-1 relative",children:A.map(i=>{const l=P===i.id;return e.jsxs("button",{type:"button",onClick:()=>{F(l?null:i.id),i.requiresNote&&requestAnimationFrame(()=>{var j;return(j=J.current)==null?void 0:j.focus()})},disabled:Z,className:"group relative flex w-full items-start gap-4 px-4 py-4 text-left focus:outline-none",children:[l&&e.jsx(ce.div,{layoutId:"decision-option-bg",className:"absolute inset-0 rounded-xl",style:{backgroundColor:`${T.lime}12`},transition:{type:"spring",stiffness:400,damping:25}}),!l&&e.jsx("div",{className:"absolute inset-0 rounded-xl opacity-0 transition-opacity group-hover:bg-white/[0.03]"}),e.jsx("div",{className:"relative mt-0.5 flex h-5 w-5 flex-shrink-0 items-center justify-center rounded-full border-[1.5px] transition-colors",style:{borderColor:l?T.lime:"rgba(255,255,255,0.2)"},children:e.jsx(Re,{children:l&&e.jsx(ce.div,{initial:{scale:0},animate:{scale:1},exit:{scale:0},transition:{type:"spring",stiffness:500,damping:30},className:"h-2.5 w-2.5 rounded-full",style:{backgroundColor:T.lime}})})}),e.jsxs("div",{className:"relative min-w-0 flex-1",children:[e.jsx("span",{className:`block text-[15px] ${l?"font-medium text-white":"text-primary"}`,children:i.label}),i.description&&e.jsx("p",{className:"mt-1 text-[13px] leading-relaxed text-secondary",children:i.description}),i.requiresNote&&e.jsx("p",{className:"mt-1.5 text-[11px] font-medium uppercase tracking-wider text-amber-400",children:"Note required"})]})]},i.id)})})]}),ke&&pe&&e.jsxs("div",{className:"mt-4",children:[e.jsx("textarea",{ref:J,value:C,onChange:i=>X(i.target.value),disabled:Z,placeholder:"Required: add context for this decision...",rows:3,className:"w-full resize-none rounded-xl border border-white/[0.08] bg-white/[0.03] px-4 py-3 text-body text-primary placeholder-white/30 outline-none transition-colors focus:border-white/[0.16] focus:bg-white/[0.04]"}),C.trim().length===0&&e.jsx("p",{className:"mt-2 text-caption text-amber-300",children:"This option requires a note before submission."})]}),te&&e.jsxs("div",{className:"mt-6 rounded-xl border border-white/[0.06] bg-white/[0.02] px-4 py-3",children:[e.jsx("p",{className:"text-micro font-semibold uppercase tracking-wider text-muted mb-2",children:"Impact"}),e.jsx("p",{className:"text-body text-primary leading-relaxed",children:st(te)}),te.blockedWorkstreams.length>0&&e.jsx("ul",{className:"mt-2 space-y-1 text-caption text-secondary",children:te.blockedWorkstreams.map(i=>e.jsxs("li",{className:"flex items-center gap-2",children:[e.jsx("span",{className:"inline-block h-1 w-1 rounded-full bg-amber-400 flex-shrink-0"}),i.title,i.status==="blocked"&&e.jsx("span",{className:"text-amber-400 text-micro",children:"(blocked)"})]},i.id))})]}),I&&B&&e.jsx("div",{className:"mt-4",children:e.jsxs("button",{type:"button",onClick:()=>B(I),className:"inline-flex items-center gap-1.5 text-caption text-[#D8FFA1] transition-colors hover:text-white",children:[e.jsx(ie,{type:"session",size:12}),"View source run"]})}),e.jsx("div",{className:"mt-4 border-t border-white/[0.06] pt-4",children:e.jsx(Ge,{entityType:"decision",entityId:t.id})}),ge.length>0&&e.jsxs("div",{className:"mt-4 border-t border-white/[0.06] pt-2",children:[e.jsxs("button",{type:"button",onClick:()=>je(i=>!i),className:"flex w-full items-center justify-between text-micro font-semibold uppercase tracking-wider text-muted hover:text-secondary transition-colors",children:[e.jsx("span",{children:"Technical details"}),e.jsx("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",className:`transition-transform ${de?"rotate-180":""}`,children:e.jsx("path",{d:"m6 9 6 6 6-6"})})]}),de&&e.jsx("div",{className:"mt-2 space-y-0.5",children:ge.map(([i,l])=>e.jsxs("div",{className:"flex gap-2 text-micro",children:[e.jsx("span",{className:"text-muted w-28 flex-shrink-0",children:i}),e.jsx("span",{className:"text-secondary truncate",children:l})]},i))})]}),e.jsxs("div",{className:"mt-4 flex flex-wrap gap-x-3 gap-y-1 text-micro text-muted opacity-60",children:[w&&e.jsx("span",{children:"j/k nav"}),e.jsx("span",{children:"a approve"}),e.jsx("span",{children:"r reject"}),e.jsx("span",{children:"n note"}),e.jsxs("span",{children:[Pe?"⌘":"Ctrl","+Enter approve"]}),e.jsx("span",{children:"esc close"})]})]}),M&&e.jsxs("div",{className:"flex items-center gap-2 border-t border-white/[0.06] px-6 py-3",children:[e.jsxs("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"none",stroke:T.red,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[e.jsx("circle",{cx:"12",cy:"12",r:"10"}),e.jsx("line",{x1:"12",x2:"12",y1:"8",y2:"12"}),e.jsx("line",{x1:"12",x2:"12.01",y1:"16",y2:"16"})]}),e.jsx("p",{className:"text-caption text-red-300",children:M})]}),ke&&e.jsx("div",{className:"relative mt-auto border-t border-white/[0.04] bg-black/60 px-6 py-5 backdrop-blur-xl",children:e.jsxs("div",{className:"flex items-center justify-between",children:[e.jsxs("div",{className:"flex items-center gap-3",children:[b&&e.jsx(ce.button,{whileTap:{scale:.97},type:"button",onClick:me,disabled:G,className:"rounded-lg px-4 py-2 text-[14px] font-medium text-secondary transition-colors hover:text-red-400 disabled:opacity-40 focus:outline-none",children:E==="rejecting"?e.jsxs("span",{className:"flex items-center gap-2",children:[e.jsx("span",{className:"inline-block h-3 w-3 animate-spin rounded-full border-[1.5px] border-current border-t-transparent"}),"Rejecting"]}):"Reject"}),e.jsx("button",{type:"button",onClick:q,className:"rounded-lg px-2 py-2 text-[13px] text-muted transition-colors hover:text-secondary focus:outline-none",title:"Copy decision as JSON",children:ve?"Copied":"Copy JSON"})]}),e.jsxs("div",{className:"flex items-center gap-4",children:[e.jsxs("span",{className:"hidden text-[13px] text-muted sm:block",children:[Pe?"⌘":"Ctrl","+Enter"]}),e.jsx(ce.button,{whileTap:!p||G?void 0:{scale:.97},type:"button",onClick:re,disabled:!p||G,"data-modal-autofocus":"true",className:"rounded-lg px-6 py-2.5 text-[14px] font-semibold transition-all focus:outline-none",style:{backgroundColor:!p||G?"rgba(255,255,255,0.06)":T.lime,color:!p||G?"rgba(255,255,255,0.4)":"#000"},children:E==="approving"?e.jsxs("span",{className:"flex items-center gap-2",children:[e.jsx("span",{className:"inline-block h-3 w-3 animate-spin rounded-full border-[1.5px] border-black/40 border-t-black"}),"Approving"]}):"Approve"})]})]})})]})})}const Te=40;function Ae(a,t){return!a||a.trim().length===0?t:Le(a.trim())||t}function Ee(a,t,u){const p=a==="approve"?`Approval failed for ${t} decision${t===1?"":"s"}.`:`Rejection failed for ${t} decision${t===1?"":"s"}.`;return Ae(u,p)}function _e(a){return a>=1440?"overdue":a>=60?"urgent":"normal"}function ot(a){return a.length>=32?a.slice(0,8):a}function We({group:a}){const t=_e(a.worstWaitingMinutes),u=a.decisions.length;return e.jsxs("div",{className:"flex items-center gap-2 px-1 pb-1 pt-2.5 first:pt-0",children:[e.jsx("span",{className:"text-caption font-semibold text-white/70 truncate",children:a.label}),e.jsxs("span",{className:"text-micro text-muted whitespace-nowrap",children:["(",u," decision",u===1?"":"s",")"]}),t==="overdue"&&e.jsxs("span",{className:"inline-flex items-center gap-1 rounded-full bg-red-500/[0.12] px-1.5 py-0.5 text-micro font-medium text-red-400",children:[e.jsx("span",{"aria-hidden":!0,className:"h-1.5 w-1.5 rounded-full bg-red-400"}),"overdue"]}),t==="urgent"&&e.jsxs("span",{className:"inline-flex items-center gap-1 rounded-full bg-amber-400/[0.12] px-1.5 py-0.5 text-micro font-medium text-amber-400",children:[e.jsx("span",{"aria-hidden":!0,className:"h-1.5 w-1.5 rounded-full bg-amber-400"}),"urgent"]})]})}function ct(a,t){return`${a}_${t}`}const wt=o.memo(function({decisions:t,focusDecisionId:u=null,onFocusDecisionHandled:p,onApproveDecision:b,onRejectDecision:v,onApproveAll:R,onBulkDecisionAction:w,mutationState:k,showHeader:N=!0,panelStyle:B="card",className:O,initiativeNames:E}){var we;const _=Ke(),[M,y]=o.useState(!1),[P,F]=o.useState(new Set),[C,X]=o.useState(new Set),[ve,ee]=o.useState(new Set),{enqueue:de,ToastRenderer:je}=Xe(),[J,ae]=o.useState("approve_selected"),[ue,z]=o.useState(""),[W,f]=o.useState(null),[te,le]=o.useState(Te),[A,x]=o.useState(null),pe=o.useRef(null),h=o.useMemo(()=>{const s=new Set;return[...t].filter(r=>s.has(r.id)?!1:(s.add(r.id),!0)).sort((r,n)=>{if(r.waitingMinutes!==n.waitingMinutes)return n.waitingMinutes-r.waitingMinutes;const c=Date.parse(r.requestedAt??r.updatedAt??""),d=Date.parse(n.requestedAt??n.updatedAt??""),m=Number.isFinite(c)?c:0;return(Number.isFinite(d)?d:0)-m})},[t]);o.useEffect(()=>{X(s=>{const r=new Set(h.map(c=>c.id)),n=new Set;for(const c of s)r.has(c)&&n.add(c);return n})},[h]);const V=C.size,q=o.useMemo(()=>h.filter(s=>!ve.has(s.id)).slice(0,te),[h,te,ve]),U=o.useMemo(()=>{const s=new Map,r=[];for(const c of q){const d=c.initiativeId??"_unscoped";let m=s.get(d);m||(m=[],s.set(d,m),r.push(d)),m.push(c)}const n=r.map(c=>{const d=s.get(c),m=Math.max(0,...d.map(Y=>Y.waitingMinutes)),S=c==="_unscoped"?"General":(E==null?void 0:E[c])??ot(c);return{initiativeId:c,label:S,decisions:d,worstWaitingMinutes:m}});return n.sort((c,d)=>d.worstWaitingMinutes-c.worstWaitingMinutes),n},[q,E]),re=o.useMemo(()=>{if(q.length===0)return!1;for(const s of q)if(!C.has(s.id))return!1;return!0},[C,q]),me=o.useMemo(()=>A?h.find(s=>s.id===A)??null:null,[A,h]),Z=o.useMemo(()=>A?h.findIndex(s=>s.id===A):-1,[A,h]),Me=o.useCallback(s=>{const r=Z+s;r>=0&&r<h.length&&x(h[r].id)},[Z,h]),se=async(s,r)=>{f(null),F(c=>{const d=new Set(c);return d.add(s),d});const n=await b(s,r);return n.failed>0?f(Ee("approve",n.failed,n.firstError)):n.updated>0&&f("Decision approved. Changes synced."),F(c=>{const d=new Set(c);return d.delete(s),d}),n},ke=v?async(s,r)=>{f(null),F(c=>{const d=new Set(c);return d.add(s),d});const n=await v(s,r);return n.failed>0?f(Ee("reject",n.failed,n.firstError)):n.updated>0&&f("Decision rejected. Changes synced."),F(c=>{const d=new Set(c);return d.delete(s),d}),n}:void 0;o.useEffect(()=>{le(s=>h.length===0?0:Math.min(Math.max(Te,s),h.length))},[h.length]),o.useEffect(()=>{const s=(u??"").trim();if(!s){pe.current=null;return}pe.current===s||!h.some(n=>n.id===s)||(pe.current=s,x(s),p==null||p(s))},[u,p,h]);const Ne=s=>{X(r=>{const n=new Set(r);return n.has(s)?n.delete(s):n.add(s),n})},$e=()=>{X(s=>{if(q.length===0)return s;const r=new Set(s),n=re;for(const c of q)n?r.delete(c.id):r.add(c.id);return r})},G=o.useMemo(()=>{const s=h.map(n=>n.id).filter(n=>C.has(n)),r=q.map(n=>n.id);return[{id:"approve_selected",label:`Approve selected (${s.length})`,action:"approve",ids:s},{id:"reject_selected",label:`Reject selected (${s.length})`,action:"reject",ids:s,hidden:!v},{id:"approve_visible",label:`Approve visible (${r.length})`,action:"approve",ids:r},{id:"reject_visible",label:`Reject visible (${r.length})`,action:"reject",ids:r,hidden:!v}].filter(n=>!n.hidden)},[v,C,h,q]),$=o.useMemo(()=>G.find(s=>s.id===J)??G[0]??null,[J,G]),Ie=async(s,r,n)=>{if(s.length===0)return{updated:0,failed:0};if(r==="approve"&&s.length===h.length&&!n)return R();let c=0,d=0,m;for(const S of s)try{const Y=r==="approve"?await b(S,n?{note:n}:void 0):v?await v(S,n?{note:n}:void 0):{updated:0,failed:1};c+=Y.updated,d+=Y.failed,!m&&Y.firstError&&(m=Y.firstError)}catch{d+=1}return{updated:c,failed:d,firstError:m}},Se=async()=>{if(!$||M)return;const s=$.ids;if(s.length===0){f("No decisions selected for this action.");return}f(null),y(!0),F(new Set(s));const r=ue.trim();try{const n=w?await w(s,$.action,r.length>0?r:void 0):await Ie(s,$.action,r.length>0?r:void 0),c=$.action==="approve"?"Approved":"Rejected";if(n.failed>0){const d=`${c} ${n.updated}; ${n.failed} failed.`,m=Ae(n.firstError,d);f(m===d?d:`${d} ${m}`)}else n.updated>0?f(`${c} ${n.updated} decision${n.updated===1?"":"s"}.`):f("No decisions were updated.");X(new Set)}catch(n){const c=n instanceof Error?n.message:"";f(Ae(c,"Bulk decision action failed."))}finally{y(!1),F(new Set)}},xe=async s=>{if(!(P.has(s)||M)){f(null),F(r=>{const n=new Set(r);return n.add(s),n});try{const r=await b(s);r.failed>0?f(Ee("approve",r.failed,r.firstError)):r.updated>0&&f("Decision approved.")}catch(r){const n=r instanceof Error?r.message:"";f(Ae(n,"Decision approval failed."))}finally{F(r=>{const n=new Set(r);return n.delete(s),n}),X(r=>{if(!r.has(s))return r;const n=new Set(r);return n.delete(s),n})}}},he=o.useCallback(s=>{P.has(s.id)||M||(ee(r=>new Set(r).add(s.id)),de({message:`Approved '${s.title.length>40?s.title.slice(0,40)+"…":s.title}'`,onUndo:()=>{ee(r=>{const n=new Set(r);return n.delete(s.id),n})},onCommit:()=>{ee(r=>{const n=new Set(r);return n.delete(s.id),n}),b(s.id).catch(()=>{f("Approval failed. Try again from the decision panel.")})}}))},[P,M,de,b]);o.useEffect(()=>{if(!W)return;const s=window.setTimeout(()=>f(null),5200);return()=>window.clearTimeout(s)},[W]);const fe=W!==null&&!W.toLowerCase().includes("fail"),I=M||P.size>0,ne=Math.max(P.size,M?V:0),ge=I?`Applying ${ne} decision action${ne===1?"":"s"}…`:W??null,i=I?"processing":W?fe?"success":"warning":"idle",l=!_&&q.length<=32,j=$!==null&&$.ids.length>0&&!M,D=h.length;(we=h[0])==null||we.waitingMinutes;const L=$!=null&&$.id.includes("visible")?"visible":"selected",Q=($==null?void 0:$.action)??"approve",g=ge!==null||i!=="idle",be=B==="card"?Ue:"div";return e.jsxs(be,{className:oe("flex h-full min-h-0 flex-col",B==="card"&&"card-enter",O),children:[e.jsx(lt,{open:A!==null,decision:me,onClose:()=>x(null),onApprove:se,onReject:ke,onNavigate:Me,currentIndex:Z>=0?Z:void 0,totalCount:h.length}),N?e.jsxs("div",{className:"space-y-2.5 border-b border-subtle px-4 py-3.5",children:[e.jsx("div",{className:"flex items-start justify-between gap-3",children:e.jsxs("div",{className:"min-w-0",children:[e.jsxs("h2",{className:"inline-flex items-center gap-2 text-heading font-semibold text-white",children:[e.jsx(ie,{type:"decision",size:14}),"Decisions"]}),e.jsx("p",{className:"mt-0.5 text-caption text-secondary",children:D>0?`${D} decision${D===1?"":"s"} need${D===1?"s":""} your input`:"All clear — no decisions pending"})]})}),e.jsxs("div",{className:"flex flex-wrap items-center gap-2",children:[h.length>0&&e.jsx("button",{onClick:$e,disabled:I,className:"control-pill h-8 flex-shrink-0 px-3 text-caption font-semibold disabled:opacity-45",children:re?"Clear all":"Select all"}),V>0&&e.jsxs(e.Fragment,{children:[e.jsx("button",{onClick:Se,disabled:!j||I,"data-state":j?"active":"idle",className:"control-pill h-8 flex-shrink-0 px-3 text-caption font-semibold disabled:opacity-45",children:M?"Approving…":`Approve ${V} selected`}),v&&e.jsx("button",{type:"button",onClick:()=>ae(ct("reject",L)),disabled:I,"data-state":Q==="reject"?"active":"idle",className:oe("control-pill h-8 px-2.5 text-caption font-semibold disabled:opacity-45",Q==="reject"&&"border-amber-300/35 bg-amber-400/[0.12] text-amber-100"),children:"Reject"})]})]}),g?e.jsxs("div",{"aria-live":"polite",className:oe("flex min-h-[32px] items-center gap-2 rounded-lg border px-2.5 py-1.5 text-caption transition-colors",i==="processing"?"border-amber-300/25 bg-amber-400/[0.08] text-amber-100":i==="success"?"border-lime/30 bg-lime/10 text-lime":i==="warning"?"border-red-400/25 bg-red-500/[0.08] text-red-100":"border-strong bg-white/[0.02] text-secondary"),children:[i==="processing"?e.jsx("span",{"aria-hidden":!0,className:"h-3.5 w-3.5 rounded-full border-2 border-amber-200/45 border-t-transparent animate-spin"}):i==="success"?e.jsx(ie,{type:"decision",size:12,className:"opacity-90"}):i==="warning"?e.jsxs("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",className:"opacity-90",children:[e.jsx("path",{d:"m21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3Z"}),e.jsx("line",{x1:"12",x2:"12",y1:"9",y2:"13"}),e.jsx("line",{x1:"12",x2:"12.01",y1:"17",y2:"17"})]}):e.jsx("span",{"aria-hidden":!0,className:"h-1.5 w-1.5 rounded-full bg-white/35"}),e.jsx("span",{className:"min-w-0 truncate",children:ge})]}):null]}):null,e.jsxs("div",{className:oe("min-h-0 flex-1 space-y-2 overflow-y-auto",N?"p-3":"p-0"),children:[h.length===0&&e.jsx("div",{className:"flex flex-col items-center gap-2.5 rounded-xl border border-subtle bg-white/[0.02] p-4 text-center",children:I?e.jsxs(e.Fragment,{children:[e.jsx("span",{"aria-hidden":!0,className:"h-5 w-5 rounded-full border-2 border-amber-200/45 border-t-transparent animate-spin"}),e.jsx("p",{className:"text-body text-secondary",children:"Finalizing decision updates…"})]}):e.jsxs(e.Fragment,{children:[e.jsxs("svg",{width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round",className:"text-faint",children:[e.jsx("path",{d:"M22 11.08V12a10 10 0 1 1-5.93-9.14"}),e.jsx("polyline",{points:"22 4 12 14.01 9 11.01"})]}),e.jsx("p",{className:"text-body text-secondary",children:"No pending decisions. All clear."})]})}),l?e.jsx(Re,{mode:"popLayout",children:U.map(s=>e.jsxs("div",{children:[U.length>1&&e.jsx(We,{group:s}),s.decisions.map((r,n)=>{const c=P.has(r.id),d=C.has(r.id),m=_e(r.waitingMinutes);return e.jsx(ce.article,{role:"button",tabIndex:0,onClick:()=>x(r.id),onKeyDown:S=>{(S.key==="Enter"||S.key===" ")&&(S.preventDefault(),x(r.id))},drag:!I&&!c?"x":!1,dragConstraints:{left:0,right:0},dragElastic:.3,onDragEnd:(S,Y)=>{Y.offset.x>120&&he(r)},initial:M?{opacity:0,x:300}:{opacity:0,y:8,scale:.98},animate:{opacity:1,y:0,x:0,scale:1},exit:{opacity:0,x:300,scale:.95},transition:{duration:.25,ease:[.22,1,.36,1],...M?{delay:n*.04}:{}},layout:!0,className:"mt-1.5 rounded-xl border bg-white/[0.03] px-3 py-2.5 transition-[border-color,box-shadow] cv-auto",style:{borderColor:d?`${T.lime}50`:"rgba(255, 255, 255, 0.1)",boxShadow:d?"0 0 0 1px rgba(191, 255, 0, 0.14)":"none"},children:e.jsxs("div",{className:"flex items-start gap-2.5",children:[e.jsx("input",{type:"checkbox",checked:d,onChange:()=>Ne(r.id),disabled:c||I,onClick:S=>S.stopPropagation(),className:"mt-0.5 h-4 w-4 rounded border-white/20 bg-black/40 text-lime focus:ring-lime/40"}),e.jsx("div",{className:"min-w-0 flex-1",children:e.jsxs("div",{className:"min-w-0",children:[e.jsxs("div",{className:"flex min-w-0 items-start gap-1.5",children:[m!=="normal"&&e.jsx("span",{"aria-label":m==="overdue"?"Overdue":"Urgent",className:oe("mt-[5px] h-2 w-2 flex-shrink-0 rounded-full",m==="overdue"?"bg-red-400":"bg-amber-400")}),e.jsxs("p",{className:"flex min-w-0 items-start gap-1.5 text-body font-medium text-white",title:r.title,children:[e.jsx(ie,{type:"decision",size:12,className:"mt-[3px] flex-shrink-0 opacity-90"}),e.jsx("span",{className:"line-clamp-2",children:r.title})]})]}),r.context&&e.jsx("p",{className:"mt-1 line-clamp-2 text-caption text-secondary",title:r.context,children:r.context}),e.jsxs("div",{className:"mt-1.5 flex items-center justify-between gap-2",children:[e.jsxs("p",{className:`min-w-0 truncate text-micro ${(()=>{const S=H(r.waitingMinutes);return S.tone==="urgent"?"text-red-400":S.tone==="attention"?"text-amber-400":"text-muted"})()}`,title:`${r.agentName??"OrgX Autopilot"} · ${H(r.waitingMinutes).text}`,children:[r.agentName??"OrgX Autopilot"," · ",H(r.waitingMinutes).text]}),e.jsx("button",{onClick:S=>{S.stopPropagation(),xe(r.id)},disabled:c||I,className:"flex-shrink-0 rounded-md border border-lime/25 bg-lime/10 px-2.5 py-1 text-micro font-semibold text-lime transition-colors hover:bg-lime/20 disabled:cursor-not-allowed disabled:border-white/10 disabled:bg-white/[0.08] disabled:text-secondary",children:c?"Approving…":"Approve"}),v&&e.jsx("button",{onClick:S=>{S.stopPropagation(),x(r.id)},disabled:c||I,className:"flex-shrink-0 rounded-md border border-white/[0.08] bg-white/[0.03] px-2.5 py-1 text-micro font-semibold text-secondary transition-colors hover:border-red-400/30 hover:bg-red-400/[0.08] hover:text-red-300 disabled:cursor-not-allowed disabled:opacity-40",children:"Reject"})]})]})})]})},r.id)})]},s.initiativeId))}):e.jsx(e.Fragment,{children:U.map(s=>e.jsxs("div",{children:[U.length>1&&e.jsx(We,{group:s}),s.decisions.map(r=>{const n=P.has(r.id),c=C.has(r.id),d=_e(r.waitingMinutes);return e.jsx("article",{role:"button",tabIndex:0,onClick:()=>x(r.id),onKeyDown:m=>{(m.key==="Enter"||m.key===" ")&&(m.preventDefault(),x(r.id))},className:"mt-1.5 rounded-xl border bg-white/[0.03] px-3 py-2.5 transition-[border-color,box-shadow] cv-auto",style:{borderColor:c?`${T.lime}50`:"rgba(255, 255, 255, 0.1)",boxShadow:c?"0 0 0 1px rgba(191, 255, 0, 0.14)":"none"},children:e.jsxs("div",{className:"flex items-start gap-2.5",children:[e.jsx("input",{type:"checkbox",checked:c,onChange:()=>Ne(r.id),disabled:n||I,onClick:m=>m.stopPropagation(),className:"mt-0.5 h-4 w-4 rounded border-white/20 bg-black/40 text-lime focus:ring-lime/40"}),e.jsx("div",{className:"min-w-0 flex-1",children:e.jsxs("div",{className:"min-w-0",children:[e.jsxs("div",{className:"flex min-w-0 items-start gap-1.5",children:[d!=="normal"&&e.jsx("span",{"aria-label":d==="overdue"?"Overdue":"Urgent",className:oe("mt-[5px] h-2 w-2 flex-shrink-0 rounded-full",d==="overdue"?"bg-red-400":"bg-amber-400")}),e.jsxs("p",{className:"flex min-w-0 items-start gap-1.5 text-body font-medium text-white",title:r.title,children:[e.jsx(ie,{type:"decision",size:12,className:"mt-[3px] flex-shrink-0 opacity-90"}),e.jsx("span",{className:"line-clamp-2",children:r.title})]})]}),r.context&&e.jsx("p",{className:"mt-1 line-clamp-2 text-caption text-secondary",title:r.context,children:r.context}),e.jsxs("div",{className:"mt-1.5 flex items-center justify-between gap-2",children:[e.jsxs("p",{className:`min-w-0 truncate text-micro ${(()=>{const m=H(r.waitingMinutes);return m.tone==="urgent"?"text-red-400":m.tone==="attention"?"text-amber-400":"text-muted"})()}`,title:`${r.agentName??"OrgX Autopilot"} · ${H(r.waitingMinutes).text}`,children:[r.agentName??"OrgX Autopilot"," · ",H(r.waitingMinutes).text]}),e.jsx("button",{onClick:m=>{m.stopPropagation(),xe(r.id)},disabled:n||I,className:"flex-shrink-0 rounded-md border border-lime/25 bg-lime/10 px-2.5 py-1 text-micro font-semibold text-lime transition-colors hover:bg-lime/20 disabled:cursor-not-allowed disabled:border-white/10 disabled:bg-white/[0.08] disabled:text-secondary",children:n?"Approving…":"Approve"}),v&&e.jsx("button",{onClick:m=>{m.stopPropagation(),x(r.id)},disabled:n||I,className:"flex-shrink-0 rounded-md border border-white/[0.08] bg-white/[0.03] px-2.5 py-1 text-micro font-semibold text-secondary transition-colors hover:border-red-400/30 hover:bg-red-400/[0.08] hover:text-red-300 disabled:cursor-not-allowed disabled:opacity-40",children:"Reject"})]})]})})]})},r.id)})]},s.initiativeId))}),q.length<h.length&&e.jsxs("button",{onClick:()=>le(s=>Math.min(h.length,s+Te)),className:"w-full rounded-xl border border-white/[0.08] bg-white/[0.02] px-3 py-2 text-caption text-secondary transition-colors hover:bg-white/[0.05]",children:["Load more (",h.length-q.length," remaining)"]})]}),e.jsx(je,{})]})});export{wt as DecisionQueue};
|
|
1
|
+
import{r as o,j as e}from"./Dj2k1r16.js";import{E as ie,e as T,y as qe,a0 as H,v as De,a1 as Be,a2 as Oe,M as ze,h as Le,P as Ue,B as oe}from"./C8AYbjlq.js";import{E as Ge}from"./DBRLnKWw.js";import{A as Re,m as ce,u as Ke}from"./eeHXe_OQ.js";import{u as Xe}from"./D8mvKY2h.js";import"./DMKyYAtD.js";import"./cX2e-TLi.js";import"./BjK42gtU.js";import"./BV0BcV1u.js";const Je={pr:"⎋",file:"◇",artifact:"▪",log:"▸",decision:"◈"};function Ve(a){return a>=.8?"#BFFF00":a>=.5?"#F5B700":"#FF6B88"}function Ze(a){const t=a.match(/https?:\/\/\S+/);return t?t[0]:null}function Qe({evidenceType:a,title:t,summary:u,sourceUrl:p,confidence:b,payload:v,icon:R,label:w,onOpenTerminal:k}){const[N,B]=o.useState(!1),O=t??w??null,E=a??(R?R.toUpperCase():null),_=R?Je[R]:null,M=R==="pr"&&w?Ze(w):null;return e.jsxs("div",{className:"rounded-xl border border-white/[0.06] bg-white/[0.02] px-3 py-2.5",children:[e.jsxs("div",{className:"flex items-start gap-2.5 cursor-pointer",onClick:()=>B(y=>!y),children:[(E||_)&&e.jsxs("span",{className:"mt-0.5 flex-shrink-0 rounded bg-white/[0.06] px-1.5 py-0.5 text-[10px] font-semibold uppercase tracking-wider text-secondary",children:[_?e.jsx("span",{className:"mr-1",children:_}):null,E]}),e.jsxs("div",{className:"min-w-0 flex-1",children:[O&&e.jsx("p",{className:"text-body font-medium text-primary",children:p?e.jsx("a",{href:p,target:"_blank",rel:"noopener noreferrer",className:"text-[#D8FFA1] hover:underline",onClick:y=>y.stopPropagation(),children:O}):M?e.jsx("a",{href:M,target:"_blank",rel:"noopener noreferrer",className:"text-[#D8FFA1] hover:underline",onClick:y=>y.stopPropagation(),children:O}):O}),u&&e.jsx("p",{className:`mt-0.5 text-caption text-secondary ${N?"":"line-clamp-2"}`,children:u})]}),e.jsx("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",className:`mt-1 flex-shrink-0 text-muted transition-transform ${N?"rotate-180":""}`,children:e.jsx("path",{d:"m6 9 6 6 6-6"})})]}),b!=null&&e.jsxs("div",{className:"mt-2 flex items-center gap-2",children:[e.jsx("div",{className:"h-1 flex-1 overflow-hidden rounded-full bg-white/[0.06]",children:e.jsx("div",{className:"h-full rounded-full transition-all",style:{width:`${Math.round(b*100)}%`,backgroundColor:Ve(b)}})}),e.jsxs("span",{className:"text-micro text-muted tabular-nums",children:[Math.round(b*100),"%"]})]}),e.jsx(Re,{children:N&&e.jsx(ce.div,{initial:{height:0,opacity:0},animate:{height:"auto",opacity:1},exit:{height:0,opacity:0},transition:{duration:.2},className:"overflow-hidden",children:e.jsxs("div",{className:"mt-2 space-y-2",children:[R==="log"&&k&&e.jsxs("button",{type:"button",onClick:y=>{y.stopPropagation(),k()},className:"inline-flex items-center gap-1.5 rounded-lg border border-white/[0.12] bg-white/[0.04] px-3 py-1.5 text-caption font-semibold text-primary transition-colors hover:bg-white/[0.08]",children:[e.jsx("span",{className:"font-mono text-micro",children:">_"}),"Open in terminal"]}),v&&Object.keys(v).length>0&&e.jsx("pre",{className:"max-h-40 overflow-auto rounded-lg bg-black/40 p-2.5 text-micro text-secondary font-mono",children:JSON.stringify(v,null,2)})]})})})]})}function Ye({segments:a}){return a.length===0?null:e.jsx("nav",{className:"flex items-center gap-1.5 min-w-0 text-caption text-secondary",children:a.map((t,u)=>e.jsxs("span",{className:"flex items-center gap-1.5 min-w-0",children:[u>0&&e.jsx("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",className:"flex-shrink-0 text-faint",children:e.jsx("path",{d:"m9 18 6-6-6-6"})}),t.icon&&e.jsx(ie,{type:t.icon,size:11,className:"flex-shrink-0 opacity-80"}),t.onClick?e.jsx("button",{type:"button",onClick:t.onClick,className:"truncate transition-colors hover:text-primary",children:t.label}):e.jsx("span",{className:"truncate",children:t.label})]},u))})}const ye={label:"Retry this workstream",description:"Re-run with the same configuration. Recommended if this was a transient issue.",impliedStatus:"approved"},K={label:"Skip and continue",description:"Mark as accepted and move to the next workstream.",impliedStatus:"approved"},He=[{test:/Worker exited without structured output.*?code=(\S+?),\s*signal=(\S+?)\)/i,headline:"Agent work stopped unexpectedly",explain:(a,t)=>{const u=t[1]==="null"?"none":t[1],p=t[2]==="null"?"none":t[2];return`The agent process exited before producing results. Exit code: ${u}. Signal: ${p}. This usually means the worker was terminated externally or ran out of resources.`},severity:"critical",options:[ye,{label:"Retry with more resources",description:"Increase token budget before re-running.",impliedStatus:"approved"},K],extractDetails:(a,t)=>({exitCode:t[1]==="null"?void 0:t[1],signal:t[2]==="null"?void 0:t[2]})},{test:/MCP handshake failed(?:\s+for\s+(\S+))?/i,headline:"Agent couldn't connect to tools",explain:(a,t)=>`The agent failed to connect to its tool server${t[1]?` (${t[1]})`:""}. This typically means the MCP server is unreachable or took too long to respond.`,severity:"critical",options:[ye,{label:"Check MCP server",description:"Investigate the tool server connection before retrying.",impliedStatus:"approved"},K],extractDetails:(a,t)=>({server:t[1]||void 0})},{test:/(?:Slice|Autopilot slice) timed out after (\d+)/i,headline:"Agent ran out of time",explain:(a,t)=>{const u=Math.round(parseInt(t[1],10)/6e4);return`The agent exceeded its ${u>0?`${u}-minute`:`${t[1]}ms`} time limit. Consider breaking the work into smaller steps or increasing the time budget.`},severity:"warning",options:[{label:"Retry with more time",description:"Increase the timeout before re-running.",impliedStatus:"approved"},{label:"Break into smaller tasks",description:"Split the workstream into smaller pieces that fit the time budget.",impliedStatus:"approved"},K],extractDetails:(a,t)=>({elapsedMs:t[1]})},{test:/(?:Slice|Autopilot slice) stalled/i,headline:"Agent stopped making progress",explain:()=>"The agent stopped producing output. It may be stuck in a loop, waiting on an unresponsive resource, or unable to proceed with the current approach.",severity:"warning",options:[ye,{label:"Review logs",description:"Check the session logs to understand why the agent stalled.",impliedStatus:"approved"},K]},{test:/blocked.*?(?:needs|requires?) intervention/i,headline:"Agent needs your help to continue",explain:()=>"The agent reached a point where it cannot proceed without human guidance. This may be a question about requirements, a permission needed, or an ambiguity.",severity:"warning",options:[{label:"Review blocker",description:"Look at what the agent needs and provide guidance.",impliedStatus:"approved"},{label:"Provide guidance",description:"Add a note with instructions for the agent.",impliedStatus:"approved"},K]},{test:/completed.*?(?:without|no) (?:verifiable )?(?:outcomes?|artifacts?)/i,headline:"Agent finished but produced no outputs",explain:()=>"The agent reported completion but produced no artifacts or status updates. The work may have been done informally, or the agent could not find actionable work.",severity:"info",options:[{label:"Accept as-is",description:"The work was done informally or no output was needed.",impliedStatus:"approved"},{label:"Retry with stronger output requirements",description:"Re-run and require the agent to produce structured artifacts.",impliedStatus:"approved"},K]},{test:/Spawn guard denied/i,headline:"Agent dispatch was blocked by safety check",explain:()=>"The system's safety checks prevented this agent from starting. This is typically due to capacity limits or quality gate requirements.",severity:"warning",options:[{label:"Approve exception",description:"Override the safety check and allow dispatch.",impliedStatus:"approved"},{label:"Investigate quality gate",description:"Review what safety check failed before proceeding.",impliedStatus:"approved"},K]},{test:/code=(\d+)/i,headline:"Agent encountered an error",explain:(a,t)=>`The agent process exited with error code ${t[1]}. Reviewing the session logs will show what operation failed.`,severity:"critical",options:[ye,{label:"Review error logs",description:"Check session logs to understand the error before retrying.",impliedStatus:"approved"},K],extractDetails:(a,t)=>({exitCode:t[1]})}];function et(a){var u;const t=a.context||a.title||"";for(const p of He){const b=t.match(p.test);if(b)return{headline:p.headline,explanation:p.explain(t,b),structuredDetails:((u=p.extractDetails)==null?void 0:u.call(p,t,b))??{},suggestedOptions:p.options,severity:p.severity}}return a.decisionType==="autopilot_failure"?{headline:"Agent work needs attention",explanation:t||"An issue occurred during autopilot execution that requires review.",structuredDetails:{},suggestedOptions:[ye,K],severity:"warning"}:{headline:a.title||"Decision needed",explanation:t||"Review the details and choose an action.",structuredDetails:{},suggestedOptions:[],severity:"info"}}function tt(a){return a.map((t,u)=>({id:`suggested-${u}`,label:t.label,description:t.description,impliedStatus:t.impliedStatus,actionType:null,requiresNote:!1}))}function rt(a,t){var w;if(!t||!a.workstreamId||!t.nodes.find(k=>k.id===a.workstreamId&&k.entityType==="workstream"))return null;const p=new Set(t.edges.filter(k=>k.source===a.workstreamId).map(k=>k.target)),b=[];for(const k of p){const N=t.nodes.find(B=>B.id===k);N&&b.push({id:N.id,title:N.title,taskCount:((w=N.children)==null?void 0:w.length)??0,status:N.status})}if(b.length===0)return null;const v=b.reduce((k,N)=>k+N.taskCount,0),R=b.some(k=>t.edges.some(N=>N.source===k.id));return{blockedWorkstreams:b,totalBlockedTasks:v,criticalPath:R}}function st(a){const t=a.blockedWorkstreams.length,u=a.blockedWorkstreams.map(p=>p.title);return t===1?`Resolving this unblocks 1 downstream workstream: ${u[0]}.`:t<=3?`Resolving this unblocks ${t} downstream workstreams: ${u.join(", ")}.`:`Resolving this unblocks ${t} downstream workstreams including ${u[0]} and ${u[1]}.`}const Pe=typeof navigator<"u"&&/Mac|iPhone|iPad/.test(navigator.userAgent);function nt(a){try{return JSON.stringify(a,null,2)}catch{return null}}function Fe(a){if(typeof a!="string")return null;const t=a.trim().toLowerCase();return t==="rejected"?"declined":t==="approved"||t==="declined"||t==="cancelled"?t:null}function Ce(a,t){return!a||a.trim().length===0?t:Le(a.trim())||t}function it(a){switch(a){case"spawn_guard_blocked":return"Spawn Guard";case"autopilot_failure":return"Autopilot Failure";case"budget_exceeded":return"Budget Exceeded";case"scope_change":return"Scope Change";case"conflict_resolution":return"Conflict Resolution";case"approval_required":return"Approval Required";case"review_required":return"Review Required";case"permission_request":return"Permission Request";default:return a.replace(/[_-]/g," ").replace(/\b\w/g,t=>t.toUpperCase())}}function at(a){const t=a.toLowerCase();return t==="critical"||t==="p0"?T.red:t==="high"||t==="p1"?T.amber:t==="medium"||t==="p2"?T.iris:"rgba(255,255,255,0.5)"}function lt({open:a,decision:t,onClose:u,onApprove:p,onReject:b,initiativeTitle:v,workstreamTitle:R,onNavigate:w,currentIndex:k,totalCount:N,onFocusRunId:B,graph:O}){const[E,_]=o.useState("idle"),[M,y]=o.useState(null),[P,F]=o.useState(null),[C,X]=o.useState(""),[ve,ee]=o.useState(!1),[de,je]=o.useState(!1),J=o.useRef(null),ae=o.useRef(),ue=o.useRef(u);ue.current=u,o.useEffect(()=>{if(a){_("idle"),y(null);const i=(t==null?void 0:t.selectedOptionId)??(t!=null&&t.options&&t.options.length===1?t.options[0].id:null);F(i),X(""),ee(!1),je(!1)}return()=>{ae.current&&clearTimeout(ae.current)}},[a,t==null?void 0:t.id]);const z=t==null?void 0:t.metadata,W=o.useMemo(()=>{if(!z)return[];const i=z,l=i.decision_options??i.options??i.actions??null;if(!Array.isArray(l))return[];const j=[],D=new Set;for(let L=0;L<l.length;L+=1){const Q=l[L];if(typeof Q=="string"){const s=Q.trim();if(!s)continue;const r=`option-${L+1}`;if(D.has(r))continue;D.add(r),j.push({id:r,label:s,description:null,impliedStatus:null,actionType:null,requiresNote:!1});continue}if(!Q||typeof Q!="object")continue;const g=Q,be=typeof g.id=="string"&&g.id.trim()||typeof g.option_id=="string"&&g.option_id.trim()||typeof g.action_id=="string"&&g.action_id.trim()||`option-${L+1}`;if(D.has(be))continue;const we=typeof g.label=="string"&&g.label.trim()||typeof g.title=="string"&&g.title.trim()||typeof g.name=="string"&&g.name.trim()||typeof g.action=="string"&&g.action.trim()||null;we&&(D.add(be),j.push({id:be,label:we,description:typeof g.description=="string"?g.description:null,impliedStatus:Fe(g.implied_status)??Fe(g.status),actionType:typeof g.action_type=="string"&&g.action_type||typeof g.type=="string"&&g.type||null,requiresNote:g.requires_note===!0||g.requiresNote===!0||g.note_required===!0}))}return j.slice(0,12)},[z]),f=o.useMemo(()=>t?et(t):null,[t==null?void 0:t.context,t==null?void 0:t.title,t==null?void 0:t.decisionType]),te=o.useMemo(()=>t?rt(t,O??null):null,[t==null?void 0:t.workstreamId,t==null?void 0:t.initiativeId,O]),le=((t==null?void 0:t.waitingMinutes)??0)>1440,A=o.useMemo(()=>t!=null&&t.options&&t.options.length>0?t.options:W.length>0?W:f&&f.suggestedOptions.length>0?tt(f.suggestedOptions):[],[t==null?void 0:t.options,W,f]),x=o.useMemo(()=>A.find(i=>i.id===P)??null,[A,P]),pe=(x==null?void 0:x.requiresNote)===!0,h=o.useMemo(()=>{const i=((t==null?void 0:t.context)??"").trim();if(i)return i;if(!z)return"";const l=z,j=(typeof l.summary=="string"?l.summary:null)??(typeof l.description=="string"?l.description:null)??"";return String(j??"").trim()},[t==null?void 0:t.context,z]),V=o.useMemo(()=>{const i=(t==null?void 0:t.waitingMinutes)??0;return i>=15?T.red:i>=5?T.amber:T.teal},[t==null?void 0:t.waitingMinutes]),q=o.useCallback(async()=>{if(!t)return;const i=nt({decision:t,metadata:z});if(i)try{await navigator.clipboard.writeText(i),ee(!0),setTimeout(()=>ee(!1),2e3)}catch{}},[t,z]),U=o.useCallback(()=>{const i=C.trim(),l=x==null?void 0:x.id;if(!(!i&&!l))return{note:i.length>0?i:void 0,optionId:l??void 0}},[C,x]),re=o.useCallback(async()=>{if(!t||!p)return;if(A.length>0&&!x){y("Select an option before approving this decision.");return}if(x!=null&&x.requiresNote&&C.trim().length===0){y("A note is required for the selected option."),requestAnimationFrame(()=>{var l;return(l=J.current)==null?void 0:l.focus()});return}let i=!1;if(_(l=>l==="approving"||l==="rejecting"?l:(i=!0,"approving")),!!i){y(null);try{const l=await p(t.id,U());l.failed>0?(_("error"),y(Ce(l.firstError,"Approval failed. Please try again."))):(_("success"),ae.current=setTimeout(()=>ue.current(),800))}catch(l){_("error");const j=l instanceof Error?l.message:"";y(Ce(j,"Approval failed."))}}},[U,t,C,p,A.length,x]),me=o.useCallback(async()=>{if(!t||!b)return;if(A.length>0&&!x){y("Select an option before rejecting this decision.");return}if(x!=null&&x.requiresNote&&C.trim().length===0){y("A note is required for the selected option."),requestAnimationFrame(()=>{var l;return(l=J.current)==null?void 0:l.focus()});return}let i=!1;if(_(l=>l==="approving"||l==="rejecting"?l:(i=!0,"rejecting")),!!i){y(null);try{const l=await b(t.id,U());l.failed>0?(_("error"),y(Ce(l.firstError,"Rejection failed. Please try again."))):(_("rejected"),ae.current=setTimeout(()=>ue.current(),800))}catch(l){_("error");const j=l instanceof Error?l.message:"";y(Ce(j,"Rejection failed."))}}},[U,t,C,b,A.length,x]);if(o.useEffect(()=>{if(!a)return;const i=l=>{var D,L;if((l.metaKey||l.ctrlKey)&&l.key==="Enter"){l.preventDefault(),re();return}const j=(D=l.target)==null?void 0:D.tagName;if(!(j==="INPUT"||j==="TEXTAREA"))switch(l.key){case"j":l.preventDefault(),w==null||w(1);break;case"k":l.preventDefault(),w==null||w(-1);break;case"a":l.preventDefault(),re();break;case"r":l.preventDefault(),me();break;case"n":l.preventDefault(),(L=J.current)==null||L.focus();break}};return document.addEventListener("keydown",i),()=>document.removeEventListener("keydown",i)},[a,re,me,w]),!a||!t)return null;const Z=E==="approving"||E==="rejecting",Me=E==="success"||E==="rejected",se=(t.status??"pending").toLowerCase(),ke=!se.includes("approved")&&!se.includes("resolved")&&!se.includes("rejected")&&!se.includes("declined")&&!se.includes("cancelled"),Ne=A.length>0&&!x,$e=(x==null?void 0:x.requiresNote)===!0&&C.trim().length===0,G=Z||Ne||$e,$=t.evidenceRefs??[],Ie=$.length>0,Se=t.recommendedAction??null,xe=t.decisionType??null,he=t.priority??null,fe=t.occurrenceCount??null,I=t.sourceRunId??null,ne=[];v&&ne.push({label:v,icon:"initiative"}),R&&ne.push({label:R,icon:"workstream"});const ge=[["ID",t.id],["Type",t.decisionType],["Dedupe key",t.dedupeKey],["Source system",t.sourceSystem],["Conflict source",t.conflictSource],["Agent ID",t.agentId],["Source run",t.sourceRunId],["Source session",t.sourceSessionId],["Source stream",t.sourceStreamId]].filter(([,i])=>i!=null);if(Me){const i=E==="success",l=i?T.lime:T.red;return e.jsx(qe,{open:a,onClose:u,maxWidth:"max-w-xl",fitContent:!0,children:e.jsxs("div",{className:"flex flex-col items-center justify-center px-8 py-12",children:[e.jsx("div",{className:"mb-4 flex h-16 w-16 items-center justify-center rounded-full",style:{backgroundColor:`${l}18`,border:`1.5px solid ${l}40`},children:i?e.jsx("svg",{width:"28",height:"28",viewBox:"0 0 24 24",fill:"none",stroke:l,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:e.jsx("polyline",{points:"20 6 9 17 4 12"})}):e.jsxs("svg",{width:"28",height:"28",viewBox:"0 0 24 24",fill:"none",stroke:l,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[e.jsx("path",{d:"M18 6L6 18"}),e.jsx("path",{d:"M6 6l12 12"})]})}),e.jsx("p",{className:"text-heading font-semibold text-white",children:i?"Approved":"Rejected"}),e.jsx("p",{className:"mt-1 text-body text-secondary",children:t.title})]})})}return e.jsx(qe,{open:a,onClose:u,maxWidth:"max-w-xl",children:e.jsxs("div",{className:"flex h-full min-h-0 w-full flex-col",style:le?{boxShadow:`inset 0 0 0 1px ${T.amber}30`,borderRadius:"inherit"}:void 0,children:[e.jsx("div",{className:"h-[2px] w-full flex-shrink-0",style:{background:`linear-gradient(90deg, ${V}60, ${V}20, transparent)`}}),w&&e.jsxs("div",{className:"flex items-center justify-between px-6 pt-3 pb-0",children:[e.jsxs("div",{className:"flex items-center gap-2",children:[e.jsx("button",{type:"button",onClick:()=>w(-1),className:"rounded p-1 text-muted hover:text-secondary hover:bg-white/[0.06] transition-colors",title:"Previous (k)",children:e.jsx("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:e.jsx("path",{d:"m15 18-6-6 6-6"})})}),e.jsx("button",{type:"button",onClick:()=>w(1),className:"rounded p-1 text-muted hover:text-secondary hover:bg-white/[0.06] transition-colors",title:"Next (j)",children:e.jsx("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:e.jsx("path",{d:"m9 18 6-6-6-6"})})}),k!=null&&N!=null&&e.jsxs("span",{className:"text-micro text-muted tabular-nums",children:[k+1," of ",N,e.jsx("span",{className:"ml-1 hidden sm:inline",children:"· Longest waiting first"})]})]}),e.jsx("button",{type:"button",onClick:u,"aria-label":"Close",className:"rounded p-1 text-muted hover:text-secondary hover:bg-white/[0.06] transition-colors",children:e.jsx("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:e.jsx("path",{d:"M18 6 6 18M6 6l12 12"})})})]}),ne.length>0&&e.jsx("div",{className:"px-6 pt-2",children:e.jsx(Ye,{segments:ne})}),e.jsxs("div",{className:"flex items-start justify-between gap-3 px-6 pt-4 pb-4",children:[e.jsx("div",{className:"min-w-0 flex-1",children:e.jsxs("div",{className:"flex items-center gap-2.5",children:[e.jsx("div",{className:"flex h-8 w-8 flex-shrink-0 items-center justify-center rounded-lg",style:{backgroundColor:`${V}14`,border:`1px solid ${V}30`},children:e.jsx(ie,{type:"decision",size:14})}),e.jsxs("div",{className:"min-w-0",children:[e.jsx("h2",{className:"text-title font-medium leading-tight text-white mb-2",children:t.title||"Decision Required"}),e.jsxs("div",{className:"flex flex-wrap items-center gap-2 text-body text-secondary",children:[e.jsx("span",{children:t.agentName||"OrgX Autopilot"}),e.jsx("span",{className:"text-white/[0.15]",children:"|"}),e.jsx("span",{className:le?"font-semibold text-red-300":"",children:H(t.waitingMinutes).text}),xe&&e.jsxs(e.Fragment,{children:[e.jsx("span",{className:"text-white/[0.15]",children:"|"}),e.jsx("span",{className:"text-primary",children:it(xe)})]}),he&&e.jsxs(e.Fragment,{children:[e.jsx("span",{className:"text-white/[0.15]",children:"|"}),e.jsx("span",{className:"font-medium",style:{color:at(he)},children:he})]})]}),fe!=null&&fe>1&&e.jsxs("p",{className:"mt-2 text-caption text-muted",children:["Seen ",fe," times",t.firstSeenAt&&e.jsxs(e.Fragment,{children:[" · first ",De(t.firstSeenAt)]}),t.lastSeenAt&&e.jsxs(e.Fragment,{children:[" · last ",De(t.lastSeenAt)]})]})]})]})}),!w&&e.jsx("button",{type:"button",onClick:u,"aria-label":"Close",className:"mt-0.5 flex h-8 w-8 flex-shrink-0 items-center justify-center rounded-lg text-muted transition-colors hover:bg-white/[0.06] hover:text-white",children:e.jsxs("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[e.jsx("path",{d:"M18 6L6 18"}),e.jsx("path",{d:"M6 6l12 12"})]})})]}),e.jsxs("div",{className:"min-h-0 flex-1 overflow-y-auto px-6 pb-4",children:[(t.initiativeId||t.workstreamId)&&e.jsx("div",{className:"mb-4",children:e.jsx(Be,{nodes:Oe({initiativeId:t.initiativeId,initiativeTitle:v,workstreamId:t.workstreamId,workstreamTitle:R,agentName:t.agentName,agentId:t.agentId}),activeId:t.workstreamId,compact:!0})}),Se&&e.jsxs("div",{className:"mb-4 rounded-xl border border-cyan-300/[0.28] bg-cyan-500/[0.12] px-4 py-3",children:[e.jsx("p",{className:"text-micro font-semibold uppercase tracking-wider text-cyan-200 mb-1",children:"Recommended"}),e.jsx("p",{className:"text-body text-cyan-100",children:Se})]}),Ie&&e.jsxs("div",{className:"mb-4",children:[e.jsx("p",{className:"mb-2 px-1 text-micro font-semibold uppercase tracking-wider text-muted",children:"Evidence"}),e.jsx("div",{className:"space-y-1.5",children:$.map((i,l)=>e.jsx(Qe,{evidenceType:i.evidenceType,title:i.title,summary:i.summary,sourceUrl:i.sourceUrl,confidence:i.confidence,payload:i.payload},l))})]}),le&&e.jsx("div",{className:"mb-4 rounded-xl border border-amber-400/[0.3] bg-amber-500/[0.08] px-4 py-3",children:e.jsxs("p",{className:"text-body text-amber-200",children:["This decision has been waiting"," ",e.jsx("span",{className:"font-semibold text-amber-100",children:H(t.waitingMinutes).text}),". Downstream work is paused."]})}),f&&f.headline!==t.title?e.jsxs("div",{className:"rounded-xl border border-white/[0.06] bg-white/[0.02] px-4 py-3",children:[e.jsx("p",{className:"text-micro font-semibold uppercase tracking-wider text-muted mb-2",children:"What happened"}),e.jsx("p",{className:"text-body text-primary leading-relaxed",children:f.explanation}),Object.keys(f.structuredDetails).length>0&&e.jsx("div",{className:"mt-3 flex flex-wrap gap-x-4 gap-y-1 text-caption text-secondary",children:Object.entries(f.structuredDetails).filter(([,i])=>i!=null).map(([i,l])=>e.jsxs("span",{children:[i.replace(/([A-Z])/g," $1").replace(/^./,j=>j.toUpperCase()),": ",l]},i))})]}):h?e.jsx("div",{className:"rounded-xl border border-white/[0.06] bg-white/[0.02] px-4 py-3",children:e.jsx(ze,{text:h,mode:"block"})}):e.jsx("p",{className:"px-1 text-body text-muted italic",children:"No additional context provided."}),A.length>0&&e.jsxs("div",{className:"mt-8",children:[e.jsx("p",{className:"mb-3 px-1 text-[11px] font-semibold uppercase tracking-widest text-muted",children:"Options"}),e.jsx("div",{className:"space-y-1 relative",children:A.map(i=>{const l=P===i.id;return e.jsxs("button",{type:"button",onClick:()=>{F(l?null:i.id),i.requiresNote&&requestAnimationFrame(()=>{var j;return(j=J.current)==null?void 0:j.focus()})},disabled:Z,className:"group relative flex w-full items-start gap-4 px-4 py-4 text-left focus:outline-none",children:[l&&e.jsx(ce.div,{layoutId:"decision-option-bg",className:"absolute inset-0 rounded-xl",style:{backgroundColor:`${T.lime}12`},transition:{type:"spring",stiffness:400,damping:25}}),!l&&e.jsx("div",{className:"absolute inset-0 rounded-xl opacity-0 transition-opacity group-hover:bg-white/[0.03]"}),e.jsx("div",{className:"relative mt-0.5 flex h-5 w-5 flex-shrink-0 items-center justify-center rounded-full border-[1.5px] transition-colors",style:{borderColor:l?T.lime:"rgba(255,255,255,0.2)"},children:e.jsx(Re,{children:l&&e.jsx(ce.div,{initial:{scale:0},animate:{scale:1},exit:{scale:0},transition:{type:"spring",stiffness:500,damping:30},className:"h-2.5 w-2.5 rounded-full",style:{backgroundColor:T.lime}})})}),e.jsxs("div",{className:"relative min-w-0 flex-1",children:[e.jsx("span",{className:`block text-[15px] ${l?"font-medium text-white":"text-primary"}`,children:i.label}),i.description&&e.jsx("p",{className:"mt-1 text-[13px] leading-relaxed text-secondary",children:i.description}),i.requiresNote&&e.jsx("p",{className:"mt-1.5 text-[11px] font-medium uppercase tracking-wider text-amber-400",children:"Note required"})]})]},i.id)})})]}),ke&&pe&&e.jsxs("div",{className:"mt-4",children:[e.jsx("textarea",{ref:J,value:C,onChange:i=>X(i.target.value),disabled:Z,placeholder:"Required: add context for this decision...",rows:3,className:"w-full resize-none rounded-xl border border-white/[0.08] bg-white/[0.03] px-4 py-3 text-body text-primary placeholder-white/30 outline-none transition-colors focus:border-white/[0.16] focus:bg-white/[0.04]"}),C.trim().length===0&&e.jsx("p",{className:"mt-2 text-caption text-amber-300",children:"This option requires a note before submission."})]}),te&&e.jsxs("div",{className:"mt-6 rounded-xl border border-white/[0.06] bg-white/[0.02] px-4 py-3",children:[e.jsx("p",{className:"text-micro font-semibold uppercase tracking-wider text-muted mb-2",children:"Impact"}),e.jsx("p",{className:"text-body text-primary leading-relaxed",children:st(te)}),te.blockedWorkstreams.length>0&&e.jsx("ul",{className:"mt-2 space-y-1 text-caption text-secondary",children:te.blockedWorkstreams.map(i=>e.jsxs("li",{className:"flex items-center gap-2",children:[e.jsx("span",{className:"inline-block h-1 w-1 rounded-full bg-amber-400 flex-shrink-0"}),i.title,i.status==="blocked"&&e.jsx("span",{className:"text-amber-400 text-micro",children:"(blocked)"})]},i.id))})]}),I&&B&&e.jsx("div",{className:"mt-4",children:e.jsxs("button",{type:"button",onClick:()=>B(I),className:"inline-flex items-center gap-1.5 text-caption text-[#D8FFA1] transition-colors hover:text-white",children:[e.jsx(ie,{type:"session",size:12}),"View source run"]})}),e.jsx("div",{className:"mt-4 border-t border-white/[0.06] pt-4",children:e.jsx(Ge,{entityType:"decision",entityId:t.id})}),ge.length>0&&e.jsxs("div",{className:"mt-4 border-t border-white/[0.06] pt-2",children:[e.jsxs("button",{type:"button",onClick:()=>je(i=>!i),className:"flex w-full items-center justify-between text-micro font-semibold uppercase tracking-wider text-muted hover:text-secondary transition-colors",children:[e.jsx("span",{children:"Technical details"}),e.jsx("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",className:`transition-transform ${de?"rotate-180":""}`,children:e.jsx("path",{d:"m6 9 6 6 6-6"})})]}),de&&e.jsx("div",{className:"mt-2 space-y-0.5",children:ge.map(([i,l])=>e.jsxs("div",{className:"flex gap-2 text-micro",children:[e.jsx("span",{className:"text-muted w-28 flex-shrink-0",children:i}),e.jsx("span",{className:"text-secondary truncate",children:l})]},i))})]}),e.jsxs("div",{className:"mt-4 flex flex-wrap gap-x-3 gap-y-1 text-micro text-muted opacity-60",children:[w&&e.jsx("span",{children:"j/k nav"}),e.jsx("span",{children:"a approve"}),e.jsx("span",{children:"r reject"}),e.jsx("span",{children:"n note"}),e.jsxs("span",{children:[Pe?"⌘":"Ctrl","+Enter approve"]}),e.jsx("span",{children:"esc close"})]})]}),M&&e.jsxs("div",{className:"flex items-center gap-2 border-t border-white/[0.06] px-6 py-3",children:[e.jsxs("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"none",stroke:T.red,strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[e.jsx("circle",{cx:"12",cy:"12",r:"10"}),e.jsx("line",{x1:"12",x2:"12",y1:"8",y2:"12"}),e.jsx("line",{x1:"12",x2:"12.01",y1:"16",y2:"16"})]}),e.jsx("p",{className:"text-caption text-red-300",children:M})]}),ke&&e.jsx("div",{className:"relative mt-auto border-t border-white/[0.04] bg-black/60 px-6 py-5 backdrop-blur-xl",children:e.jsxs("div",{className:"flex items-center justify-between",children:[e.jsxs("div",{className:"flex items-center gap-3",children:[b&&e.jsx(ce.button,{whileTap:{scale:.97},type:"button",onClick:me,disabled:G,className:"rounded-lg px-4 py-2 text-[14px] font-medium text-secondary transition-colors hover:text-red-400 disabled:opacity-40 focus:outline-none",children:E==="rejecting"?e.jsxs("span",{className:"flex items-center gap-2",children:[e.jsx("span",{className:"inline-block h-3 w-3 animate-spin rounded-full border-[1.5px] border-current border-t-transparent"}),"Rejecting"]}):"Reject"}),e.jsx("button",{type:"button",onClick:q,className:"rounded-lg px-2 py-2 text-[13px] text-muted transition-colors hover:text-secondary focus:outline-none",title:"Copy decision as JSON",children:ve?"Copied":"Copy JSON"})]}),e.jsxs("div",{className:"flex items-center gap-4",children:[e.jsxs("span",{className:"hidden text-[13px] text-muted sm:block",children:[Pe?"⌘":"Ctrl","+Enter"]}),e.jsx(ce.button,{whileTap:!p||G?void 0:{scale:.97},type:"button",onClick:re,disabled:!p||G,"data-modal-autofocus":"true",className:"rounded-lg px-6 py-2.5 text-[14px] font-semibold transition-all focus:outline-none",style:{backgroundColor:!p||G?"rgba(255,255,255,0.06)":T.lime,color:!p||G?"rgba(255,255,255,0.4)":"#000"},children:E==="approving"?e.jsxs("span",{className:"flex items-center gap-2",children:[e.jsx("span",{className:"inline-block h-3 w-3 animate-spin rounded-full border-[1.5px] border-black/40 border-t-black"}),"Approving"]}):"Approve"})]})]})})]})})}const Te=40;function Ae(a,t){return!a||a.trim().length===0?t:Le(a.trim())||t}function Ee(a,t,u){const p=a==="approve"?`Approval failed for ${t} decision${t===1?"":"s"}.`:`Rejection failed for ${t} decision${t===1?"":"s"}.`;return Ae(u,p)}function _e(a){return a>=1440?"overdue":a>=60?"urgent":"normal"}function ot(a){return a.length>=32?a.slice(0,8):a}function We({group:a}){const t=_e(a.worstWaitingMinutes),u=a.decisions.length;return e.jsxs("div",{className:"flex items-center gap-2 px-1 pb-1 pt-2.5 first:pt-0",children:[e.jsx("span",{className:"text-caption font-semibold text-white/70 truncate",children:a.label}),e.jsxs("span",{className:"text-micro text-muted whitespace-nowrap",children:["(",u," decision",u===1?"":"s",")"]}),t==="overdue"&&e.jsxs("span",{className:"inline-flex items-center gap-1 rounded-full bg-red-500/[0.12] px-1.5 py-0.5 text-micro font-medium text-red-400",children:[e.jsx("span",{"aria-hidden":!0,className:"h-1.5 w-1.5 rounded-full bg-red-400"}),"overdue"]}),t==="urgent"&&e.jsxs("span",{className:"inline-flex items-center gap-1 rounded-full bg-amber-400/[0.12] px-1.5 py-0.5 text-micro font-medium text-amber-400",children:[e.jsx("span",{"aria-hidden":!0,className:"h-1.5 w-1.5 rounded-full bg-amber-400"}),"urgent"]})]})}function ct(a,t){return`${a}_${t}`}const wt=o.memo(function({decisions:t,focusDecisionId:u=null,onFocusDecisionHandled:p,onApproveDecision:b,onRejectDecision:v,onApproveAll:R,onBulkDecisionAction:w,mutationState:k,showHeader:N=!0,panelStyle:B="card",className:O,initiativeNames:E}){var we;const _=Ke(),[M,y]=o.useState(!1),[P,F]=o.useState(new Set),[C,X]=o.useState(new Set),[ve,ee]=o.useState(new Set),{enqueue:de,ToastRenderer:je}=Xe(),[J,ae]=o.useState("approve_selected"),[ue,z]=o.useState(""),[W,f]=o.useState(null),[te,le]=o.useState(Te),[A,x]=o.useState(null),pe=o.useRef(null),h=o.useMemo(()=>{const s=new Set;return[...t].filter(r=>s.has(r.id)?!1:(s.add(r.id),!0)).sort((r,n)=>{if(r.waitingMinutes!==n.waitingMinutes)return n.waitingMinutes-r.waitingMinutes;const c=Date.parse(r.requestedAt??r.updatedAt??""),d=Date.parse(n.requestedAt??n.updatedAt??""),m=Number.isFinite(c)?c:0;return(Number.isFinite(d)?d:0)-m})},[t]);o.useEffect(()=>{X(s=>{const r=new Set(h.map(c=>c.id)),n=new Set;for(const c of s)r.has(c)&&n.add(c);return n})},[h]);const V=C.size,q=o.useMemo(()=>h.filter(s=>!ve.has(s.id)).slice(0,te),[h,te,ve]),U=o.useMemo(()=>{const s=new Map,r=[];for(const c of q){const d=c.initiativeId??"_unscoped";let m=s.get(d);m||(m=[],s.set(d,m),r.push(d)),m.push(c)}const n=r.map(c=>{const d=s.get(c),m=Math.max(0,...d.map(Y=>Y.waitingMinutes)),S=c==="_unscoped"?"General":(E==null?void 0:E[c])??ot(c);return{initiativeId:c,label:S,decisions:d,worstWaitingMinutes:m}});return n.sort((c,d)=>d.worstWaitingMinutes-c.worstWaitingMinutes),n},[q,E]),re=o.useMemo(()=>{if(q.length===0)return!1;for(const s of q)if(!C.has(s.id))return!1;return!0},[C,q]),me=o.useMemo(()=>A?h.find(s=>s.id===A)??null:null,[A,h]),Z=o.useMemo(()=>A?h.findIndex(s=>s.id===A):-1,[A,h]),Me=o.useCallback(s=>{const r=Z+s;r>=0&&r<h.length&&x(h[r].id)},[Z,h]),se=async(s,r)=>{f(null),F(c=>{const d=new Set(c);return d.add(s),d});const n=await b(s,r);return n.failed>0?f(Ee("approve",n.failed,n.firstError)):n.updated>0&&f("Decision approved. Changes synced."),F(c=>{const d=new Set(c);return d.delete(s),d}),n},ke=v?async(s,r)=>{f(null),F(c=>{const d=new Set(c);return d.add(s),d});const n=await v(s,r);return n.failed>0?f(Ee("reject",n.failed,n.firstError)):n.updated>0&&f("Decision rejected. Changes synced."),F(c=>{const d=new Set(c);return d.delete(s),d}),n}:void 0;o.useEffect(()=>{le(s=>h.length===0?0:Math.min(Math.max(Te,s),h.length))},[h.length]),o.useEffect(()=>{const s=(u??"").trim();if(!s){pe.current=null;return}pe.current===s||!h.some(n=>n.id===s)||(pe.current=s,x(s),p==null||p(s))},[u,p,h]);const Ne=s=>{X(r=>{const n=new Set(r);return n.has(s)?n.delete(s):n.add(s),n})},$e=()=>{X(s=>{if(q.length===0)return s;const r=new Set(s),n=re;for(const c of q)n?r.delete(c.id):r.add(c.id);return r})},G=o.useMemo(()=>{const s=h.map(n=>n.id).filter(n=>C.has(n)),r=q.map(n=>n.id);return[{id:"approve_selected",label:`Approve selected (${s.length})`,action:"approve",ids:s},{id:"reject_selected",label:`Reject selected (${s.length})`,action:"reject",ids:s,hidden:!v},{id:"approve_visible",label:`Approve visible (${r.length})`,action:"approve",ids:r},{id:"reject_visible",label:`Reject visible (${r.length})`,action:"reject",ids:r,hidden:!v}].filter(n=>!n.hidden)},[v,C,h,q]),$=o.useMemo(()=>G.find(s=>s.id===J)??G[0]??null,[J,G]),Ie=async(s,r,n)=>{if(s.length===0)return{updated:0,failed:0};if(r==="approve"&&s.length===h.length&&!n)return R();let c=0,d=0,m;for(const S of s)try{const Y=r==="approve"?await b(S,n?{note:n}:void 0):v?await v(S,n?{note:n}:void 0):{updated:0,failed:1};c+=Y.updated,d+=Y.failed,!m&&Y.firstError&&(m=Y.firstError)}catch{d+=1}return{updated:c,failed:d,firstError:m}},Se=async()=>{if(!$||M)return;const s=$.ids;if(s.length===0){f("No decisions selected for this action.");return}f(null),y(!0),F(new Set(s));const r=ue.trim();try{const n=w?await w(s,$.action,r.length>0?r:void 0):await Ie(s,$.action,r.length>0?r:void 0),c=$.action==="approve"?"Approved":"Rejected";if(n.failed>0){const d=`${c} ${n.updated}; ${n.failed} failed.`,m=Ae(n.firstError,d);f(m===d?d:`${d} ${m}`)}else n.updated>0?f(`${c} ${n.updated} decision${n.updated===1?"":"s"}.`):f("No decisions were updated.");X(new Set)}catch(n){const c=n instanceof Error?n.message:"";f(Ae(c,"Bulk decision action failed."))}finally{y(!1),F(new Set)}},xe=async s=>{if(!(P.has(s)||M)){f(null),F(r=>{const n=new Set(r);return n.add(s),n});try{const r=await b(s);r.failed>0?f(Ee("approve",r.failed,r.firstError)):r.updated>0&&f("Decision approved.")}catch(r){const n=r instanceof Error?r.message:"";f(Ae(n,"Decision approval failed."))}finally{F(r=>{const n=new Set(r);return n.delete(s),n}),X(r=>{if(!r.has(s))return r;const n=new Set(r);return n.delete(s),n})}}},he=o.useCallback(s=>{P.has(s.id)||M||(ee(r=>new Set(r).add(s.id)),de({message:`Approved '${s.title.length>40?s.title.slice(0,40)+"…":s.title}'`,onUndo:()=>{ee(r=>{const n=new Set(r);return n.delete(s.id),n})},onCommit:()=>{ee(r=>{const n=new Set(r);return n.delete(s.id),n}),b(s.id).catch(()=>{f("Approval failed. Try again from the decision panel.")})}}))},[P,M,de,b]);o.useEffect(()=>{if(!W)return;const s=window.setTimeout(()=>f(null),5200);return()=>window.clearTimeout(s)},[W]);const fe=W!==null&&!W.toLowerCase().includes("fail"),I=M||P.size>0,ne=Math.max(P.size,M?V:0),ge=I?`Applying ${ne} decision action${ne===1?"":"s"}…`:W??null,i=I?"processing":W?fe?"success":"warning":"idle",l=!_&&q.length<=32,j=$!==null&&$.ids.length>0&&!M,D=h.length;(we=h[0])==null||we.waitingMinutes;const L=$!=null&&$.id.includes("visible")?"visible":"selected",Q=($==null?void 0:$.action)??"approve",g=ge!==null||i!=="idle",be=B==="card"?Ue:"div";return e.jsxs(be,{className:oe("flex h-full min-h-0 flex-col",B==="card"&&"card-enter",O),children:[e.jsx(lt,{open:A!==null,decision:me,onClose:()=>x(null),onApprove:se,onReject:ke,onNavigate:Me,currentIndex:Z>=0?Z:void 0,totalCount:h.length}),N?e.jsxs("div",{className:"space-y-2.5 border-b border-subtle px-4 py-3.5",children:[e.jsx("div",{className:"flex items-start justify-between gap-3",children:e.jsxs("div",{className:"min-w-0",children:[e.jsxs("h2",{className:"inline-flex items-center gap-2 text-heading font-semibold text-white",children:[e.jsx(ie,{type:"decision",size:14}),"Decisions"]}),e.jsx("p",{className:"mt-0.5 text-caption text-secondary",children:D>0?`${D} decision${D===1?"":"s"} need${D===1?"s":""} your input`:"All clear — no decisions pending"})]})}),e.jsxs("div",{className:"flex flex-wrap items-center gap-2",children:[h.length>0&&e.jsx("button",{onClick:$e,disabled:I,className:"control-pill h-8 flex-shrink-0 px-3 text-caption font-semibold disabled:opacity-45",children:re?"Clear all":"Select all"}),V>0&&e.jsxs(e.Fragment,{children:[e.jsx("button",{onClick:Se,disabled:!j||I,"data-state":j?"active":"idle",className:"control-pill h-8 flex-shrink-0 px-3 text-caption font-semibold disabled:opacity-45",children:M?"Approving…":`Approve ${V} selected`}),v&&e.jsx("button",{type:"button",onClick:()=>ae(ct("reject",L)),disabled:I,"data-state":Q==="reject"?"active":"idle",className:oe("control-pill h-8 px-2.5 text-caption font-semibold disabled:opacity-45",Q==="reject"&&"border-amber-300/35 bg-amber-400/[0.12] text-amber-100"),children:"Reject"})]})]}),g?e.jsxs("div",{"aria-live":"polite",className:oe("flex min-h-[32px] items-center gap-2 rounded-lg border px-2.5 py-1.5 text-caption transition-colors",i==="processing"?"border-amber-300/25 bg-amber-400/[0.08] text-amber-100":i==="success"?"border-lime/30 bg-lime/10 text-lime":i==="warning"?"border-red-400/25 bg-red-500/[0.08] text-red-100":"border-strong bg-white/[0.02] text-secondary"),children:[i==="processing"?e.jsx("span",{"aria-hidden":!0,className:"h-3.5 w-3.5 rounded-full border-2 border-amber-200/45 border-t-transparent animate-spin"}):i==="success"?e.jsx(ie,{type:"decision",size:12,className:"opacity-90"}):i==="warning"?e.jsxs("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",className:"opacity-90",children:[e.jsx("path",{d:"m21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3Z"}),e.jsx("line",{x1:"12",x2:"12",y1:"9",y2:"13"}),e.jsx("line",{x1:"12",x2:"12.01",y1:"17",y2:"17"})]}):e.jsx("span",{"aria-hidden":!0,className:"h-1.5 w-1.5 rounded-full bg-white/35"}),e.jsx("span",{className:"min-w-0 truncate",children:ge})]}):null]}):null,e.jsxs("div",{className:oe("min-h-0 flex-1 space-y-2 overflow-y-auto",N?"p-3":"p-0"),children:[h.length===0&&e.jsx("div",{className:"flex flex-col items-center gap-2.5 rounded-xl border border-subtle bg-white/[0.02] p-4 text-center",children:I?e.jsxs(e.Fragment,{children:[e.jsx("span",{"aria-hidden":!0,className:"h-5 w-5 rounded-full border-2 border-amber-200/45 border-t-transparent animate-spin"}),e.jsx("p",{className:"text-body text-secondary",children:"Finalizing decision updates…"})]}):e.jsxs(e.Fragment,{children:[e.jsxs("svg",{width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round",className:"text-faint",children:[e.jsx("path",{d:"M22 11.08V12a10 10 0 1 1-5.93-9.14"}),e.jsx("polyline",{points:"22 4 12 14.01 9 11.01"})]}),e.jsx("p",{className:"text-body text-secondary",children:"No pending decisions. All clear."})]})}),l?e.jsx(Re,{mode:"popLayout",children:U.map(s=>e.jsxs("div",{children:[U.length>1&&e.jsx(We,{group:s}),s.decisions.map((r,n)=>{const c=P.has(r.id),d=C.has(r.id),m=_e(r.waitingMinutes);return e.jsx(ce.article,{role:"button",tabIndex:0,onClick:()=>x(r.id),onKeyDown:S=>{(S.key==="Enter"||S.key===" ")&&(S.preventDefault(),x(r.id))},drag:!I&&!c?"x":!1,dragConstraints:{left:0,right:0},dragElastic:.3,onDragEnd:(S,Y)=>{Y.offset.x>120&&he(r)},initial:M?{opacity:0,x:300}:{opacity:0,y:8,scale:.98},animate:{opacity:1,y:0,x:0,scale:1},exit:{opacity:0,x:300,scale:.95},transition:{duration:.25,ease:[.22,1,.36,1],...M?{delay:n*.04}:{}},layout:!0,className:"mt-1.5 rounded-xl border bg-white/[0.03] px-3 py-2.5 transition-[border-color,box-shadow] cv-auto",style:{borderColor:d?`${T.lime}50`:"rgba(255, 255, 255, 0.1)",boxShadow:d?"0 0 0 1px rgba(191, 255, 0, 0.14)":"none"},children:e.jsxs("div",{className:"flex items-start gap-2.5",children:[e.jsx("input",{type:"checkbox",checked:d,onChange:()=>Ne(r.id),disabled:c||I,onClick:S=>S.stopPropagation(),className:"mt-0.5 h-4 w-4 rounded border-white/20 bg-black/40 text-lime focus:ring-lime/40"}),e.jsx("div",{className:"min-w-0 flex-1",children:e.jsxs("div",{className:"min-w-0",children:[e.jsxs("div",{className:"flex min-w-0 items-start gap-1.5",children:[m!=="normal"&&e.jsx("span",{"aria-label":m==="overdue"?"Overdue":"Urgent",className:oe("mt-[5px] h-2 w-2 flex-shrink-0 rounded-full",m==="overdue"?"bg-red-400":"bg-amber-400")}),e.jsxs("p",{className:"flex min-w-0 items-start gap-1.5 text-body font-medium text-white",title:r.title,children:[e.jsx(ie,{type:"decision",size:12,className:"mt-[3px] flex-shrink-0 opacity-90"}),e.jsx("span",{className:"line-clamp-2",children:r.title})]})]}),r.context&&e.jsx("p",{className:"mt-1 line-clamp-2 text-caption text-secondary",title:r.context,children:r.context}),e.jsxs("div",{className:"mt-1.5 flex items-center justify-between gap-2",children:[e.jsxs("p",{className:`min-w-0 truncate text-micro ${(()=>{const S=H(r.waitingMinutes);return S.tone==="urgent"?"text-red-400":S.tone==="attention"?"text-amber-400":"text-muted"})()}`,title:`${r.agentName??"OrgX Autopilot"} · ${H(r.waitingMinutes).text}`,children:[r.agentName??"OrgX Autopilot"," · ",H(r.waitingMinutes).text]}),e.jsx("button",{onClick:S=>{S.stopPropagation(),xe(r.id)},disabled:c||I,className:"flex-shrink-0 rounded-md border border-lime/25 bg-lime/10 px-2.5 py-1 text-micro font-semibold text-lime transition-colors hover:bg-lime/20 disabled:cursor-not-allowed disabled:border-white/10 disabled:bg-white/[0.08] disabled:text-secondary",children:c?"Approving…":"Approve"}),v&&e.jsx("button",{onClick:S=>{S.stopPropagation(),x(r.id)},disabled:c||I,className:"flex-shrink-0 rounded-md border border-white/[0.08] bg-white/[0.03] px-2.5 py-1 text-micro font-semibold text-secondary transition-colors hover:border-red-400/30 hover:bg-red-400/[0.08] hover:text-red-300 disabled:cursor-not-allowed disabled:opacity-40",children:"Reject"})]})]})})]})},r.id)})]},s.initiativeId))}):e.jsx(e.Fragment,{children:U.map(s=>e.jsxs("div",{children:[U.length>1&&e.jsx(We,{group:s}),s.decisions.map(r=>{const n=P.has(r.id),c=C.has(r.id),d=_e(r.waitingMinutes);return e.jsx("article",{role:"button",tabIndex:0,onClick:()=>x(r.id),onKeyDown:m=>{(m.key==="Enter"||m.key===" ")&&(m.preventDefault(),x(r.id))},className:"mt-1.5 rounded-xl border bg-white/[0.03] px-3 py-2.5 transition-[border-color,box-shadow] cv-auto",style:{borderColor:c?`${T.lime}50`:"rgba(255, 255, 255, 0.1)",boxShadow:c?"0 0 0 1px rgba(191, 255, 0, 0.14)":"none"},children:e.jsxs("div",{className:"flex items-start gap-2.5",children:[e.jsx("input",{type:"checkbox",checked:c,onChange:()=>Ne(r.id),disabled:n||I,onClick:m=>m.stopPropagation(),className:"mt-0.5 h-4 w-4 rounded border-white/20 bg-black/40 text-lime focus:ring-lime/40"}),e.jsx("div",{className:"min-w-0 flex-1",children:e.jsxs("div",{className:"min-w-0",children:[e.jsxs("div",{className:"flex min-w-0 items-start gap-1.5",children:[d!=="normal"&&e.jsx("span",{"aria-label":d==="overdue"?"Overdue":"Urgent",className:oe("mt-[5px] h-2 w-2 flex-shrink-0 rounded-full",d==="overdue"?"bg-red-400":"bg-amber-400")}),e.jsxs("p",{className:"flex min-w-0 items-start gap-1.5 text-body font-medium text-white",title:r.title,children:[e.jsx(ie,{type:"decision",size:12,className:"mt-[3px] flex-shrink-0 opacity-90"}),e.jsx("span",{className:"line-clamp-2",children:r.title})]})]}),r.context&&e.jsx("p",{className:"mt-1 line-clamp-2 text-caption text-secondary",title:r.context,children:r.context}),e.jsxs("div",{className:"mt-1.5 flex items-center justify-between gap-2",children:[e.jsxs("p",{className:`min-w-0 truncate text-micro ${(()=>{const m=H(r.waitingMinutes);return m.tone==="urgent"?"text-red-400":m.tone==="attention"?"text-amber-400":"text-muted"})()}`,title:`${r.agentName??"OrgX Autopilot"} · ${H(r.waitingMinutes).text}`,children:[r.agentName??"OrgX Autopilot"," · ",H(r.waitingMinutes).text]}),e.jsx("button",{onClick:m=>{m.stopPropagation(),xe(r.id)},disabled:n||I,className:"flex-shrink-0 rounded-md border border-lime/25 bg-lime/10 px-2.5 py-1 text-micro font-semibold text-lime transition-colors hover:bg-lime/20 disabled:cursor-not-allowed disabled:border-white/10 disabled:bg-white/[0.08] disabled:text-secondary",children:n?"Approving…":"Approve"}),v&&e.jsx("button",{onClick:m=>{m.stopPropagation(),x(r.id)},disabled:n||I,className:"flex-shrink-0 rounded-md border border-white/[0.08] bg-white/[0.03] px-2.5 py-1 text-micro font-semibold text-secondary transition-colors hover:border-red-400/30 hover:bg-red-400/[0.08] hover:text-red-300 disabled:cursor-not-allowed disabled:opacity-40",children:"Reject"})]})]})})]})},r.id)})]},s.initiativeId))}),q.length<h.length&&e.jsxs("button",{onClick:()=>le(s=>Math.min(h.length,s+Te)),className:"w-full rounded-xl border border-white/[0.08] bg-white/[0.02] px-3 py-2 text-caption text-secondary transition-colors hover:bg-white/[0.05]",children:["Load more (",h.length-q.length," remaining)"]})]}),e.jsx(je,{})]})});export{wt as DecisionQueue};
|
|
Binary file
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{r as c}from"./Dj2k1r16.js";import{c as m}from"./DMKyYAtD.js";import{b as g,h as n}from"./
|
|
1
|
+
import{r as c}from"./Dj2k1r16.js";import{c as m}from"./DMKyYAtD.js";import{b as g,h as n}from"./C8AYbjlq.js";function h({authToken:s=null,embedMode:o=!1,enabled:i=!0}={}){var a;const u=c.useMemo(()=>["usage-control-plane",{authToken:s,embedMode:o}],[s,o]),e=m({queryKey:u,enabled:i,queryFn:async()=>{const t=await fetch("/orgx/api/usage/control-plane/summary",{headers:g({authToken:s,embedMode:o})}),r=await t.json().catch(()=>null);if(!t.ok){const l=(r&&typeof r=="object"&&"error"in r&&typeof r.error=="string"?r.error:null)??(r&&typeof r=="object"&&"message"in r&&typeof r.message=="string"?r.message:null)??`Failed to load usage summary (${t.status})`;throw new Error(n(l))}if(!r||typeof r!="object"||!("generatedAt"in r))throw new Error(n("Usage summary response is missing required fields."));return r},refetchInterval:6e4});return{summary:e.data??null,isLoading:e.isLoading,isFetching:e.isFetching,error:((a=e.error)==null?void 0:a.message)??null,refetch:e.refetch}}export{h as u};
|
|
Binary file
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{r as s,j as t}from"./Dj2k1r16.js";import{y as ke}from"./B1LENRC8.js";import"./DMKyYAtD.js";import"./eeHXe_OQ.js";import"./cX2e-TLi.js";import"./BjK42gtU.js";import"./BV0BcV1u.js";const I={PREVIEW:"orgx_orchestrator_preview",APPLY:"orgx_orchestrator_apply",STATUS:"orgx_orchestrator_status"};function l(p){if(typeof p!="string")return null;const n=p.trim();return n.length?n:null}function Ce(p){if(!p.trim())return{};const n=JSON.parse(p);return!n||typeof n!="object"||Array.isArray(n)?{}:n}function Q(p){const n=l(p.transcript)??l(p.text)??l(p.delta??null);if(n)return n;const h=p.item&&typeof p.item=="object"?p.item:null,v=Array.isArray(h==null?void 0:h.content)?h==null?void 0:h.content:[];for(const y of v){if(!y||typeof y!="object")continue;const f=l(y.transcript)??l(y.text);if(f)return f}return null}function Se(p){const n=p.response&&typeof p.response=="object"?p.response:null,h=Array.isArray(n==null?void 0:n.output)?n==null?void 0:n.output:[],v=[];for(const y of h){if(!y||typeof y!="object")continue;const f=y;if(f.type!=="function_call")continue;const C=l(f.name),S=l(f.call_id)??l(f.id),A=typeof f.arguments=="string"?f.arguments:"{}";!C||!S||v.push({callId:S,name:C,arguments:A})}return v}function Ae(p){const n=Number.isFinite(p)?p*100:0;return`${Math.max(0,Math.min(100,Math.round(n)))}%`}const fe=[{type:"function",name:I.PREVIEW,description:"Preview orchestrator actions from a natural language command. Use this before apply.",parameters:{type:"object",additionalProperties:!1,properties:{input:{type:"string",description:"Natural language command from the operator."},workspace_id:{type:"string",description:"Optional OrgX workspace/command_center id."}},required:["input"]}},{type:"function",name:I.APPLY,description:"Apply selected action ids from a previewed command after user confirmation.",parameters:{type:"object",additionalProperties:!1,properties:{command_id:{type:"string",description:"Command id from preview response."},confirmed_action_ids:{type:"array",items:{type:"string"},description:"Optional subset of action ids to apply. Omit to apply all."},workspace_id:{type:"string",description:"Optional OrgX workspace/command_center id."}},required:["command_id"]}},{type:"function",name:I.STATUS,description:"Get latest status for a previously created command.",parameters:{type:"object",additionalProperties:!1,properties:{command_id:{type:"string",description:"Command id from preview/apply response."}},required:["command_id"]}}];function Me({open:p,selectedWorkspaceId:n,onClose:h}){var le,de,pe;const[v,y]=s.useState(!1),[f,C]=s.useState(!1),[S,A]=s.useState(!1),[xe,he]=s.useState("gpt-realtime-1.5"),[$,Z]=s.useState(""),[W,M]=s.useState(""),[o,P]=s.useState(null),[T,X]=s.useState([]),[ee,te]=s.useState(!1),[re,oe]=s.useState(!1),[se,b]=s.useState(null),[ne,z]=s.useState([]),G=s.useRef(null),D=s.useRef(null),O=s.useRef(null),H=s.useRef(null),E=s.useRef(""),J=s.useRef(new Set),R=s.useCallback(e=>{z(r=>[e,...r].slice(0,10))},[]),N=s.useCallback(()=>{A(!1),C(!1),J.current=new Set;const e=D.current;if(e)try{e.close()}catch{}D.current=null;const r=G.current;if(r)try{r.close()}catch{}G.current=null;const a=O.current;if(a)for(const m of a.getTracks())try{m.stop()}catch{}O.current=null;const d=H.current;if(d){try{const m=d.srcObject;m==null||m.getTracks().forEach(i=>i.stop())}catch{}try{d.pause()}catch{}d.srcObject=null}H.current=null},[]);s.useEffect(()=>{p||(N(),b(null),M(""),z([]),E.current="")},[N,p]),s.useEffect(()=>()=>N(),[N]);const g=s.useCallback(e=>{const r=D.current;!r||r.readyState!=="open"||r.send(JSON.stringify(e))},[]),ae=s.useCallback(async e=>{const r=await fetch(e),a=await r.json().catch(()=>({}));if(!r.ok)throw new Error(a&&typeof a=="object"&&"error"in a&&a.error||`Request failed: ${r.status}`);return a},[]),j=s.useCallback(async(e,r)=>{const a=await fetch(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(r)}),d=await a.json().catch(()=>({}));if(!a.ok)throw new Error(d&&typeof d=="object"&&"error"in d&&d.error||`Request failed: ${a.status}`);return d},[]),L=s.useCallback(async e=>{if(!J.current.has(e.callId)){J.current.add(e.callId);try{const r=Ce(e.arguments);let a={ok:!1,error:"Unsupported tool call."};if(e.name===I.PREVIEW){const d=l(r.input);if(!d)throw new Error("Preview tool call requires input.");const m=await j("/orgx/api/orchestrator/commands/preview",{input:d,workspace_id:l(r.workspace_id)??n??void 0});if(!m.command)throw new Error(m.error??"Preview command failed.");P(m.command),X(m.command.proposedActions.map(i=>i.actionId)),a={ok:!0,command:m.command}}else if(e.name===I.APPLY){const d=l(r.command_id);if(!d)throw new Error("Apply tool call requires command_id.");const m=Array.isArray(r.confirmed_action_ids)?r.confirmed_action_ids.filter(F=>typeof F=="string"):void 0,i=await j("/orgx/api/orchestrator/commands/apply",{command_id:d,confirmed_action_ids:m,workspace_id:l(r.workspace_id)??n??void 0});if(!i.command)throw new Error(i.error??"Apply command failed.");P(i.command),a={ok:!0,command:i.command}}else if(e.name===I.STATUS){const d=l(r.command_id);if(!d)throw new Error("Status tool call requires command_id.");const m=await ae(`/orgx/api/orchestrator/commands/${encodeURIComponent(d)}`);if(!m.command)throw new Error(m.error??"Command status unavailable.");P(m.command),a={ok:!0,command:m.command}}g({type:"conversation.item.create",item:{type:"function_call_output",call_id:e.callId,output:JSON.stringify(a)}}),g({type:"response.create"}),R(`Tool executed: ${e.name}`)}catch(r){const a=r instanceof Error?r.message:"Tool execution failed.";b(a),g({type:"conversation.item.create",item:{type:"function_call_output",call_id:e.callId,output:JSON.stringify({ok:!1,error:a})}}),g({type:"response.create"}),R(`Tool failed: ${e.name}`)}}},[ae,R,j,n,g]),ye=s.useCallback(async()=>{var e,r,a,d,m;if(!((e=navigator.mediaDevices)!=null&&e.getUserMedia)){b("Microphone capture is unavailable in this browser/runtime.");return}b(null),y(!0),z([]);try{const i=await j("/orgx/api/realtime/session",{workspace_id:n??void 0,model:"gpt-realtime-1.5",voice:"alloy",tool_choice:"auto",tools:fe,instructions:"You are the OrgX realtime orchestrator copilot. Use tools for state-changing operations. Before applying actions, state the plan concisely."});if(!(i!=null&&i.session))throw new Error((i==null?void 0:i.error)??"Failed to create realtime session.");const F=l((r=i==null?void 0:i.session)==null?void 0:r.model)??l((a=i==null?void 0:i.defaults)==null?void 0:a.model)??"gpt-realtime-1.5";he(F);const me=l((m=(d=i==null?void 0:i.session)==null?void 0:d.client_secret)==null?void 0:m.value);if(!me)throw new Error("Realtime session is missing client_secret.");const U=await navigator.mediaDevices.getUserMedia({audio:!0});O.current=U;for(const _ of U.getAudioTracks())_.enabled=!1;const k=new RTCPeerConnection;G.current=k,U.getTracks().forEach(_=>k.addTrack(_,U));const q=document.createElement("audio");q.autoplay=!0,H.current=q,k.ontrack=_=>{const[u]=_.streams;u&&(q.srcObject=u,q.play().catch(()=>{}))};const V=k.createDataChannel("oai-events");D.current=V,V.onmessage=_=>{try{const u=JSON.parse(String(_.data)),x=l(u.type)??"";if(x==="error"){const c=u.error&&typeof u.error=="object"?u.error:null,w=l(c==null?void 0:c.message)??l(u.message)??"Realtime session error.";b(w),R(`Error: ${w}`);return}if(x==="conversation.item.input_audio_transcription.completed"){const c=Q(u);c&&Z(c)}if(x==="response.output_text.delta"||x==="response.text.delta"||x==="response.output_audio_transcript.delta"||x==="response.audio_transcript.delta"){const c=l(u.delta)??Q(u);c&&(E.current=`${E.current}${c}`,M(E.current))}if(x==="response.output_text.done"||x==="response.text.done"||x==="response.output_audio_transcript.done"||x==="response.audio_transcript.done"){const c=Q(u);c&&(E.current=c,M(c))}if(x==="response.function_call_arguments.done"){const c=l(u.call_id),w=l(u.name);if(c&&w){const B=typeof u.arguments=="string"?u.arguments:"{}";L({callId:c,name:w,arguments:B})}}if(x==="response.output_item.done"){const c=u.item&&typeof u.item=="object"?u.item:null;if((c==null?void 0:c.type)==="function_call"){const w=l(c.call_id)??l(c.id),B=l(c.name);if(w&&B){const Ne=typeof c.arguments=="string"?c.arguments:"{}";L({callId:w,name:B,arguments:Ne})}}}if(x==="response.done"){const c=Se(u);for(const w of c)L(w)}}catch{}},V.onopen=()=>{C(!0),g({type:"session.update",session:{tools:fe,tool_choice:"auto"}}),R("Realtime connected")},V.onclose=()=>{C(!1),A(!1)};const ue=await k.createOffer();await k.setLocalDescription(ue);const Y=await fetch(`https://api.openai.com/v1/realtime?model=${encodeURIComponent(F)}`,{method:"POST",headers:{Authorization:`Bearer ${me}`,"Content-Type":"application/sdp"},body:ue.sdp??""});if(!Y.ok){const _=await Y.text().catch(()=>Y.statusText);throw new Error(`Realtime SDP negotiation failed: ${_}`)}const ve=await Y.text();await k.setRemoteDescription({type:"answer",sdp:ve})}catch(i){N(),b(i instanceof Error?i.message:"Failed to connect realtime session.")}finally{y(!1)}},[N,L,R,j,n]),ie=s.useCallback(()=>{if(!f)return;const e=O.current;if(e){for(const r of e.getAudioTracks())r.enabled=!0;E.current="",M(""),A(!0),g({type:"input_audio_buffer.clear"})}},[f,g]),K=s.useCallback(()=>{const e=O.current;if(e)for(const r of e.getAudioTracks())r.enabled=!1;A(!1),g({type:"input_audio_buffer.commit"}),g({type:"response.create"})},[g]),ge=s.useCallback(async()=>{const e=$.trim();if(e){te(!0),b(null);try{const r=await j("/orgx/api/orchestrator/commands/preview",{input:e,workspace_id:n??void 0});if(!r.command)throw new Error(r.error??"Failed to preview command.");P(r.command),X(r.command.proposedActions.map(a=>a.actionId))}catch(r){b(r instanceof Error?r.message:"Failed to preview command.")}finally{te(!1)}}},[$,j,n]),be=s.useCallback(async()=>{if(o!=null&&o.id){oe(!0),b(null);try{const e=await j("/orgx/api/orchestrator/commands/apply",{command_id:o.id,confirmed_action_ids:T,workspace_id:n??void 0});if(!e.command)throw new Error(e.error??"Failed to apply command.");P(e.command)}catch(e){b(e instanceof Error?e.message:"Failed to apply command.")}finally{oe(!1)}}},[o==null?void 0:o.id,j,T,n]),ce=T.length,we=(((le=o==null?void 0:o.proposedActions)==null?void 0:le.length)??0)>0,je=!!(o!=null&&o.id)&&ce>0&&!re,_e=s.useMemo(()=>{const e=(o==null?void 0:o.status)??"draft";return e==="completed"?"text-lime":e==="completed_with_errors"||e==="failed"?"text-amber-300":e==="applying"?"text-teal":"text-secondary"},[o==null?void 0:o.status]);return t.jsxs(ke,{open:p,onClose:h,maxWidth:"max-w-5xl",fitContent:!0,closeOnEscapeWhenTyping:!1,children:[t.jsx("div",{className:"border-b border-strong px-4 py-3",children:t.jsxs("div",{className:"flex items-start justify-between gap-3",children:[t.jsxs("div",{children:[t.jsx("p",{className:"text-caption uppercase tracking-[0.14em] text-secondary",children:"Realtime Orchestrator"}),t.jsx("h2",{className:"text-heading font-semibold text-white",children:"GPT Realtime 1.5"}),t.jsx("p",{className:"text-micro text-secondary",children:"Voice + tool-calls for initiative launch, decision resolution, and Next Up control."})]}),t.jsx("button",{type:"button",onClick:h,className:"rounded-full border border-strong bg-white/[0.03] px-3 py-1.5 text-caption text-secondary transition-colors hover:bg-white/[0.08] hover:text-white",children:"Close"})]})}),t.jsxs("div",{className:"grid gap-4 px-4 pb-4 pt-3 lg:grid-cols-[1.12fr_1fr]",children:[t.jsxs("section",{className:"space-y-3",children:[t.jsxs("div",{className:"rounded-xl border border-strong bg-white/[0.02] p-3",children:[t.jsxs("div",{className:"mb-2 flex items-center justify-between",children:[t.jsx("span",{className:"text-caption uppercase tracking-[0.12em] text-secondary",children:"Session"}),t.jsx("span",{className:"text-micro text-secondary",children:xe})]}),t.jsx("div",{className:"flex flex-wrap items-center gap-2",children:f?t.jsxs(t.Fragment,{children:[t.jsx("button",{type:"button",onMouseDown:ie,onMouseUp:K,onMouseLeave:()=>{S&&K()},onTouchStart:e=>{e.preventDefault(),ie()},onTouchEnd:e=>{e.preventDefault(),K()},className:`rounded-full border px-3 py-1.5 text-caption font-semibold transition-colors ${S?"border-teal/45 bg-teal/[0.16] text-teal":"border-white/[0.2] bg-white/[0.04] text-primary hover:bg-white/[0.1]"}`,children:S?"Listening… release to send":"Hold to talk"}),t.jsx("button",{type:"button",onClick:N,className:"rounded-full border border-strong bg-white/[0.03] px-3 py-1.5 text-caption text-secondary transition-colors hover:bg-white/[0.08] hover:text-primary",children:"Disconnect"})]}):t.jsx("button",{type:"button",disabled:v,onClick:()=>void ye(),className:"rounded-full border border-lime/35 bg-lime/[0.12] px-3 py-1.5 text-caption font-semibold text-lime transition-colors hover:bg-lime/[0.2] disabled:cursor-not-allowed disabled:opacity-60",children:v?"Connecting…":"Connect Realtime"})}),ne.length>0?t.jsx("div",{className:"mt-3 rounded-lg border border-strong bg-black/20 p-2",children:ne.map((e,r)=>t.jsx("p",{className:"text-micro text-secondary",children:e},`${e}-${r}`))}):null]}),t.jsxs("div",{className:"rounded-xl border border-strong bg-white/[0.02] p-3",children:[t.jsx("label",{className:"mb-2 block text-caption uppercase tracking-[0.12em] text-secondary",children:"Command Input"}),t.jsx("textarea",{value:$,onChange:e=>Z(e.target.value),rows:4,"data-modal-autofocus":"true",placeholder:"Example: create initiative called AI Readiness Audit for this workspace",className:"w-full rounded-lg border border-strong bg-[#040912] px-3 py-2 text-body text-primary placeholder:text-secondary focus:border-lime/35 focus:outline-none"}),W?t.jsxs("p",{className:"mt-2 text-caption text-secondary",children:["Assistant: ",t.jsx("span",{className:"text-primary",children:W})]}):null,t.jsxs("div",{className:"mt-3 flex items-center gap-2",children:[t.jsx("button",{type:"button",disabled:ee||$.trim().length===0,onClick:()=>void ge(),className:"rounded-full border border-teal/35 bg-teal/[0.12] px-3 py-1.5 text-caption font-semibold text-teal transition-colors hover:bg-teal/[0.2] disabled:cursor-not-allowed disabled:opacity-60",children:ee?"Previewing…":"Preview Actions"}),t.jsx("button",{type:"button",disabled:!je,onClick:()=>void be(),className:"rounded-full border border-lime/35 bg-lime/[0.12] px-3 py-1.5 text-caption font-semibold text-lime transition-colors hover:bg-lime/[0.2] disabled:cursor-not-allowed disabled:opacity-60",children:re?"Applying…":`Apply (${ce})`})]})]})]}),t.jsxs("section",{className:"space-y-3",children:[t.jsxs("div",{className:"rounded-xl border border-strong bg-white/[0.02] p-3",children:[t.jsxs("div",{className:"mb-2 flex items-center justify-between",children:[t.jsx("span",{className:"text-caption uppercase tracking-[0.12em] text-secondary",children:"Command Status"}),t.jsx("span",{className:`text-caption font-semibold ${_e}`,children:(o==null?void 0:o.status)??"idle"})]}),t.jsx("p",{className:"text-body text-primary",children:(o==null?void 0:o.humanSummary)??"Preview a command or use voice to trigger tool calls."}),(de=o==null?void 0:o.riskFlags)!=null&&de.length?t.jsxs("p",{className:"mt-2 text-caption text-amber-200",children:["Risk flags: ",o.riskFlags.join(", ")]}):null]}),t.jsxs("div",{className:"max-h-[360px] space-y-2 overflow-y-auto rounded-xl border border-strong bg-white/[0.02] p-3",children:[t.jsx("p",{className:"text-caption uppercase tracking-[0.12em] text-secondary",children:"Proposed Actions"}),we?o.proposedActions.map(e=>{const r=T.includes(e.actionId);return t.jsx("label",{className:"block rounded-lg border border-strong bg-[#040912] p-2 text-body",children:t.jsxs("div",{className:"flex items-start gap-2",children:[t.jsx("input",{type:"checkbox",checked:r,onChange:a=>{const d=a.target.checked?[...T,e.actionId]:T.filter(m=>m!==e.actionId);X(d)},className:"mt-1"}),t.jsxs("div",{className:"min-w-0",children:[t.jsx("p",{className:"font-semibold text-primary",children:e.type}),t.jsx("p",{className:"text-caption text-secondary",children:e.reason}),t.jsxs("p",{className:"text-micro text-secondary",children:["confidence ",Ae(e.confidence)," • impact ",e.blockingImpact]})]})]})},e.actionId)}):t.jsx("p",{className:"text-body text-secondary",children:"No actions inferred yet."})]}),(((pe=o==null?void 0:o.results)==null?void 0:pe.length)??0)>0?t.jsxs("div",{className:"max-h-[220px] space-y-2 overflow-y-auto rounded-xl border border-strong bg-white/[0.02] p-3",children:[t.jsx("p",{className:"text-caption uppercase tracking-[0.12em] text-secondary",children:"Apply Results"}),o.results.map(e=>t.jsxs("div",{className:`rounded-lg border p-2 text-body ${e.ok?"border-lime/30 bg-lime/[0.08] text-lime":"border-amber-400/35 bg-amber-500/[0.12] text-amber-100"}`,children:[t.jsx("p",{className:"font-semibold",children:e.type}),t.jsx("p",{className:"text-caption",children:e.message}),e.error?t.jsxs("p",{className:"text-micro text-amber-200",children:["error: ",e.error]}):null]},`${e.actionId}-${e.type}`))]}):null]})]}),se?t.jsx("div",{className:"border-t border-amber-500/30 bg-amber-500/[0.12] px-4 py-2 text-caption text-amber-100",children:se}):null]})}export{Me as RealtimeOrchestratorModal};
|
|
1
|
+
import{r as s,j as t}from"./Dj2k1r16.js";import{y as ke}from"./C8AYbjlq.js";import"./DMKyYAtD.js";import"./eeHXe_OQ.js";import"./cX2e-TLi.js";import"./BjK42gtU.js";import"./BV0BcV1u.js";const I={PREVIEW:"orgx_orchestrator_preview",APPLY:"orgx_orchestrator_apply",STATUS:"orgx_orchestrator_status"};function l(p){if(typeof p!="string")return null;const n=p.trim();return n.length?n:null}function Ce(p){if(!p.trim())return{};const n=JSON.parse(p);return!n||typeof n!="object"||Array.isArray(n)?{}:n}function Q(p){const n=l(p.transcript)??l(p.text)??l(p.delta??null);if(n)return n;const h=p.item&&typeof p.item=="object"?p.item:null,v=Array.isArray(h==null?void 0:h.content)?h==null?void 0:h.content:[];for(const y of v){if(!y||typeof y!="object")continue;const f=l(y.transcript)??l(y.text);if(f)return f}return null}function Se(p){const n=p.response&&typeof p.response=="object"?p.response:null,h=Array.isArray(n==null?void 0:n.output)?n==null?void 0:n.output:[],v=[];for(const y of h){if(!y||typeof y!="object")continue;const f=y;if(f.type!=="function_call")continue;const C=l(f.name),S=l(f.call_id)??l(f.id),A=typeof f.arguments=="string"?f.arguments:"{}";!C||!S||v.push({callId:S,name:C,arguments:A})}return v}function Ae(p){const n=Number.isFinite(p)?p*100:0;return`${Math.max(0,Math.min(100,Math.round(n)))}%`}const fe=[{type:"function",name:I.PREVIEW,description:"Preview orchestrator actions from a natural language command. Use this before apply.",parameters:{type:"object",additionalProperties:!1,properties:{input:{type:"string",description:"Natural language command from the operator."},workspace_id:{type:"string",description:"Optional OrgX workspace/command_center id."}},required:["input"]}},{type:"function",name:I.APPLY,description:"Apply selected action ids from a previewed command after user confirmation.",parameters:{type:"object",additionalProperties:!1,properties:{command_id:{type:"string",description:"Command id from preview response."},confirmed_action_ids:{type:"array",items:{type:"string"},description:"Optional subset of action ids to apply. Omit to apply all."},workspace_id:{type:"string",description:"Optional OrgX workspace/command_center id."}},required:["command_id"]}},{type:"function",name:I.STATUS,description:"Get latest status for a previously created command.",parameters:{type:"object",additionalProperties:!1,properties:{command_id:{type:"string",description:"Command id from preview/apply response."}},required:["command_id"]}}];function Me({open:p,selectedWorkspaceId:n,onClose:h}){var le,de,pe;const[v,y]=s.useState(!1),[f,C]=s.useState(!1),[S,A]=s.useState(!1),[xe,he]=s.useState("gpt-realtime-1.5"),[$,Z]=s.useState(""),[W,M]=s.useState(""),[o,P]=s.useState(null),[T,X]=s.useState([]),[ee,te]=s.useState(!1),[re,oe]=s.useState(!1),[se,b]=s.useState(null),[ne,z]=s.useState([]),G=s.useRef(null),D=s.useRef(null),O=s.useRef(null),H=s.useRef(null),E=s.useRef(""),J=s.useRef(new Set),R=s.useCallback(e=>{z(r=>[e,...r].slice(0,10))},[]),N=s.useCallback(()=>{A(!1),C(!1),J.current=new Set;const e=D.current;if(e)try{e.close()}catch{}D.current=null;const r=G.current;if(r)try{r.close()}catch{}G.current=null;const a=O.current;if(a)for(const m of a.getTracks())try{m.stop()}catch{}O.current=null;const d=H.current;if(d){try{const m=d.srcObject;m==null||m.getTracks().forEach(i=>i.stop())}catch{}try{d.pause()}catch{}d.srcObject=null}H.current=null},[]);s.useEffect(()=>{p||(N(),b(null),M(""),z([]),E.current="")},[N,p]),s.useEffect(()=>()=>N(),[N]);const g=s.useCallback(e=>{const r=D.current;!r||r.readyState!=="open"||r.send(JSON.stringify(e))},[]),ae=s.useCallback(async e=>{const r=await fetch(e),a=await r.json().catch(()=>({}));if(!r.ok)throw new Error(a&&typeof a=="object"&&"error"in a&&a.error||`Request failed: ${r.status}`);return a},[]),j=s.useCallback(async(e,r)=>{const a=await fetch(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(r)}),d=await a.json().catch(()=>({}));if(!a.ok)throw new Error(d&&typeof d=="object"&&"error"in d&&d.error||`Request failed: ${a.status}`);return d},[]),L=s.useCallback(async e=>{if(!J.current.has(e.callId)){J.current.add(e.callId);try{const r=Ce(e.arguments);let a={ok:!1,error:"Unsupported tool call."};if(e.name===I.PREVIEW){const d=l(r.input);if(!d)throw new Error("Preview tool call requires input.");const m=await j("/orgx/api/orchestrator/commands/preview",{input:d,workspace_id:l(r.workspace_id)??n??void 0});if(!m.command)throw new Error(m.error??"Preview command failed.");P(m.command),X(m.command.proposedActions.map(i=>i.actionId)),a={ok:!0,command:m.command}}else if(e.name===I.APPLY){const d=l(r.command_id);if(!d)throw new Error("Apply tool call requires command_id.");const m=Array.isArray(r.confirmed_action_ids)?r.confirmed_action_ids.filter(F=>typeof F=="string"):void 0,i=await j("/orgx/api/orchestrator/commands/apply",{command_id:d,confirmed_action_ids:m,workspace_id:l(r.workspace_id)??n??void 0});if(!i.command)throw new Error(i.error??"Apply command failed.");P(i.command),a={ok:!0,command:i.command}}else if(e.name===I.STATUS){const d=l(r.command_id);if(!d)throw new Error("Status tool call requires command_id.");const m=await ae(`/orgx/api/orchestrator/commands/${encodeURIComponent(d)}`);if(!m.command)throw new Error(m.error??"Command status unavailable.");P(m.command),a={ok:!0,command:m.command}}g({type:"conversation.item.create",item:{type:"function_call_output",call_id:e.callId,output:JSON.stringify(a)}}),g({type:"response.create"}),R(`Tool executed: ${e.name}`)}catch(r){const a=r instanceof Error?r.message:"Tool execution failed.";b(a),g({type:"conversation.item.create",item:{type:"function_call_output",call_id:e.callId,output:JSON.stringify({ok:!1,error:a})}}),g({type:"response.create"}),R(`Tool failed: ${e.name}`)}}},[ae,R,j,n,g]),ye=s.useCallback(async()=>{var e,r,a,d,m;if(!((e=navigator.mediaDevices)!=null&&e.getUserMedia)){b("Microphone capture is unavailable in this browser/runtime.");return}b(null),y(!0),z([]);try{const i=await j("/orgx/api/realtime/session",{workspace_id:n??void 0,model:"gpt-realtime-1.5",voice:"alloy",tool_choice:"auto",tools:fe,instructions:"You are the OrgX realtime orchestrator copilot. Use tools for state-changing operations. Before applying actions, state the plan concisely."});if(!(i!=null&&i.session))throw new Error((i==null?void 0:i.error)??"Failed to create realtime session.");const F=l((r=i==null?void 0:i.session)==null?void 0:r.model)??l((a=i==null?void 0:i.defaults)==null?void 0:a.model)??"gpt-realtime-1.5";he(F);const me=l((m=(d=i==null?void 0:i.session)==null?void 0:d.client_secret)==null?void 0:m.value);if(!me)throw new Error("Realtime session is missing client_secret.");const U=await navigator.mediaDevices.getUserMedia({audio:!0});O.current=U;for(const _ of U.getAudioTracks())_.enabled=!1;const k=new RTCPeerConnection;G.current=k,U.getTracks().forEach(_=>k.addTrack(_,U));const q=document.createElement("audio");q.autoplay=!0,H.current=q,k.ontrack=_=>{const[u]=_.streams;u&&(q.srcObject=u,q.play().catch(()=>{}))};const V=k.createDataChannel("oai-events");D.current=V,V.onmessage=_=>{try{const u=JSON.parse(String(_.data)),x=l(u.type)??"";if(x==="error"){const c=u.error&&typeof u.error=="object"?u.error:null,w=l(c==null?void 0:c.message)??l(u.message)??"Realtime session error.";b(w),R(`Error: ${w}`);return}if(x==="conversation.item.input_audio_transcription.completed"){const c=Q(u);c&&Z(c)}if(x==="response.output_text.delta"||x==="response.text.delta"||x==="response.output_audio_transcript.delta"||x==="response.audio_transcript.delta"){const c=l(u.delta)??Q(u);c&&(E.current=`${E.current}${c}`,M(E.current))}if(x==="response.output_text.done"||x==="response.text.done"||x==="response.output_audio_transcript.done"||x==="response.audio_transcript.done"){const c=Q(u);c&&(E.current=c,M(c))}if(x==="response.function_call_arguments.done"){const c=l(u.call_id),w=l(u.name);if(c&&w){const B=typeof u.arguments=="string"?u.arguments:"{}";L({callId:c,name:w,arguments:B})}}if(x==="response.output_item.done"){const c=u.item&&typeof u.item=="object"?u.item:null;if((c==null?void 0:c.type)==="function_call"){const w=l(c.call_id)??l(c.id),B=l(c.name);if(w&&B){const Ne=typeof c.arguments=="string"?c.arguments:"{}";L({callId:w,name:B,arguments:Ne})}}}if(x==="response.done"){const c=Se(u);for(const w of c)L(w)}}catch{}},V.onopen=()=>{C(!0),g({type:"session.update",session:{tools:fe,tool_choice:"auto"}}),R("Realtime connected")},V.onclose=()=>{C(!1),A(!1)};const ue=await k.createOffer();await k.setLocalDescription(ue);const Y=await fetch(`https://api.openai.com/v1/realtime?model=${encodeURIComponent(F)}`,{method:"POST",headers:{Authorization:`Bearer ${me}`,"Content-Type":"application/sdp"},body:ue.sdp??""});if(!Y.ok){const _=await Y.text().catch(()=>Y.statusText);throw new Error(`Realtime SDP negotiation failed: ${_}`)}const ve=await Y.text();await k.setRemoteDescription({type:"answer",sdp:ve})}catch(i){N(),b(i instanceof Error?i.message:"Failed to connect realtime session.")}finally{y(!1)}},[N,L,R,j,n]),ie=s.useCallback(()=>{if(!f)return;const e=O.current;if(e){for(const r of e.getAudioTracks())r.enabled=!0;E.current="",M(""),A(!0),g({type:"input_audio_buffer.clear"})}},[f,g]),K=s.useCallback(()=>{const e=O.current;if(e)for(const r of e.getAudioTracks())r.enabled=!1;A(!1),g({type:"input_audio_buffer.commit"}),g({type:"response.create"})},[g]),ge=s.useCallback(async()=>{const e=$.trim();if(e){te(!0),b(null);try{const r=await j("/orgx/api/orchestrator/commands/preview",{input:e,workspace_id:n??void 0});if(!r.command)throw new Error(r.error??"Failed to preview command.");P(r.command),X(r.command.proposedActions.map(a=>a.actionId))}catch(r){b(r instanceof Error?r.message:"Failed to preview command.")}finally{te(!1)}}},[$,j,n]),be=s.useCallback(async()=>{if(o!=null&&o.id){oe(!0),b(null);try{const e=await j("/orgx/api/orchestrator/commands/apply",{command_id:o.id,confirmed_action_ids:T,workspace_id:n??void 0});if(!e.command)throw new Error(e.error??"Failed to apply command.");P(e.command)}catch(e){b(e instanceof Error?e.message:"Failed to apply command.")}finally{oe(!1)}}},[o==null?void 0:o.id,j,T,n]),ce=T.length,we=(((le=o==null?void 0:o.proposedActions)==null?void 0:le.length)??0)>0,je=!!(o!=null&&o.id)&&ce>0&&!re,_e=s.useMemo(()=>{const e=(o==null?void 0:o.status)??"draft";return e==="completed"?"text-lime":e==="completed_with_errors"||e==="failed"?"text-amber-300":e==="applying"?"text-teal":"text-secondary"},[o==null?void 0:o.status]);return t.jsxs(ke,{open:p,onClose:h,maxWidth:"max-w-5xl",fitContent:!0,closeOnEscapeWhenTyping:!1,children:[t.jsx("div",{className:"border-b border-strong px-4 py-3",children:t.jsxs("div",{className:"flex items-start justify-between gap-3",children:[t.jsxs("div",{children:[t.jsx("p",{className:"text-caption uppercase tracking-[0.14em] text-secondary",children:"Realtime Orchestrator"}),t.jsx("h2",{className:"text-heading font-semibold text-white",children:"GPT Realtime 1.5"}),t.jsx("p",{className:"text-micro text-secondary",children:"Voice + tool-calls for initiative launch, decision resolution, and Next Up control."})]}),t.jsx("button",{type:"button",onClick:h,className:"rounded-full border border-strong bg-white/[0.03] px-3 py-1.5 text-caption text-secondary transition-colors hover:bg-white/[0.08] hover:text-white",children:"Close"})]})}),t.jsxs("div",{className:"grid gap-4 px-4 pb-4 pt-3 lg:grid-cols-[1.12fr_1fr]",children:[t.jsxs("section",{className:"space-y-3",children:[t.jsxs("div",{className:"rounded-xl border border-strong bg-white/[0.02] p-3",children:[t.jsxs("div",{className:"mb-2 flex items-center justify-between",children:[t.jsx("span",{className:"text-caption uppercase tracking-[0.12em] text-secondary",children:"Session"}),t.jsx("span",{className:"text-micro text-secondary",children:xe})]}),t.jsx("div",{className:"flex flex-wrap items-center gap-2",children:f?t.jsxs(t.Fragment,{children:[t.jsx("button",{type:"button",onMouseDown:ie,onMouseUp:K,onMouseLeave:()=>{S&&K()},onTouchStart:e=>{e.preventDefault(),ie()},onTouchEnd:e=>{e.preventDefault(),K()},className:`rounded-full border px-3 py-1.5 text-caption font-semibold transition-colors ${S?"border-teal/45 bg-teal/[0.16] text-teal":"border-white/[0.2] bg-white/[0.04] text-primary hover:bg-white/[0.1]"}`,children:S?"Listening… release to send":"Hold to talk"}),t.jsx("button",{type:"button",onClick:N,className:"rounded-full border border-strong bg-white/[0.03] px-3 py-1.5 text-caption text-secondary transition-colors hover:bg-white/[0.08] hover:text-primary",children:"Disconnect"})]}):t.jsx("button",{type:"button",disabled:v,onClick:()=>void ye(),className:"rounded-full border border-lime/35 bg-lime/[0.12] px-3 py-1.5 text-caption font-semibold text-lime transition-colors hover:bg-lime/[0.2] disabled:cursor-not-allowed disabled:opacity-60",children:v?"Connecting…":"Connect Realtime"})}),ne.length>0?t.jsx("div",{className:"mt-3 rounded-lg border border-strong bg-black/20 p-2",children:ne.map((e,r)=>t.jsx("p",{className:"text-micro text-secondary",children:e},`${e}-${r}`))}):null]}),t.jsxs("div",{className:"rounded-xl border border-strong bg-white/[0.02] p-3",children:[t.jsx("label",{className:"mb-2 block text-caption uppercase tracking-[0.12em] text-secondary",children:"Command Input"}),t.jsx("textarea",{value:$,onChange:e=>Z(e.target.value),rows:4,"data-modal-autofocus":"true",placeholder:"Example: create initiative called AI Readiness Audit for this workspace",className:"w-full rounded-lg border border-strong bg-[#040912] px-3 py-2 text-body text-primary placeholder:text-secondary focus:border-lime/35 focus:outline-none"}),W?t.jsxs("p",{className:"mt-2 text-caption text-secondary",children:["Assistant: ",t.jsx("span",{className:"text-primary",children:W})]}):null,t.jsxs("div",{className:"mt-3 flex items-center gap-2",children:[t.jsx("button",{type:"button",disabled:ee||$.trim().length===0,onClick:()=>void ge(),className:"rounded-full border border-teal/35 bg-teal/[0.12] px-3 py-1.5 text-caption font-semibold text-teal transition-colors hover:bg-teal/[0.2] disabled:cursor-not-allowed disabled:opacity-60",children:ee?"Previewing…":"Preview Actions"}),t.jsx("button",{type:"button",disabled:!je,onClick:()=>void be(),className:"rounded-full border border-lime/35 bg-lime/[0.12] px-3 py-1.5 text-caption font-semibold text-lime transition-colors hover:bg-lime/[0.2] disabled:cursor-not-allowed disabled:opacity-60",children:re?"Applying…":`Apply (${ce})`})]})]})]}),t.jsxs("section",{className:"space-y-3",children:[t.jsxs("div",{className:"rounded-xl border border-strong bg-white/[0.02] p-3",children:[t.jsxs("div",{className:"mb-2 flex items-center justify-between",children:[t.jsx("span",{className:"text-caption uppercase tracking-[0.12em] text-secondary",children:"Command Status"}),t.jsx("span",{className:`text-caption font-semibold ${_e}`,children:(o==null?void 0:o.status)??"idle"})]}),t.jsx("p",{className:"text-body text-primary",children:(o==null?void 0:o.humanSummary)??"Preview a command or use voice to trigger tool calls."}),(de=o==null?void 0:o.riskFlags)!=null&&de.length?t.jsxs("p",{className:"mt-2 text-caption text-amber-200",children:["Risk flags: ",o.riskFlags.join(", ")]}):null]}),t.jsxs("div",{className:"max-h-[360px] space-y-2 overflow-y-auto rounded-xl border border-strong bg-white/[0.02] p-3",children:[t.jsx("p",{className:"text-caption uppercase tracking-[0.12em] text-secondary",children:"Proposed Actions"}),we?o.proposedActions.map(e=>{const r=T.includes(e.actionId);return t.jsx("label",{className:"block rounded-lg border border-strong bg-[#040912] p-2 text-body",children:t.jsxs("div",{className:"flex items-start gap-2",children:[t.jsx("input",{type:"checkbox",checked:r,onChange:a=>{const d=a.target.checked?[...T,e.actionId]:T.filter(m=>m!==e.actionId);X(d)},className:"mt-1"}),t.jsxs("div",{className:"min-w-0",children:[t.jsx("p",{className:"font-semibold text-primary",children:e.type}),t.jsx("p",{className:"text-caption text-secondary",children:e.reason}),t.jsxs("p",{className:"text-micro text-secondary",children:["confidence ",Ae(e.confidence)," • impact ",e.blockingImpact]})]})]})},e.actionId)}):t.jsx("p",{className:"text-body text-secondary",children:"No actions inferred yet."})]}),(((pe=o==null?void 0:o.results)==null?void 0:pe.length)??0)>0?t.jsxs("div",{className:"max-h-[220px] space-y-2 overflow-y-auto rounded-xl border border-strong bg-white/[0.02] p-3",children:[t.jsx("p",{className:"text-caption uppercase tracking-[0.12em] text-secondary",children:"Apply Results"}),o.results.map(e=>t.jsxs("div",{className:`rounded-lg border p-2 text-body ${e.ok?"border-lime/30 bg-lime/[0.08] text-lime":"border-amber-400/35 bg-amber-500/[0.12] text-amber-100"}`,children:[t.jsx("p",{className:"font-semibold",children:e.type}),t.jsx("p",{className:"text-caption",children:e.message}),e.error?t.jsxs("p",{className:"text-micro text-amber-200",children:["error: ",e.error]}):null]},`${e.actionId}-${e.type}`))]}):null]})]}),se?t.jsx("div",{className:"border-t border-amber-500/30 bg-amber-500/[0.12] px-4 py-2 text-caption text-amber-100",children:se}):null]})}export{Me as RealtimeOrchestratorModal};
|
|
Binary file
|
|
Binary file
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{r as d,j as e}from"./Dj2k1r16.js";import{y as C,E as k,e as m,v as S}from"./
|
|
1
|
+
import{r as d,j as e}from"./Dj2k1r16.js";import{y as C,E as k,e as m,v as S}from"./C8AYbjlq.js";import"./DMKyYAtD.js";import"./eeHXe_OQ.js";import"./cX2e-TLi.js";import"./BjK42gtU.js";import"./BV0BcV1u.js";function $(i){const o=i.trim().toLowerCase();return o==="fulfilled"||o==="completed"?m.lime:o==="claimed"?m.teal:o==="blocked"?m.red:m.amber}function z({open:i,onClose:o,handoffs:x}){const[p,g]=d.useState(""),[c,h]=d.useState(new Set),[y,n]=d.useState(null);d.useEffect(()=>{i&&n(null)},[i]);const b=d.useMemo(()=>[...x].sort((t,s)=>Date.parse(s.updatedAt??"")-Date.parse(t.updatedAt??"")),[x]),r=d.useMemo(()=>{const t=p.trim().toLowerCase();return t?b.filter(s=>[s.title,s.summary,s.status,s.priority].filter(Boolean).join(" ").toLowerCase().includes(t)):b},[b,p]);d.useEffect(()=>{i&&h(t=>{const s=new Set(r.map(a=>a.id)),l=new Set;for(const a of t)s.has(a)&&l.add(a);return l})},[r,i]);const u=c.size,f=r.length>0&&r.every(t=>c.has(t.id)),w=()=>{h(t=>r.length===0?t:f?new Set:new Set(r.map(s=>s.id)))},j=t=>{h(s=>{const l=new Set(s);return l.has(t)?l.delete(t):l.add(t),l})},N=async()=>{const t=r.filter(a=>u===0||c.has(a.id)),s=[];s.push(`# Handoffs (${t.length})`),s.push("");for(const a of t)s.push(`- **${a.title}** — ${a.status}${a.priority?` (priority: ${a.priority})`:""}`),a.summary&&s.push(` - ${a.summary}`),s.push(` - Updated: ${a.updatedAt}`);const l=s.join(`
|
|
2
2
|
`);try{await navigator.clipboard.writeText(l),n("Copied markdown."),setTimeout(()=>n(null),1200)}catch{n("Copy failed (clipboard unavailable).")}},v=async()=>{const t=r.filter(s=>u===0||c.has(s.id));try{await navigator.clipboard.writeText(JSON.stringify(t,null,2)),n("Copied JSON."),setTimeout(()=>n(null),1200)}catch{n("Copy failed (clipboard unavailable).")}};return e.jsx(C,{open:i,onClose:o,maxWidth:"max-w-3xl",children:e.jsxs("div",{className:"flex h-full w-full flex-col",children:[e.jsxs("div",{className:"border-b border-subtle px-5 pt-5 pb-4",children:[e.jsxs("div",{className:"flex items-start justify-between gap-3",children:[e.jsxs("div",{className:"min-w-0",children:[e.jsxs("h3",{className:"inline-flex items-center gap-2 text-heading font-semibold text-white",children:[e.jsx(k,{type:"handoff",size:14}),e.jsx("span",{className:"truncate",children:"Handoffs"}),e.jsx("span",{className:"rounded-full border border-strong bg-white/[0.04] px-2 py-0.5 text-caption font-semibold text-primary",children:x.length})]}),e.jsx("p",{className:"mt-1 text-body leading-relaxed text-secondary",children:"Review and export current handoffs. Select items for a tighter export."})]}),e.jsx("button",{type:"button",onClick:o,className:"rounded-md border border-strong bg-white/[0.03] px-2.5 py-1.5 text-caption text-primary transition-colors hover:bg-white/[0.08]","aria-label":"Close handoffs modal",children:"Close"})]}),e.jsxs("div",{className:"mt-4 flex flex-col gap-2 sm:flex-row sm:items-center",children:[e.jsxs("div",{className:"flex-1",children:[e.jsx("label",{className:"sr-only",htmlFor:"bulk-handoffs-search",children:"Search handoffs"}),e.jsx("input",{id:"bulk-handoffs-search",value:p,onChange:t=>g(t.target.value),placeholder:"Search title, summary, status…","data-modal-autofocus":"true",className:"w-full rounded-lg border border-strong bg-black/25 px-3 py-2 text-body text-white placeholder:text-muted focus:outline-none focus:ring-1 focus:ring-[#BFFF00]/35"})]}),e.jsx("button",{type:"button",onClick:w,disabled:r.length===0,className:"rounded-lg border border-strong bg-white/[0.03] px-3 py-2 text-caption text-primary transition-colors hover:bg-white/[0.08] disabled:opacity-45",children:f?"Clear all":`Select all (${r.length})`})]}),y&&e.jsx("div",{className:"mt-3 rounded-xl border border-white/[0.08] bg-white/[0.02] px-3 py-2 text-body text-secondary",children:y})]}),e.jsx("div",{className:"min-h-0 flex-1 overflow-y-auto px-5 py-4",children:r.length===0?e.jsx("div",{className:"rounded-xl border border-subtle bg-white/[0.02] p-4 text-body text-secondary",children:"No handoffs match this view."}):e.jsx("div",{className:"space-y-2",children:r.map(t=>{const s=c.has(t.id),l=$(t.status);return e.jsx("div",{className:"rounded-xl border border-white/[0.08] bg-white/[0.02] px-3 py-2.5",style:{borderColor:s?`${m.lime}40`:"rgba(255,255,255,0.08)"},children:e.jsxs("div",{className:"flex items-start gap-3",children:[e.jsx("input",{type:"checkbox",checked:s,onChange:()=>j(t.id),className:"mt-0.5 h-4 w-4 rounded border-white/20 bg-black/40 text-lime focus:ring-lime/40","aria-label":`Select handoff ${t.title}`}),e.jsx("div",{className:"min-w-0 flex-1",children:e.jsxs("div",{className:"flex items-start justify-between gap-3",children:[e.jsxs("div",{className:"min-w-0",children:[e.jsx("p",{className:"truncate text-body font-medium text-white",children:t.title}),t.summary&&e.jsx("p",{className:"mt-1 line-clamp-2 text-caption text-secondary",children:t.summary}),e.jsxs("p",{className:"mt-1 text-micro text-secondary",children:["Updated ",S(t.updatedAt)]})]}),e.jsx("span",{className:"shrink-0 rounded-full border px-2 py-0.5 text-micro font-semibold uppercase tracking-[0.08em]",style:{borderColor:`${l}30`,backgroundColor:`${l}14`,color:l},children:t.status})]})})]})},t.id)})})}),e.jsxs("div",{className:"flex flex-col gap-2 border-t border-subtle px-5 py-3 sm:flex-row sm:items-center sm:justify-between",children:[e.jsx("div",{className:"text-caption text-secondary",children:u>0?`${u} selected`:"No selection (exporting will include all filtered handoffs)"}),e.jsxs("div",{className:"flex flex-wrap items-center justify-end gap-2",children:[e.jsx("button",{type:"button",onClick:N,disabled:r.length===0,className:"rounded-md border border-strong bg-white/[0.03] px-3 py-1.5 text-caption text-primary transition-colors hover:bg-white/[0.08] disabled:opacity-45",children:"Copy markdown"}),e.jsx("button",{type:"button",onClick:v,disabled:r.length===0,className:"rounded-md border border-strong bg-white/[0.03] px-3 py-1.5 text-caption text-primary transition-colors hover:bg-white/[0.08] disabled:opacity-45",children:"Copy JSON"})]})]})]})})}export{z as BulkHandoffsModal};
|
|
Binary file
|
|
Binary file
|