tide-commander 1.76.2 → 1.78.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (35) hide show
  1. package/dist/assets/{BossLogsModal-B41BvcEF.js → BossLogsModal-BJUaVgOz.js} +1 -1
  2. package/dist/assets/{BossSpawnModal-DUTcju8I.js → BossSpawnModal-CLzUp9FQ.js} +1 -1
  3. package/dist/assets/{ControlsModal-DbiIdKPt.js → ControlsModal-BK-nIx6P.js} +1 -1
  4. package/dist/assets/{DockerLogsModal-5mrsMmlQ.js → DockerLogsModal-wW7EV327.js} +1 -1
  5. package/dist/assets/{EmbeddedEditor-DirMT3E8.js → EmbeddedEditor-B7LC5gF5.js} +1 -1
  6. package/dist/assets/{GmailOAuthSetup-CmGKGxui.js → GmailOAuthSetup-C_kETU4w.js} +1 -1
  7. package/dist/assets/{GoogleOAuthSetup-CbWwCAK0.js → GoogleOAuthSetup-Dn1hZsMs.js} +1 -1
  8. package/dist/assets/{IframeModal-Dboa4JXN.js → IframeModal-8t96ASFF.js} +1 -1
  9. package/dist/assets/{IntegrationsPanel-DS28YNJo.js → IntegrationsPanel-C0TjN-6q.js} +2 -2
  10. package/dist/assets/{LogViewerModal-UbrMLs2v.js → LogViewerModal-J_Wv4RxY.js} +1 -1
  11. package/dist/assets/{MonitoringModal-B_XI1vTS.js → MonitoringModal-CUy6EbeR.js} +1 -1
  12. package/dist/assets/{PM2LogsModal-ChvPf5Uv.js → PM2LogsModal-CgYX33GL.js} +1 -1
  13. package/dist/assets/{RestoreArchivedAreaModal-CEq_4zoQ.js → RestoreArchivedAreaModal-ILOa64df.js} +1 -1
  14. package/dist/assets/{Scene2DCanvas-DYDA_fv5.js → Scene2DCanvas-B9_c0Cr2.js} +1 -1
  15. package/dist/assets/{SceneManager-Be_I2Z9r.js → SceneManager-BuMbzzM8.js} +1 -1
  16. package/dist/assets/{SkillsPanel-CNIkJScD.js → SkillsPanel-Bp0UiQRG.js} +1 -1
  17. package/dist/assets/{SpawnModal-BXV32TQn.js → SpawnModal-DjzhiAMO.js} +1 -1
  18. package/dist/assets/{SubordinateAssignmentModal-DK3uJtBR.js → SubordinateAssignmentModal-CWaAMKp5.js} +1 -1
  19. package/dist/assets/{TriggerManagerPanel-C8JheOOO.js → TriggerManagerPanel-DpCFDRa5.js} +1 -1
  20. package/dist/assets/{WorkflowEditorPanel-DeLnt3ou.js → WorkflowEditorPanel-D-Vcfxmm.js} +1 -1
  21. package/dist/assets/{index-C-HNvKyN.js → index-1yqGGDiA.js} +1 -1
  22. package/dist/assets/{index-B7BnOlMV.js → index-7TaAASV1.js} +2 -2
  23. package/dist/assets/{index-CymWdB1l.js → index-BRLyVoUe.js} +1 -1
  24. package/dist/assets/{index-D6ez6g4v.js → index-BeUHeagl.js} +1 -1
  25. package/dist/assets/{index-BR3DNqtn.js → index-COln_-Fk.js} +1 -1
  26. package/dist/assets/index-D6--gGWa.js +2 -0
  27. package/dist/assets/{index-DXjESpea.js → index-DX-7fZ78.js} +3 -3
  28. package/dist/assets/{index-BZFjiZW2.js → index-DyidqysN.js} +1 -1
  29. package/dist/assets/{index-C2QVwmIa.js → index-rGRqmeiB.js} +1 -1
  30. package/dist/assets/{main-BvvvhWnd.js → main-COvyQg-T.js} +89 -89
  31. package/dist/assets/{web-B-5bt6Uj.js → web-CpCf-DCG.js} +1 -1
  32. package/dist/assets/{web-Dyi_JNTJ.js → web-N_FykYu_.js} +1 -1
  33. package/dist/index.html +1 -1
  34. package/package.json +1 -1
  35. package/dist/assets/index-DHlpIGVI.js +0 -2
@@ -1,4 +1,4 @@
1
- import{b9 as Oe,r as t,s as I,l as ye,ba as Ee,aE as _e,j as e,I as z,u as fe,bb as ze,bc as Te,bd as Be,be as Ue,m as Ke,bf as We,bg as De,bh as Ve,$ as Ge,a0 as qe,bi as Ye,aN as Je,E as Me,S as ce,aH as Xe,aD as Qe,V as Ze,G as Ie,ab as et,N as tt,bj as st,n as X,bk as nt}from"./main-BvvvhWnd.js";import{F as at}from"./index-DXjESpea.js";import"./vendor-react--Eh9ivFN.js";import"./vendor-three-Chj50gSY.js";const Se={status:"all",activity:"all",sort:"activity"},lt={"1h":3600*1e3,"6h":360*60*1e3,"24h":1440*60*1e3},Ae=20,me=3,ct={idle:"#4aff9e",working:"#4a9eff",waiting:"#ff9e4a",waiting_permission:"#ffcc00",error:"#ff4a4a",offline:"#888888",orphaned:"#ff9e4a"},ot=12e4;function rt(s){return s.trim().replace(/\r\n/g,`
1
+ import{b9 as Oe,r as t,s as I,l as ye,ba as Ee,aE as _e,j as e,I as z,u as fe,bb as ze,bc as Te,bd as Be,be as Ue,m as Ke,bf as We,bg as De,bh as Ve,$ as Ge,a0 as qe,bi as Ye,aN as Je,E as Me,S as ce,aH as Xe,aD as Qe,V as Ze,G as Ie,ab as et,N as tt,bj as st,n as X,bk as nt}from"./main-COvyQg-T.js";import{F as at}from"./index-DX-7fZ78.js";import"./vendor-react--Eh9ivFN.js";import"./vendor-three-Chj50gSY.js";const Se={status:"all",activity:"all",sort:"activity"},lt={"1h":3600*1e3,"6h":360*60*1e3,"24h":1440*60*1e3},Ae=20,me=3,ct={idle:"#4aff9e",working:"#4a9eff",waiting:"#ff9e4a",waiting_permission:"#ffcc00",error:"#ff4a4a",offline:"#888888",orphaned:"#ff9e4a"},ot=12e4;function rt(s){return s.trim().replace(/\r\n/g,`
2
2
  `)}function $e(s,a){return`${s}:${rt(a)}`}function it(s,a,l,f){if(s.uuid&&a.has(s.uuid))return!1;if(s.uuid)return!0;const p=s.isUserPrompt?"user":"assistant",d=$e(p,s.text),M=s.timestamp||0,A=l.get(d);return A!==void 0&&Math.abs(M-A)<=ot?!1:M>f}function dt({isOpen:s,agents:a}){const l=Oe(),[f,p]=t.useState(new Map),d=t.useRef(new Set);t.useRef(a);const M=t.useMemo(()=>Array.from(a.keys()).sort().join(","),[a]),A=t.useMemo(()=>Array.from(a.values()).map(j=>`${j.id}:${j.sessionId||""}`).sort().join(","),[a]);t.useEffect(()=>{s||(d.current.clear(),p(new Map))},[s]),t.useEffect(()=>{if(!s)return;const j=new Set(Array.from(a.keys()));for(const i of d.current)j.has(i)||d.current.delete(i);let h=null;l>0&&(h=I.preserveOutputs(),d.current.clear());const v=async(i,C,F=0)=>{if(d.current.add(i.id),F>0&&await new Promise(x=>setTimeout(x,F)),p(x=>{const k=new Map(x);return k.set(i.id,{agentId:i.id,messages:[],loading:!0,hasMore:!1,totalCount:0}),k}),!i.sessionId){C&&C.length>0&&I.mergeOutputsWithHistory(i.id,[],C),p(x=>{const k=new Map(x);return k.set(i.id,{agentId:i.id,messages:[],loading:!1,hasMore:!1,totalCount:0}),k});return}try{const k=await(await _e(ye(`/api/agents/${i.id}/history?limit=${Ee}&offset=0`))).json(),P=k.messages||[],W=P.length>0?Math.max(...P.map(w=>w.timestamp?new Date(w.timestamp).getTime():0)):0,Y=new Set(P.map(w=>w.uuid).filter(w=>!!w)),V=new Map;for(const w of P){if(w.type!=="user"&&w.type!=="assistant")continue;const o=$e(w.type,w.content),L=w.timestamp?new Date(w.timestamp).getTime():0,K=V.get(o)??0;L>K&&V.set(o,L)}const G=I.getOutputs(i.id),U=(C&&C.length>0?[...C,...G]:G).filter(w=>it(w,Y,V,W));I.clearOutputs(i.id);for(const w of U)I.addOutput(i.id,w);p(w=>{const o=new Map(w);return o.set(i.id,{agentId:i.id,messages:P,loading:!1,hasMore:k.hasMore||!1,totalCount:k.totalCount||0}),o})}catch(x){if(console.error(`Failed to load history for ${i.name}:`,x),C&&C.length>0){I.clearOutputs(i.id);for(const k of C)I.addOutput(i.id,k)}p(k=>{const P=new Map(k);return P.set(i.id,{agentId:i.id,messages:[],loading:!1,hasMore:!1,totalCount:0}),P})}},u=l>0?500:0,D=Array.from(a.values());for(const i of D)if(!d.current.has(i.id)){const C=h==null?void 0:h.get(i.id);v(i,C,u)}},[s,M,A,l]);const R=t.useRef(a),S=t.useRef(f);R.current=a,S.current=f;const b=t.useCallback(async j=>{const h=R.current.get(j),v=S.current.get(j);if(!(h!=null&&h.sessionId)||!v||!v.hasMore)return;const u=v.messages.length;try{const i=await(await fetch(ye(`/api/agents/${j}/history?limit=${Ee}&offset=${u}`))).json();i.messages&&i.messages.length>0&&p(C=>{const F=new Map(C),x=C.get(j);return x&&F.set(j,{...x,messages:[...i.messages,...x.messages],hasMore:i.hasMore||!1}),F})}catch(D){console.error(`Failed to load more history for agent ${j}:`,D)}},[]),E=t.useCallback(j=>{d.current.delete(j),p(h=>{const v=new Map(h),u=h.get(j);return u&&v.set(j,{...u,messages:[],hasMore:!1,totalCount:0,loading:!1}),v})},[]);return{histories:f,loadMoreHistory:b,clearAgentHistory:E}}function ut({command:s,onCommandChange:a,useTextarea:l,forceTextarea:f,onForceTextarea:p,onSend:d,canSend:M,attachedFiles:A,onAddFile:R,onRemoveFile:S,uploadFile:b,onAddPastedText:E,placeholder:j="Message...",className:h="",compact:v=!1,inputRef:u}){const D=t.useRef(null),i=t.useRef(null),C=t.useRef(l);t.useEffect(()=>{if(l&&!C.current&&i.current){const o=i.current;o.focus(),o.selectionStart=o.selectionEnd=o.value.length}C.current=l},[l]),t.useEffect(()=>{const o=i.current;if(!o||!l)return;o.style.height="auto";const L=v?120:180,K=Math.min(o.scrollHeight,L);o.style.height=`${K}px`},[s,l,v]);const F=t.useCallback(async o=>{const L=o.clipboardData.items;for(const _ of L)if(_.type.startsWith("image/")){o.preventDefault();const $=_.getAsFile();if($){const H=await b($);H&&R(H)}return}const K=o.clipboardData.files;if(K.length>0){o.preventDefault();for(const _ of K){const $=await b(_);$&&R($)}return}const B=o.clipboardData.getData("text"),te=(B.match(/\n/g)||[]).length+1;if(te>5){o.preventDefault();const $=`[Pasted text #${E(B)} +${te} lines]`,H=o.target,se=H.selectionStart||0,ae=H.selectionEnd||0,ne=s.slice(0,se)+$+s.slice(ae);a(ne),l||p(!0)}},[s,a,l,p,b,R,E]),x=t.useCallback(async o=>{const L=o.target.files;if(L){for(const K of L){const B=await b(K);B&&R(B)}D.current&&(D.current.value="")}},[b,R]),k=t.useCallback(o=>{if(o.key==="Enter"&&o.shiftKey){l||(o.preventDefault(),p(!0));return}o.key==="Enter"&&(o.preventDefault(),d())},[l,p,d]),P=t.useCallback(o=>{},[]),W=t.useCallback(o=>{o.button===1&&(o.preventDefault(),o.stopPropagation())},[]),Y=t.useCallback(o=>{i.current=o,u==null||u(o)},[u]),V=v?"agent-panel-input":"guake-input",G=v?"agent-panel-input-container":"guake-input-container",Q=v?"agent-panel-attach-btn":"guake-attach-btn",U=v?"agent-panel-send-btn":"",w=l?v?"agent-panel-input-expanded":"guake-input-expanded":"";return e.jsxs(e.Fragment,{children:[A.length>0&&e.jsx("div",{className:v?"agent-panel-attachments":"guake-attachments",children:A.map(o=>e.jsxs("div",{className:`${v?"agent-panel-attachment":"guake-attachment"} ${o.isImage?"is-image":""}`,children:[e.jsx("span",{className:v?"agent-panel-attachment-icon":"guake-attachment-icon",children:e.jsx(z,{name:o.isImage?"file":"paperclip",size:12})}),e.jsx("span",{className:v?"agent-panel-attachment-name":"guake-attachment-name",title:o.path,children:o.name}),!v&&e.jsxs("span",{className:"guake-attachment-size",children:["(",Math.round(o.size/1024),"KB)"]}),e.jsx("button",{className:v?"agent-panel-attachment-remove":"guake-attachment-remove",onClick:()=>S(o.id),title:"Remove",children:"×"})]},o.id))}),e.jsxs("div",{className:`${V} ${w} ${h}`,children:[e.jsx("input",{ref:D,type:"file",multiple:!0,onChange:x,style:{display:"none"},accept:"*"}),e.jsxs("div",{className:G,onAuxClick:W,children:[e.jsx("button",{className:Q,onClick:()=>{var o;return(o=D.current)==null?void 0:o.click()},title:"Attach file (or paste image)",children:e.jsx(z,{name:"paperclip",size:14})}),l?e.jsx("textarea",{ref:Y,placeholder:j,value:s,onChange:o=>a(o.target.value),onKeyDown:k,onPaste:F,onMouseDown:P}):e.jsx("input",{ref:u,type:"text",placeholder:j,value:s,onChange:o=>a(o.target.value),onKeyDown:k,onPaste:F,onMouseDown:P}),e.jsx("button",{className:U,onClick:d,disabled:!M,title:"Send",children:e.jsx(z,{name:"send",size:14})})]})]})]})}function mt(s){const a=Math.floor(s/1e3),l=Math.floor(a/60),f=a%60;return`${l}:${f.toString().padStart(2,"0")}`}const ft=t.memo(function({agentId:a,isWorking:l,timestamp:f}){const{t:p}=fe(["terminal"]),[d,M]=t.useState(0);return t.useEffect(()=>{if(!l||!f){M(0);return}M(Date.now()-f);const A=setInterval(()=>{M(Date.now()-f)},1e3);return()=>clearInterval(A)},[l,f]),l?e.jsxs("div",{className:"guake-stop-bar",children:[e.jsx("span",{className:"guake-elapsed-timer",children:mt(d)}),e.jsxs("button",{className:"guake-stop-btn",onClick:()=>I.stopAgent(a),title:p("terminal:input.stopOperation"),children:[e.jsx("span",{className:"stop-icon",children:e.jsx(z,{name:"stop",size:12,weight:"fill"})}),e.jsx("span",{className:"stop-label",children:p("terminal:input.stop")})]})]}):null});function pt({agent:s,history:a,outputs:l,isExpanded:f,isFocused:p,advancedView:d,onExpand:M,onFocus:A,inputRef:R,onLoadMore:S,onClearHistory:b}){const{t:E}=fe(["terminal","common"]),j=ze(s.id),h=t.useRef(null),[v,u]=t.useState(!1),D=t.useRef(0),i=t.useRef(!1),[C,F]=t.useState(!0),[x,k]=t.useState(!1),[P,W]=t.useState(null),[Y,V]=t.useState(null),[G,Q]=t.useState(null);Te(`commander-image-modal-${s.id}`,P!==null,()=>W(null));const{command:U,setCommand:w,forceTextarea:o,setForceTextarea:L,useTextarea:K,setPastedTexts:B,incrementPastedCount:te,resetPastedCount:_,attachedFiles:$,setAttachedFiles:H,removeAttachedFile:se,uploadFile:ae,expandPastedTexts:ne}=Be({selectedAgentId:s.id}),le=U.trim().length>0||$.length>0,n=Ue({outputs:l,viewMode:d?"advanced":"simple"}),c=t.useMemo(()=>{const N=Ke(s);return{usedPercent:N.usedPercent,freePercent:N.freePercent,hasData:!!s.contextStats,totalTokens:N.totalTokens,contextWindow:N.contextWindow}},[s.contextStats,s.contextUsed,s.contextLimit]),g=t.useCallback(()=>{!v&&(a!=null&&a.hasMore)&&S&&(u(!0),D.current=h.current?h.current.scrollHeight-h.current.scrollTop:0,S())},[v,a==null?void 0:a.hasMore,S]);t.useEffect(()=>{v&&a&&!a.loading&&u(!1)},[a,v]);const m=t.useCallback(()=>{i.current=!0,F(!1)},[]),T=t.useRef(f),Z=t.useRef(p);t.useEffect(()=>{(f&&!T.current||p&&!Z.current)&&(i.current=!1,F(!0),k(!0)),T.current=f,Z.current=p},[f,p]);const ee=t.useRef(a==null?void 0:a.loading);t.useEffect(()=>{ee.current&&!(a!=null&&a.loading)&&(i.current=!1,F(!0),k(!0)),ee.current=a==null?void 0:a.loading},[a==null?void 0:a.loading]),t.useEffect(()=>{if(!x)return;const N=h.current;if(!N)return;const y=performance.now();let O=0,ue=-1,ke;const Re=()=>{const{scrollTop:Fe,scrollHeight:Ne,clientHeight:Le}=N,He=Ne-Fe-Le<=2;if(Math.abs(Ne-ue)<=1&&He?O+=1:O=0,ue=Ne,O>=3){k(!1);return}if(performance.now()-y>5e3){k(!1);return}ke=requestAnimationFrame(Re)};return ke=requestAnimationFrame(Re),()=>cancelAnimationFrame(ke)},[x]),t.useEffect(()=>{i.current||F(!0)},[n.length]);const q=t.useCallback(()=>!1,[]),ie=t.useCallback(N=>{const y=te();return B(O=>new Map(O).set(y,N)),y},[te,B]),he=t.useCallback(N=>{H(y=>[...y,N])},[H]),xe=t.useCallback(()=>{if(!le)return;if(U.trim()==="/clear"&&$.length===0){I.clearContext(s.id),b(),w(""),L(!1),B(new Map),H([]),_();return}let N=ne(U.trim());if($.length>0){const y=$.map(O=>O.isImage?`[Image: ${O.path}]`:`[File: ${O.path}]`).join(`
3
3
  `);N=N?`${N}
4
4
 
@@ -0,0 +1,2 @@
1
+ import{u as Rt,z as Lt,B as zt,r as n,E as wt,S as j,G as Ct,H as gt,J as jt,K as Qe,L as we,M as $t,s as C,N as At,O as Ot,v as Ft,w as Wt,j as e,I as m,P as Bt,m as Ht,U as Gt,V as St,W as It,X as Vt,Y as Xt,Z as Ut,_ as qt,$ as Kt,a0 as Yt,a1 as Zt,a2 as Jt,a3 as Qt,C as ea,a4 as ta,a5 as aa,a6 as na,a7 as sa,a8 as ra,a9 as la,aa as ia,ab as oa,ac as ca,ad as da,ae as ua,af as pa,ag as ma,ah as fa,ai as ha,aj as ga,ak as xa}from"./main-COvyQg-T.js";import"./vendor-react--Eh9ivFN.js";import"./vendor-three-Chj50gSY.js";const et=3,tt=280,vt=320,ht=240,Nt=64,_a=["simple","chat","advanced"],ba={simple:"Simple",chat:"Chat",advanced:"Advanced"},wa={simple:"○",chat:"◐",advanced:"◉"},Ca={simple:"Simple view — clean messages only",chat:"Chat view — assistant replies (no tool calls)",advanced:"Advanced view — everything including tools"},kt="flat-clear-context";function ja(x){const d=x.split("/").filter(Boolean);return d.length===0?x:d.slice(-2).join("/")}function va(x){if(x.provider==="codex"){const ue=x.codexModel||"gpt-5.3-codex",$=ha[ue];return{model:($==null?void 0:$.label)||ue}}if(x.provider==="opencode")return{model:x.opencodeModel||"opencode"};const d=x.model||"sonnet",v=xa[d],T=x.effort,z=T?ga[T]:void 0;return{model:(v==null?void 0:v.label)||d,effort:z==null?void 0:z.label}}function Na(x,d){if(d.type==="rectangle"&&d.width&&d.height){const v=d.width/2,T=d.height/2;return x.x>=d.center.x-v&&x.x<=d.center.x+v&&x.z>=d.center.z-T&&x.z<=d.center.z+T}if(d.type==="circle"&&d.radius){const v=x.x-d.center.x,T=x.z-d.center.z;return v*v+T*T<=d.radius*d.radius}return!1}const ka=ta.memo(function({agentId:d,terminalViewMode:v,onTerminalViewModeChange:T,inspectorOpen:z,onToggleInspector:ue,onImageClick:$,onFileClick:M,onBashClick:Ce,onViewMarkdown:je,onRequestClearSubordinates:De,onOpenBuilding:ve,keyboard:Re,canNavigateBack:Ne,canNavigateForward:Le,onNavigateBack:E,onNavigateForward:K,agentInfoOpen:O,onToggleAgentInfo:ze}){var Ve,P,ce,Xe;const p=aa(d),R=na(),pe=n.useRef(null),ke=n.useRef(null);n.useEffect(()=>{const r=ke.current;if(!r)return;const i=o=>{o.button===3?(o.preventDefault(),o.stopPropagation(),E()):o.button===4&&(o.preventDefault(),o.stopPropagation(),K())},c=o=>{(o.button===3||o.button===4)&&o.preventDefault()};return r.addEventListener("mouseup",i),r.addEventListener("mousedown",c),()=>{r.removeEventListener("mouseup",i),r.removeEventListener("mousedown",c)}},[E,K]),n.useEffect(()=>{const r=ke.current;if(!r)return;let i=0,c=0,o=0;const ge=250,xe=600,se=80,Ue=1.5,ut=D=>{let N=D instanceof HTMLElement?D:null;for(;N&&N!==r;){const qe=window.getComputedStyle(N).overflowX;if((qe==="auto"||qe==="scroll")&&N.scrollWidth>N.clientWidth)return!0;N=N.parentElement}return!1},ye=D=>{const N=Date.now();if(N<o){D.preventDefault();return}if(Math.abs(D.deltaX)<=Math.abs(D.deltaY)*Ue){i=0;return}if(ut(D.target)){i=0;return}N-c>ge&&(i=0),c=N,i+=D.deltaX,i<=-se?(i=0,o=N+xe,D.preventDefault(),E()):i>=se&&(i=0,o=N+xe,D.preventDefault(),K())};return r.addEventListener("wheel",ye,{passive:!1}),()=>r.removeEventListener("wheel",ye)},[E,K]);const Ae=At(),me=n.useMemo(()=>{if(!p)return null;const r=new Set,i=[];for(const c of Ae.values())c.archived||c.directories.length===0||c.assignedAgentIds.includes(d)&&(r.add(c.id),i.push(c));for(const c of Ae.values())c.archived||c.directories.length===0||r.has(c.id)||Na({x:p.position.x,z:p.position.z},c)&&(r.add(c.id),i.push(c));return i.length===0?null:i.flatMap(c=>c.directories.filter(o=>o&&o.trim().length>0).map(o=>({areaId:c.id,areaName:c.name,dir:o})))},[p,d,Ae]),{branches:$e,fetchRemote:Se,fetchingDirs:Ie}=sa(me),B=n.useMemo(()=>{var c;const r=C.getAreaForAgent(d);if(!r)return[];const i=[];for(const o of R.values())o.type==="terminal"&&C.isPositionInArea(o.position,r)&&i.push({id:o.id,name:o.name,hasUrl:!!((c=o.terminalStatus)!=null&&c.url)});return i},[d,R]),fe=n.useMemo(()=>{var c;const r=C.getAreaForAgent(d);if(!r)return[];const i=[];for(const o of R.values())o.type==="server"&&((c=o.pm2)!=null&&c.enabled)&&C.isPositionInArea(o.position,r)&&i.push({id:o.id,name:o.name});return i},[d,R]),Oe=n.useMemo(()=>{const r=C.getAreaForAgent(d);if(!r)return[];const i=[];for(const c of R.values())c.type==="database"&&c.database&&C.isPositionInArea(c.position,r)&&i.push({id:c.id,name:c.name});return i},[d,R]),[,at]=n.useReducer(r=>r+1,0),H=((Ve=pe.current)==null?void 0:Ve.search.searchMode)??!1,re=n.useCallback(()=>{var r;(r=pe.current)==null||r.search.toggleSearch(),at()},[]),Y=ra(),Z=Y.isPending(kt),[A,G]=n.useState(null),y=A?R.get(A):null,{height:J,onResizeStart:nt}=la(),[le,Me]=n.useState(()=>gt(j.GIT_PANEL_OPEN,!1)),[F,Fe]=n.useState(()=>gt(j.BUILDINGS_PANEL_OPEN,!1)),[ie,Q]=n.useState(!1),st=n.useCallback(()=>{Q(r=>{const i=!r;return i&&ia.setEnabled(!0),i})},[]),We=n.useCallback(()=>Q(!1),[]),rt=n.useCallback(()=>{Me(r=>{const i=!r;return we(j.GIT_PANEL_OPEN,i),i})},[]),lt=n.useCallback(()=>{Fe(r=>{const i=!r;return we(j.BUILDINGS_PANEL_OPEN,i),i})},[]),it=n.useCallback(()=>{Me(!1),we(j.GIT_PANEL_OPEN,!1)},[]),ot=n.useCallback(()=>{Fe(!1),we(j.BUILDINGS_PANEL_OPEN,!1)},[]),ct=oa();n.useEffect(()=>{if(!A)return;B.some(i=>i.id===A)||G(null)},[A,B]);const[oe,ee]=n.useState(!1),Ee=n.useRef(null);if(n.useEffect(()=>{if(!oe)return;const r=i=>{Ee.current&&!Ee.current.contains(i.target)&&ee(!1)};return document.addEventListener("mousedown",r),()=>document.removeEventListener("mousedown",r)},[oe]),!p)return e.jsx("div",{className:"flat-chat flat-chat--empty",children:e.jsxs("div",{className:"flat-chat__placeholder",children:[e.jsx("span",{className:"flat-chat__placeholder-icon",children:"💬"}),e.jsx("span",{className:"flat-chat__placeholder-text",children:"Select an agent to start chatting"})]})});const V=p.contextStats,u=!!V,X=V?V.totalTokens:p.contextUsed||0,L=V?V.contextWindow:p.contextLimit||2e5,he=V?V.usedPercent:Math.round(X/L*100),U=Math.max(0,Math.min(100,he)),dt=Math.max(0,100-U),Be=U>=80?"#ff4a4a":U>=60?"#ff9e4a":U>=40?"#ffd700":"#4aff9e",He=(X/1e3).toFixed(1),Ge=(L/1e3).toFixed(1),q=p.cwd,te=q?ja(q):null,ae=((P=p.subordinateIds)==null?void 0:P.length)||0,ne=ae>0;return e.jsxs("div",{ref:ke,className:`flat-terminal-wrapper ${le||F||ie?"flat-terminal-wrapper--with-side-panel":""}`,children:[e.jsxs("div",{className:"flat-terminal-wrapper__header",children:[e.jsxs("button",{type:"button",className:`flat-terminal-wrapper__header-main ${O?"flat-terminal-wrapper__header-main--active":""}`,onClick:ze,title:O?"Hide agent info":"Show agent info","aria-pressed":O,children:[e.jsx(St,{agent:p,size:28}),e.jsxs("span",{className:"flat-terminal-wrapper__header-info",children:[e.jsx("span",{className:"flat-terminal-wrapper__header-name",children:p.name}),e.jsx("span",{className:"flat-terminal-wrapper__header-status",style:{color:It(p.status)},children:p.status})]}),p.taskLabel&&e.jsxs("span",{className:"flat-terminal-wrapper__header-task",title:p.taskLabel,children:["📋 ",p.taskLabel]}),e.jsxs("span",{className:"flat-terminal-wrapper__header-model",children:[e.jsx("img",{src:p.provider==="codex"?"/assets/codex.png":p.provider==="opencode"?"/assets/opencode.png":"/assets/claude.png",alt:p.provider,className:"flat-terminal-wrapper__header-provider-icon",title:p.provider==="codex"?"Codex Agent":p.provider==="opencode"?"OpenCode Agent":"Claude Agent"}),(()=>{const{model:r,effort:i}=va(p);return e.jsxs("span",{className:"flat-terminal-wrapper__header-model-chip",title:i?`Model: ${r} · Effort: ${i}`:`Model: ${r}`,children:[e.jsx("span",{className:"flat-terminal-wrapper__header-model-name",children:r}),i&&e.jsxs(e.Fragment,{children:[e.jsx("span",{className:"flat-terminal-wrapper__header-model-sep","aria-hidden":"true",children:"·"}),e.jsx("span",{className:"flat-terminal-wrapper__header-model-effort",children:i})]})]})})()]})]}),e.jsxs("div",{className:"flat-terminal-wrapper__header-meta",children:[e.jsx("div",{className:"flat-terminal-wrapper__view-mode",role:"group","aria-label":"Message view mode",children:_a.map(r=>e.jsxs("button",{type:"button",className:`flat-terminal-wrapper__view-mode-btn ${v===r?"flat-terminal-wrapper__view-mode-btn--active":""}`,onClick:()=>T(r),title:Ca[r],"aria-pressed":v===r,children:[e.jsx("span",{className:"flat-terminal-wrapper__view-mode-icon","aria-hidden":"true",children:wa[r]}),e.jsx("span",{className:"flat-terminal-wrapper__view-mode-label",children:ba[r]})]},r))}),e.jsxs("div",{className:"flat-terminal-wrapper__actions",role:"group","aria-label":"Terminal actions",children:[e.jsx("button",{type:"button",className:"flat-terminal-wrapper__action-btn",onClick:E,disabled:!Ne,title:"Back to previous agent","aria-label":"Back to previous agent",children:e.jsx(m,{name:"arrow-left",size:14})}),e.jsx("button",{type:"button",className:"flat-terminal-wrapper__action-btn",onClick:K,disabled:!Le,title:"Forward to next agent","aria-label":"Forward to next agent",children:e.jsx(m,{name:"arrow-right",size:14})}),e.jsx("button",{type:"button",className:`flat-terminal-wrapper__action-btn ${H?"flat-terminal-wrapper__action-btn--active":""}`,onClick:re,title:H?"Close search":"Search messages","aria-pressed":H,children:e.jsx(m,{name:H?"cross":"search",size:14})}),e.jsx("button",{type:"button",className:`flat-terminal-wrapper__action-btn flat-terminal-wrapper__action-btn--danger ${Z?"flat-terminal-wrapper__action-btn--confirm":""}`,onClick:()=>Y.handleClick(kt,()=>{var r;C.clearContext(d),(r=pe.current)==null||r.historyLoader.clearHistory()}),title:Z?"Click again to confirm clear context":"Clear context",children:e.jsx(m,{name:Z?"question":"clear",size:14})}),e.jsx("button",{type:"button",className:`flat-terminal-wrapper__action-btn ${le?"flat-terminal-wrapper__action-btn--active":""}`,onClick:rt,title:le?"Hide git panel":"Show git changes","aria-pressed":le,children:e.jsx(m,{name:"git-branch",size:14})}),e.jsx("button",{type:"button",className:`flat-terminal-wrapper__action-btn ${F?"flat-terminal-wrapper__action-btn--active":""}`,onClick:lt,title:F?"Hide buildings panel":"Show area buildings","aria-pressed":F,children:e.jsx(m,{name:"buildings",size:14})}),e.jsxs("div",{className:"flat-terminal-wrapper__more",ref:Ee,children:[e.jsx("button",{type:"button",className:`flat-terminal-wrapper__action-btn ${oe?"flat-terminal-wrapper__action-btn--active":""}`,onClick:()=>ee(r=>!r),title:"More actions","aria-expanded":oe,children:"⋮"}),oe&&e.jsxs("div",{className:"flat-terminal-wrapper__more-menu",role:"menu",children:[e.jsxs("button",{type:"button",role:"menuitem",className:`flat-terminal-wrapper__more-item ${ie?"flat-terminal-wrapper__more-item--active":""}`,onClick:()=>{st(),ee(!1)},title:ie?"Hide Debug Panel":"Show Debug Panel",children:[e.jsx(m,{name:"bug",size:14}),e.jsx("span",{children:ie?"Hide Debug Panel":"Show Debug Panel"})]}),e.jsx("div",{className:"flat-terminal-wrapper__more-divider"}),e.jsxs("button",{type:"button",role:"menuitem",className:"flat-terminal-wrapper__more-item",onClick:()=>{C.collapseContext(d),ee(!1)},disabled:p.status!=="idle",title:p.status!=="idle"?"Agent must be idle to collapse context":"Collapse context",children:[e.jsx(m,{name:"package",size:14}),e.jsx("span",{children:"Collapse context"})]}),ne&&e.jsxs("button",{type:"button",role:"menuitem",className:"flat-terminal-wrapper__more-item flat-terminal-wrapper__more-item--danger",onClick:()=>{De(d,ae),ee(!1)},children:[e.jsx(m,{name:"crown",size:14}),e.jsxs("span",{children:["Clear ",ae," subordinate",ae===1?"":"s"]})]}),e.jsx("div",{className:"flat-terminal-wrapper__more-divider"}),e.jsxs("button",{type:"button",role:"menuitem",className:"flat-terminal-wrapper__more-item flat-terminal-wrapper__more-item--danger",onClick:()=>{C.killAgent(d),ee(!1)},children:[e.jsx(m,{name:"cross",size:14}),e.jsx("span",{children:"Remove agent"})]})]})]})]}),e.jsxs("button",{type:"button",className:`flat-terminal-wrapper__inspector-toggle ${z?"flat-terminal-wrapper__inspector-toggle--active":""}`,onClick:ue,title:z?"Hide inspector panel":"Show inspector panel","aria-label":z?"Hide inspector panel":"Show inspector panel","aria-pressed":z,children:[e.jsx("span",{className:"flat-terminal-wrapper__inspector-icon","aria-hidden":"true",children:e.jsxs("svg",{width:"14",height:"14",viewBox:"0 0 16 16",fill:"none",stroke:"currentColor",strokeWidth:"1.6",strokeLinecap:"round",strokeLinejoin:"round",children:[e.jsx("rect",{x:"1.5",y:"2.5",width:"13",height:"11",rx:"1.5"}),e.jsx("line",{x1:"10",y1:"2.5",x2:"10",y2:"13.5"})]})}),e.jsx("span",{className:"flat-terminal-wrapper__inspector-label",children:"Inspector"})]}),e.jsx("button",{type:"button",className:"flat-terminal-wrapper__close",onClick:()=>C.deselectAll(),title:"Close chat","aria-label":"Close chat",children:e.jsx(m,{name:"cross",size:14})})]})]}),e.jsx(ca,{ref:pe,agentId:d,agent:p,viewMode:v,isOpen:!0,onImageClick:$,onFileClick:M,onBashClick:Ce,onViewMarkdown:je,keyboard:Re,hasModalOpen:!1}),y&&e.jsxs(e.Fragment,{children:[e.jsx("div",{className:"guake-bottom-terminal-resize",onMouseDown:nt,role:"separator","aria-orientation":"horizontal","aria-label":"Resize embedded terminal"}),e.jsxs("div",{className:"flat-bottom-panel",role:"region","aria-label":`Embedded terminal: ${y.name}`,style:{height:J},children:[e.jsxs("div",{className:"flat-bottom-panel__header",children:[e.jsxs("span",{className:"flat-bottom-panel__title",children:[e.jsx(m,{name:"terminal",size:12}),e.jsx("span",{children:y.name}),!((ce=y.terminalStatus)!=null&&ce.url)&&e.jsx("span",{className:"flat-bottom-panel__muted",children:"(starting...)"})]}),e.jsx("button",{type:"button",className:"flat-bottom-panel__close",onClick:()=>G(null),title:"Close embedded terminal","aria-label":"Close embedded terminal",children:e.jsx(m,{name:"cross",size:12})})]}),e.jsx("div",{className:"flat-bottom-panel__body",children:(Xe=y.terminalStatus)!=null&&Xe.url?e.jsx(da,{terminalUrl:y.terminalStatus.url,visible:!0}):e.jsx("div",{className:"flat-bottom-panel__placeholder",children:"Starting terminal..."})})]})]}),e.jsxs("div",{className:"flat-terminal-wrapper__statusbar",role:"contentinfo",children:[p.isDetached&&e.jsxs("span",{className:"flat-terminal-wrapper__detached",title:"Reattaching session...",children:[e.jsx(m,{name:"refresh",size:12}),e.jsx("span",{children:"Reattaching"})]}),q&&te&&e.jsxs("span",{className:"flat-terminal-wrapper__cwd",title:q,onClick:()=>C.setFileViewerPath(q),children:[e.jsx("span",{className:"flat-terminal-wrapper__cwd-icon",children:e.jsx(m,{name:"folder",size:12})}),e.jsx("span",{className:"flat-terminal-wrapper__cwd-text",children:te})]}),me&&me.map(({areaId:r,areaName:i,dir:c})=>{const o=$e.get(c),ge=Ie.has(c),xe=c.split("/").filter(Boolean).pop()||c;return e.jsxs("span",{className:"flat-terminal-wrapper__area-dir",title:`${i}: ${c}${o?` (${o.branch}${o.ahead?` ↑${o.ahead}`:""}${o.behind?` ↓${o.behind}`:""})`:""}`,onClick:()=>C.openFileExplorerForAreaFolder(r,c),children:[e.jsx(m,{name:"folder-open",size:12}),e.jsx("span",{className:"flat-terminal-wrapper__area-dir-name",children:xe}),o&&e.jsxs(e.Fragment,{children:[e.jsxs("span",{className:"flat-terminal-wrapper__area-dir-branch",children:[e.jsx(m,{name:"git-branch",size:10})," ",o.branch]}),o.ahead>0&&e.jsxs("span",{className:"flat-terminal-wrapper__branch-ahead",title:`${o.ahead} ahead`,children:[e.jsx(m,{name:"arrow-up",size:9}),o.ahead]}),o.behind>0&&e.jsxs("span",{className:"flat-terminal-wrapper__branch-behind",title:`${o.behind} behind`,children:[e.jsx(m,{name:"arrow-down",size:9}),o.behind]}),e.jsx("span",{className:`flat-terminal-wrapper__area-fetch ${ge?"flat-terminal-wrapper__area-fetch--fetching":""}`,title:"Git fetch",onClick:se=>{se.stopPropagation(),Se(c)},children:e.jsx(m,{name:ge?"hourglass":"download",size:12})})]})]},`${r}:${c}`)}),e.jsxs("span",{className:"flat-terminal-wrapper__context",onClick:()=>C.setContextModalAgentId(d),title:u?`Context usage: ${He}k / ${Ge}k tokens (${U}% used). Click to view stats.`:"Click to fetch context stats",children:[e.jsx("span",{className:"flat-terminal-wrapper__context-icon",children:e.jsx(m,{name:"dashboard",size:12})}),e.jsx("span",{className:"flat-terminal-wrapper__context-label",children:"Ctx:"}),e.jsx("span",{className:"flat-terminal-wrapper__context-bar",children:e.jsx("span",{className:"flat-terminal-wrapper__context-bar-fill",style:{width:`${U}%`,backgroundColor:Be}})}),e.jsxs("span",{className:"flat-terminal-wrapper__context-tokens",style:{color:Be},children:[He,"k/",Ge,"k"]}),e.jsxs("span",{className:"flat-terminal-wrapper__context-free",children:["(",dt,"% free)"]}),!u&&e.jsx("span",{className:"flat-terminal-wrapper__context-warning",title:"No context stats yet",children:e.jsx(m,{name:"warn",size:12})})]}),e.jsx("div",{className:"flat-terminal-wrapper__statusbar-spacer","aria-hidden":"true"}),B.length>0&&e.jsx("span",{className:"flat-terminal-wrapper__buildings",role:"group","aria-label":"Area terminals",children:B.map(r=>{const i=A===r.id;return e.jsx("button",{type:"button",className:`flat-terminal-wrapper__building-btn ${i?"flat-terminal-wrapper__building-btn--active":""} ${r.hasUrl?"":"flat-terminal-wrapper__building-btn--offline"}`,title:`${i?"Hide":"Show"} terminal: ${r.name}${r.hasUrl?"":" (starting...)"}`,onClick:()=>{if(i){G(null);return}r.hasUrl||C.sendBuildingCommand(r.id,"start"),G(r.id)},children:e.jsx(m,{name:"terminal",size:14})},r.id)})}),fe.length>0&&e.jsx("span",{className:"flat-terminal-wrapper__buildings",role:"group","aria-label":"Area PM2 logs",children:fe.map(r=>e.jsx("button",{type:"button",className:"flat-terminal-wrapper__building-btn",title:`Open logs: ${r.name}`,onClick:()=>ve(r.id),children:e.jsx(m,{name:"scroll",size:14})},r.id))}),Oe.length>0&&e.jsx("span",{className:"flat-terminal-wrapper__buildings",role:"group","aria-label":"Area databases",children:Oe.map(r=>e.jsx("button",{type:"button",className:"flat-terminal-wrapper__building-btn",title:`Open database: ${r.name}`,onClick:()=>ve(r.id),children:e.jsx(m,{name:"hard-drives",size:14})},r.id))}),e.jsx("div",{className:"flat-terminal-wrapper__theme",children:e.jsx(ua,{})})]}),le&&e.jsx(pa,{agentId:d,agents:ct,onClose:it,branchInfoMap:$e,fetchRemote:Se,fetchingDirs:Ie}),F&&e.jsx(ma,{agentId:d,onClose:ot}),ie&&e.jsx(fa,{agentId:d,onClose:We})]})});function Ma({onAgentClick:x,onBuildingClick:d,onBuildingDoubleClick:v,onOpenSpawnModal:T,onOpenBossSpawnModal:z,onOpenAreaModal:ue}){const{t:$}=Rt(["common"]),M=Lt(),Ce=zt(),[je,De]=n.useState(null),[ve,Re]=n.useState(null),[Ne,Le]=n.useState(null),[E,K]=n.useState(null),[O,ze]=n.useState(null),[p,R]=n.useState(!1),pe=n.useCallback(()=>{R(t=>!t)},[]),ke=n.useCallback(()=>{R(!1)},[]),[Ae,me]=n.useState(()=>{const t=wt(j.VIEW_MODE);return t==="simple"||t==="chat"||t==="advanced"?t:"simple"}),$e=n.useCallback(t=>{me(t),Ct(j.VIEW_MODE,t)},[]);n.useEffect(()=>{const t=a=>{if(a.key!==j.VIEW_MODE)return;const s=a.newValue;(s==="simple"||s==="chat"||s==="advanced")&&me(s)};return window.addEventListener("storage",t),()=>window.removeEventListener("storage",t)},[]);const[Se,Ie]=n.useState(()=>gt(j.FLAT_INSPECTOR_OPEN,!1)),[B,fe]=n.useState(!1),Oe=n.useCallback(()=>fe(t=>!t),[]),at=n.useCallback(()=>fe(!1),[]),H=n.useRef(null),re=n.useRef(null),[Y,Z]=n.useState(()=>{const t=jt(j.FLAT_MIDDLE_WIDTH,0);return t>=tt?t:null}),[A,G]=n.useState(()=>{const t=jt(j.FLAT_INSPECTOR_WIDTH,0);return t>=ht?t:null}),y=n.useCallback(t=>{if(typeof window>"u")return t;const a=A!==null?et+A:0,s=window.innerWidth-Nt-et-vt-a;return Math.max(tt,Math.min(Math.max(s,tt),t))},[A]),J=n.useCallback(t=>{var f;if(typeof window>"u")return t;const a=(f=H.current)==null?void 0:f.querySelector(".flat-middle"),s=(a==null?void 0:a.getBoundingClientRect().width)??tt,l=window.innerWidth-Nt-s-et-vt-et;return Math.max(ht,Math.min(Math.max(l,ht),t))},[]);n.useEffect(()=>{if(Y===null&&A===null)return;const t=()=>{Z(a=>{if(a===null)return a;const s=y(a);return s===a?a:s}),G(a=>{if(a===null)return a;const s=J(a);return s===a?a:s})};return window.addEventListener("resize",t),()=>window.removeEventListener("resize",t)},[Y,A,y,J]);const nt=n.useCallback(t=>{var s;if(t.button!==0)return;const a=(s=H.current)==null?void 0:s.querySelector(".flat-middle");a&&(t.currentTarget.setPointerCapture(t.pointerId),re.current={kind:"middle",startX:t.clientX,startWidth:a.getBoundingClientRect().width,pointerId:t.pointerId},document.body.classList.add("flat-splitter-dragging"))},[]),le=n.useCallback(t=>{var s;if(t.button!==0)return;const a=(s=H.current)==null?void 0:s.querySelector(".flat-inspector");a&&(t.currentTarget.setPointerCapture(t.pointerId),re.current={kind:"inspector",startX:t.clientX,startWidth:a.getBoundingClientRect().width,pointerId:t.pointerId},document.body.classList.add("flat-splitter-dragging"))},[]),Me=n.useCallback(t=>{const a=re.current;if(!a||t.pointerId!==a.pointerId)return;const s=t.clientX-a.startX;a.kind==="middle"?Z(y(a.startWidth+s)):G(J(a.startWidth-s))},[y,J]),F=n.useCallback(t=>{const a=re.current;if(!a||t.pointerId!==a.pointerId)return;try{t.currentTarget.releasePointerCapture(t.pointerId)}catch{}if(re.current=null,document.body.classList.remove("flat-splitter-dragging"),!(Math.abs(t.clientX-a.startX)>2))return;const l=t.clientX-a.startX;if(a.kind==="middle"){const f=y(a.startWidth+l);Z(f),Qe(j.FLAT_MIDDLE_WIDTH,f)}else{const f=J(a.startWidth-l);G(f),Qe(j.FLAT_INSPECTOR_WIDTH,f)}},[y,J]),Fe=n.useCallback(()=>{Z(null),Qe(j.FLAT_MIDDLE_WIDTH,0)},[]),ie=n.useCallback(()=>{G(null),Qe(j.FLAT_INSPECTOR_WIDTH,0)},[]),[Q,st]=n.useState(()=>wt(j.FLAT_INSPECTOR_VIEW)==="tracking"?"tracking":"agent"),We=n.useCallback(t=>{st(t),Ct(j.FLAT_INSPECTOR_VIEW,t)},[]),rt=n.useCallback(()=>{Ie(t=>{const a=!t;return we(j.FLAT_INSPECTOR_OPEN,a),a})},[]),lt=n.useCallback(()=>{Ie(!1),we(j.FLAT_INSPECTOR_OPEN,!1)},[]),it=$t(),ot=n.useCallback((t,a)=>{De({url:t,name:a})},[]),ct=n.useCallback((t,a)=>{Re({command:t,output:a,isLive:!1})},[]),oe=n.useCallback((t,a)=>{C.setFileViewerPath(t,a)},[]),ee=n.useCallback(t=>{},[]),Ee=n.useCallback((t,a)=>{Le({agentId:t,count:a})},[]),V=n.useCallback(t=>{v?v(t):d(t)},[d,v]),u=n.useMemo(()=>Ce.size>0?Array.from(Ce)[0]:null,[Ce]);n.useEffect(()=>{R(!1)},[u]);const X=n.useRef([]),L=n.useRef(-1),he=n.useRef(!1),U=n.useRef(null),[dt,Be]=n.useState(!1),[He,Ge]=n.useState(!1),q=n.useRef(!1),te=n.useRef(null),ae=n.useRef(!1),ne=n.useMemo(()=>new Set(M.map(t=>t.id)),[M]),Ve=n.useMemo(()=>{const t=new Map(M.map(s=>[s.id,s])),a=new Map;for(const s of M)if((s.isBoss||s.class==="boss")&&s.subordinateIds&&s.subordinateIds.length>0){const l=s.subordinateIds.map(f=>t.get(f)).filter(f=>f!==void 0);l.length>0&&a.set(s.id,l)}return a},[M]),P=n.useCallback(()=>{const t=X.current,a=L.current;Be(a>0),Ge(a>=0&&a<t.length-1)},[]),ce=n.useCallback(t=>{const a=X.current;if(a.length===0)return;let s=L.current+t;for(;s>=0&&s<a.length;){const l=a[s];if(ne.has(l)){he.current=!0,L.current=s,P(),C.selectAgent(l);return}s+=t}},[ne,P]),Xe=n.useCallback(()=>ce(-1),[ce]),r=n.useCallback(()=>ce(1),[ce]),i=n.useCallback((t,a)=>{if(typeof window>"u")return;const s=window.history.state,f={...typeof s=="object"&&s!==null?s:{},__flatAgentNav:{agentId:t}};a==="replace"?window.history.replaceState(f,"",window.location.href):window.history.pushState(f,"",window.location.href)},[]);n.useEffect(()=>{if(!u){q.current=!1,te.current=null;return}if(!q.current){i(u,"replace"),q.current=!0,te.current=u;return}if(ae.current){ae.current=!1,te.current=u;return}te.current!==u&&(i(u,"push"),te.current=u)},[u,i]),n.useEffect(()=>{const t=a=>{var w,h;const s=(h=(w=a.state)==null?void 0:w.__flatAgentNav)==null?void 0:h.agentId;if(!s||typeof s!="string"||!ne.has(s)||s===u)return;ae.current=!0,he.current=!0;const l=X.current,f=l.lastIndexOf(s);f>=0?L.current=f:(l.push(s),L.current=l.length-1),P(),C.selectAgent(s)};return window.addEventListener("popstate",t),()=>window.removeEventListener("popstate",t)},[ne,u,P]),n.useEffect(()=>{if(!u){X.current=[],L.current=-1,P();return}if(U.current=u,he.current){he.current=!1,P();return}const t=X.current,a=L.current;if(a>=0&&t[a]===u){P();return}const s=a<t.length-1?t.slice(0,a+1):t.slice();s.push(u),s.length>100&&s.shift(),X.current=s,L.current=s.length-1,P()},[u,P]);const c=n.useCallback(t=>{x(t),fe(!1)},[x]),o=u??"",ge=n.useCallback(()=>{},[]),xe=n.useCallback(t=>{c(t)},[c]),se=Se,Ue=n.useRef(null);n.useEffect(()=>{if(u)return;const t=a=>{if(a.key!==" "&&a.key!=="Backspace")return;const s=a.target;if(s.tagName==="INPUT"||s.tagName==="TEXTAREA"||s.isContentEditable)return;const l=U.current;!l||!ne.has(l)||(a.preventDefault(),C.selectAgent(l))};return document.addEventListener("keydown",t),()=>document.removeEventListener("keydown",t)},[u,ne]);const[ut,ye]=n.useState(new Set),D=n.useCallback(t=>{ye(a=>{const s=new Set(a);return s.has(t)?s.delete(t):s.add(t),s})},[]),N=At(),[qe]=Ot(),_e=n.useMemo(()=>{const t=new Map,a=[];for(const g of M){const b=C.getAreaForAgent(g.id);if(!Ft((b==null?void 0:b.id)??null))continue;if(!b||b.archived){a.push(g);continue}const W=t.get(b.id);W?W.push(g):t.set(b.id,[g])}const s=[];for(const[,g]of N){if(g.archived||!Wt(g.id))continue;const b=t.get(g.id);b&&b.length>0&&s.push({area:g,agents:b})}a.length>0&&s.push({area:{id:"__unassigned__",name:"Unassigned",color:"#6272a4",center:{x:0,z:0},type:"circle",radius:0,directories:[],archived:!1,assignedAgentIds:[],zIndex:0},agents:a});const l=s.filter(g=>g.area.id!=="__unassigned__"),f=s.filter(g=>g.area.id==="__unassigned__");let w=1,h=1;const Te=new Map;if(l.length>1){let g=1/0,b=-1/0,W=1/0,be=-1/0;for(const S of l)g=Math.min(g,S.area.center.x),b=Math.max(b,S.area.center.x),W=Math.min(W,S.area.center.z),be=Math.max(be,S.area.center.z);const Ye=b-g||1,Ze=be-W||1;if(l.length<=4){w=l.length,h=1;const S=[...l].sort((I,pt)=>I.area.center.x-pt.area.center.x);for(let I=0;I<S.length;I++)Te.set(S[I].area.id,{row:1,col:I+1})}else{const S=[...l].sort((_,k)=>_.area.center.x-k.area.center.x),I=[];for(let _=1;_<S.length;_++)I.push(S[_].area.center.x-S[_-1].area.center.x);const pt=I.reduce((_,k)=>_+k,0)/I.length||1;let xt=1;for(const _ of I)_>pt*1.3&&xt++;w=Math.max(2,Math.min(xt,l.length));const mt=[...l].sort((_,k)=>_.area.center.z-k.area.center.z),Je=[];for(let _=1;_<mt.length;_++)Je.push(mt[_].area.center.z-mt[_-1].area.center.z);const yt=Je.reduce((_,k)=>_+k,0)/Je.length||1;let _t=1;for(const _ of Je)_>yt*1.3&&_t++;h=Math.max(2,Math.min(_t,l.length)),w=Math.max(w,Math.ceil(l.length/h)),h=Math.max(h,Math.ceil(l.length/w));const Tt=Ye/w,Pt=Ze/h,ft=new Set;for(const _ of l){let k=Math.min(w-1,Math.max(0,Math.floor((_.area.center.x-g)/Tt))),de=Math.min(h-1,Math.max(0,Math.floor((_.area.center.z-W)/Pt))),Pe=`${de},${k}`,bt=0;const Dt=h*w;for(;ft.has(Pe)&&bt<Dt;)k++,k>=w&&(k=0,de=(de+1)%h),Pe=`${de},${k}`,bt++;ft.has(Pe)&&(de=h,k=0,Pe=`${de},${k}`,h++),ft.add(Pe),Te.set(_.area.id,{row:de+1,col:k+1})}}}const Ke=g=>{g.sort((b,W)=>{var Ye,Ze,S,I;const be=(((Ye=b.position)==null?void 0:Ye.z)??0)-(((Ze=W.position)==null?void 0:Ze.z)??0);return be!==0?be:(((S=b.position)==null?void 0:S.x)??0)-(((I=W.position)==null?void 0:I.x)??0)})};for(const g of l)Ke(g.agents);for(const g of f)Ke(g.agents);return{groups:[...l,...f],gridCols:w,gridRows:h,positions:Te}},[M,N,qe]),Mt=n.useMemo(()=>{if(!E)return[];const t=M.find(a=>a.id===E.agentId);return t?[{id:"edit-agent",label:"Edit Agent",icon:e.jsx(m,{name:"edit",size:14}),onClick:()=>{window.dispatchEvent(new CustomEvent("tide:open-agent-edit",{detail:{agentId:t.id}}))}},{id:"open-chat",label:"Open Chat",icon:e.jsx(m,{name:"chat",size:14}),onClick:()=>x(t.id)},{id:"delete-agent",label:"Delete Agent",icon:e.jsx(m,{name:"trash",size:14}),danger:!0,onClick:()=>{ze({agentId:t.id,name:t.name})}}]:[]},[E,M,x]),Et=n.useCallback(t=>{const a=new Set(_e.groups.map(s=>s.area.id));a.delete(t),ye(a),requestAnimationFrame(()=>{const s=Ue.current;if(!s)return;const l=s.querySelector(`[data-area-id="${t}"]`);if(!l)return;const f=s.getBoundingClientRect(),h=l.getBoundingClientRect().top-f.top+s.scrollTop-8;s.scrollTo({top:Math.max(0,h),behavior:"smooth"})})},[_e]);return e.jsxs("div",{ref:H,className:`flat-view ${se?"flat-view--with-inspector":""} ${u?"flat-view--has-chat":""} ${B?"flat-view--mobile-sidebar-open":""}`,style:(()=>{if(Y===null&&A===null)return;const t={};return Y!==null&&(t["--flat-middle-width"]=`${Y}px`),A!==null&&(t["--flat-inspector-width"]=`${A}px`),t})(),children:[B&&e.jsx("div",{className:"flat-mobile-sidebar-backdrop",onClick:at,"aria-hidden":"true"}),e.jsxs("div",{className:"flat-middle",children:[e.jsxs("div",{className:"flat-middle__header",children:[e.jsx("h2",{className:"flat-middle__title",children:"👥 Agents"}),e.jsxs("div",{className:"flat-middle__actions",children:[e.jsx("button",{className:"flat-cta-btn flat-cta-btn--agent",onClick:T,title:"Create new agent",children:"+ Agent"}),e.jsx("button",{className:"flat-cta-btn flat-cta-btn--boss",onClick:z,title:"Create new boss agent",children:"+ Boss"}),e.jsx("button",{className:"flat-cta-btn flat-cta-btn--area",onClick:ue,title:"Create new area",children:"+ Area"})]})]}),e.jsx("div",{className:"flat-middle__content",children:e.jsx(Bt,{activeAgentId:o,onClose:ge,onSelectAgent:xe,collapsedAreas:ut,onToggleArea:D,agentListRef:Ue})})]}),e.jsx("div",{className:"flat-splitter flat-splitter--middle",role:"separator","aria-orientation":"vertical","aria-label":"Resize agents panel",title:"Drag to resize · Double-click to reset",onPointerDown:nt,onPointerMove:Me,onPointerUp:F,onPointerCancel:F,onDoubleClick:Fe}),e.jsxs("div",{className:"flat-right",children:[e.jsxs("button",{type:"button",className:"flat-mobile-sidebar-toggle","aria-label":B?"Close agents sidebar":"Open agents sidebar","aria-expanded":B,onClick:Oe,children:[e.jsx(m,{name:"list",size:18}),e.jsx("span",{className:"flat-mobile-sidebar-toggle__label",children:"Agents"})]}),u?e.jsx(ka,{agentId:u,terminalViewMode:Ae,onTerminalViewModeChange:$e,inspectorOpen:Se,onToggleInspector:rt,onImageClick:ot,onFileClick:oe,onBashClick:ct,onViewMarkdown:ee,onRequestClearSubordinates:Ee,onOpenBuilding:V,keyboard:it,canNavigateBack:dt,canNavigateForward:He,onNavigateBack:Xe,onNavigateForward:r,agentInfoOpen:p,onToggleAgentInfo:pe}):e.jsx("div",{className:"flat-chat flat-chat--empty",children:e.jsxs("div",{className:"flat-map",children:[e.jsxs("div",{className:"flat-map__header",children:[e.jsx("span",{className:"flat-map__title",children:"🗺️ Areas"}),e.jsx("span",{className:"flat-map__hint",children:"Click an area to focus it, or an agent to chat"})]}),e.jsx("div",{className:"flat-map__grid",style:{gridTemplateColumns:`repeat(${_e.gridCols}, 1fr)`},children:_e.groups.length===0?e.jsx("div",{className:"flat-map__empty",children:e.jsx("span",{children:"No areas or agents yet"})}):_e.groups.map(t=>{const a=t.area.id,s=_e.positions.get(a);return e.jsxs("div",{className:"flat-map-area-card",style:{"--area-color":t.area.color,gridRow:s==null?void 0:s.row,gridColumn:s==null?void 0:s.col},children:[e.jsxs("button",{type:"button",className:"flat-map-area-card__header",onClick:()=>Et(a),title:`Focus ${t.area.name} in left panel`,children:[e.jsx("span",{className:"flat-map-area-card__color",style:{background:t.area.color}}),e.jsx("span",{className:"flat-map-area-card__name",children:t.area.name}),e.jsx("span",{className:"flat-map-area-card__count",children:t.agents.length})]}),e.jsx("div",{className:"flat-map-area-card__agents",children:t.agents.map(l=>{const f=l.isBoss||l.class==="boss",w=f?Ve.get(l.id):void 0,h=Ht(l),Te=h.usedPercent>=80?"#ff4a4a":h.usedPercent>=60?"#ff9e4a":h.usedPercent>=40?"#ffd700":"#4aff9e",Ke=`Context: ${(h.totalTokens/1e3).toFixed(1)}k / ${(h.contextWindow/1e3).toFixed(1)}k (${h.usedPercent}% used, ${h.freePercent}% free)`,g=l.latestTodos&&l.latestTodos.length>0||w&&w.length>0;return e.jsx(Gt,{todos:l.latestTodos,subordinates:w,position:"top",children:e.jsxs("button",{type:"button",className:`flat-map-agent-chip ${l.status}`,onClick:()=>x(l.id),onContextMenu:b=>{b.preventDefault(),b.stopPropagation(),K({agentId:l.id,position:{x:b.clientX,y:b.clientY}})},title:g?void 0:`${f?"Boss · ":""}Open chat with ${l.name}
2
+ ${Ke}`,children:[e.jsx(St,{agent:l,size:16}),f&&e.jsx("span",{className:"flat-map-agent-chip__crown","aria-hidden":"true",children:e.jsx(m,{name:"crown",size:11,color:"#ffd700",weight:"fill"})}),e.jsx("span",{className:"flat-map-agent-chip__name",children:l.name}),e.jsx("img",{src:l.provider==="codex"?"/assets/codex.png":l.provider==="opencode"?"/assets/opencode.png":"/assets/claude.png",alt:l.provider,className:"flat-map-agent-chip__provider-icon",title:l.provider==="codex"?"Codex Agent":l.provider==="opencode"?"OpenCode Agent":"Claude Agent"}),e.jsx("span",{className:"flat-map-agent-chip__dot",style:{backgroundColor:It(l.status)}}),l.latestTodos&&l.latestTodos.length>0&&e.jsx(Vt,{todos:l.latestTodos,maxDots:6}),f&&w&&w.length>0&&e.jsx(Xt,{subordinates:w,maxDots:6}),e.jsx("span",{className:"flat-map-agent-chip__context-bar","aria-hidden":"true",children:e.jsx("span",{className:"flat-map-agent-chip__context-bar-fill",style:{width:`${h.usedPercent}%`,backgroundColor:Te}})})]})},l.id)})})]},a)})})]})})]}),se&&e.jsx("div",{className:"flat-splitter flat-splitter--inspector",role:"separator","aria-orientation":"vertical","aria-label":"Resize inspector panel",title:"Drag to resize · Double-click to reset",onPointerDown:le,onPointerMove:Me,onPointerUp:F,onPointerCancel:F,onDoubleClick:ie}),se&&e.jsxs("aside",{className:"flat-inspector","aria-label":"Inspector panel",children:[e.jsxs("div",{className:"flat-inspector__header",children:[e.jsxs("div",{className:"flat-inspector__tabs",role:"tablist","aria-label":"Inspector view",children:[e.jsx("button",{type:"button",role:"tab","aria-selected":Q==="agent",className:`flat-inspector__tab ${Q==="agent"?"flat-inspector__tab--active":""}`,onClick:()=>We("agent"),children:"Agent"}),e.jsx("button",{type:"button",role:"tab","aria-selected":Q==="tracking",className:`flat-inspector__tab ${Q==="tracking"?"flat-inspector__tab--active":""}`,onClick:()=>We("tracking"),children:"Tracking"})]}),e.jsx("button",{type:"button",className:"flat-inspector__close",onClick:lt,title:"Close inspector","aria-label":"Close inspector",children:"✕"})]}),e.jsx("div",{className:"flat-inspector__body",children:Q==="tracking"?e.jsx(Ut,{activeAgentId:u??"",onSelectAgent:t=>x(t)}):(()=>{if(!u)return e.jsx("div",{className:"flat-inspector__empty",children:e.jsx("span",{children:"Select an agent to inspect"})});const t=M.find(a=>a.id===u);return t?e.jsx(qt,{agent:t,onFocusAgent:a=>x(a),onKillAgent:a=>C.killAgent(a)}):e.jsx("div",{className:"flat-inspector__empty",children:e.jsx("span",{children:"Agent not found"})})})()})]}),je&&e.jsx(Kt,{url:je.url,name:je.name,onClose:()=>De(null)}),ve&&e.jsx(Yt,{state:ve,onClose:()=>Re(null)}),Ne&&e.jsx(Zt,{action:"clear-subordinates",selectedAgentId:Ne.agentId,subordinateCount:Ne.count,onClose:()=>Le(null),onClearHistory:()=>{}}),e.jsx(Jt,{agent:u?M.find(t=>t.id===u)??null:null,isOpen:p&&!!u,onClose:ke}),e.jsx(Qt,{isOpen:E!==null,position:(E==null?void 0:E.position)??{x:0,y:0},worldPosition:{x:0,z:0},actions:Mt,onClose:()=>K(null)}),e.jsx(ea,{isOpen:O!==null,title:$("common:confirm.removeAgentTitle"),message:$("common:confirm.removeAgentMessage",{name:(O==null?void 0:O.name)??""}),confirmLabel:$("common:buttons.remove"),cancelLabel:$("common:buttons.cancel"),variant:"danger",onConfirm:()=>{O&&C.removeAgentFromServer(O.agentId)},onClose:()=>ze(null)})]})}export{Ma as FlatView};