cli-jaw 0.1.12 → 1.0.2
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/README.ko.md +14 -0
- package/README.md +50 -0
- package/README.zh-CN.md +14 -0
- package/dist/bin/commands/serve.js +1 -0
- package/dist/bin/commands/serve.js.map +1 -1
- package/dist/server.js +2 -1
- package/dist/server.js.map +1 -1
- package/dist/src/browser/connection.js +3 -0
- package/dist/src/browser/connection.js.map +1 -1
- package/package.json +1 -1
- package/public/dist/bundle.js +15 -15
- package/public/dist/bundle.js.map +4 -4
- package/public/js/cjk-fix.ts +38 -0
- package/public/js/render.ts +5 -1
package/public/dist/bundle.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var
|
|
1
|
+
var wn=Object.defineProperty;var b=(e,t)=>()=>(e&&(t=e(e=0)),t);var R=(e,t)=>{for(var n in t)wn(e,n,{get:t[n],enumerable:!0})};var l,T=b(()=>{"use strict";l={ws:null,agentBusy:!1,employees:[],allSkills:[],currentSkillFilter:"all",currentAgentDiv:null,attachedFiles:[],heartbeatJobs:[],cliStatusCache:null,cliStatusTs:0}});var It={};R(It,{api:()=>f,apiFire:()=>I,apiJson:()=>y});async function f(e,t={}){try{let n=await fetch(e,t);if(!n.ok)return console.warn(`[api] ${t.method||"GET"} ${e} \u2192 ${n.status}`),null;if(!(n.headers.get("content-type")||"").includes("json"))return null;let i=await n.json();return i&&typeof i=="object"&&"ok"in i&&"data"in i?i.ok?i.data:(console.warn(`[api] ${e} \u2192 ok:false`,i.error||""),null):i}catch(n){return console.warn(`[api] ${e} failed:`,n.message),null}}async function y(e,t,n){return f(e,{method:t,headers:{"Content-Type":"application/json"},body:JSON.stringify(n)})}function I(e,t="POST",n){let o={method:t};n&&(o.headers={"Content-Type":"application/json"},o.body=JSON.stringify(n)),fetch(e,o).catch(()=>{})}var L=b(()=>{"use strict"});function Ht(e){let t={};for(let[n,o]of Object.entries(e))t[n]=Array.isArray(o?.models)?[...o.models]:[];return t}function Bt(e){let t={};for(let[n,o]of Object.entries(e||{})){if(!o||typeof o!="object")continue;let i=o,a={label:i.label||n,efforts:Array.isArray(i.efforts)?[...i.efforts]:[],models:Array.isArray(i.models)?[...i.models]:[]};typeof i.effortNote=="string"&&i.effortNote.trim()&&(a.effortNote=i.effortNote),t[n]=a}return t}function wt(e){let t=Bt(e);return Object.keys(t).length?(K=t,$t=Object.keys(t),B=Ht(t),!0):!1}async function oe(){try{let e=await f("/api/cli-registry");if(!e||!wt(e))throw new Error("invalid registry")}catch(e){console.warn("[cli-registry] fallback:",e.message),wt(Ct)}return K}function w(){return $t}function ie(e){return K[e]||null}var Ct,K,$t,B,U,ae=b(()=>{"use strict";L();Ct={claude:{label:"Claude",efforts:["low","medium","high"],models:["claude-sonnet-4-6","claude-opus-4-6","claude-sonnet-4-6[1m]","claude-opus-4-6[1m]","claude-haiku-4-5-20251001"]},codex:{label:"Codex",efforts:["low","medium","high","xhigh"],models:["gpt-5.3-codex","gpt-5.3-codex-spark","gpt-5.2-codex","gpt-5.1-codex-max","gpt-5.1-codex-mini"]},gemini:{label:"Gemini",efforts:[],models:["gemini-3.0-pro-preview","gemini-3.1-pro-preview","gemini-2.5-pro","gemini-3-flash-preview","gemini-2.5-flash"]},opencode:{label:"OpenCode",efforts:["minimal","low","high","max"],models:["anthropic/claude-opus-4-6-thinking","anthropic/claude-sonnet-4-6-thinking","anthropic/claude-sonnet-4-6","openai/gpt-5.3-codex-xhigh","openai/gpt-5.3-codex-high","opencode/big-pickle","opencode/GLM-5 Free","opencode/MiniMax M2.5 Free","opencode/Kimi K2.5 Free","opencode/GPT 5 Nano Free","opencode/Grok Code Fast 1 Free"]},copilot:{label:"Copilot",efforts:["low","medium","high"],effortNote:"\u2192 ~/.copilot/config.json",models:["claude-sonnet-4.6","claude-opus-4.6","claude-opus-4.6-fast","claude-haiku-4.5","gpt-5.3-codex","gpt-5.2-codex","gpt-5.1-codex","gpt-4.1","gpt-5-mini","gemini-3-pro-preview"]}};K=Bt(Ct),$t=Object.keys(K),B=Ht(K);U=[{value:"frontend",labelKey:"role.label.frontend",label:"Frontend",prompt:"UI/UX, CSS, components",skill:"dev-frontend"},{value:"backend",labelKey:"role.label.backend",label:"Backend",prompt:"API, DB, server logic",skill:"dev-backend"},{value:"data",labelKey:"role.label.data",label:"Data",prompt:"Data pipeline, analysis, ML",skill:"dev-data"},{value:"docs",labelKey:"role.label.docs",label:"Docs",prompt:"Documentation, README, API docs",skill:"documentation"},{value:"custom",labelKey:"role.label.custom",label:"Custom...",prompt:"",skill:null}]});var W={};R(W,{addEmployee:()=>we,deleteEmployee:()=>Ce,loadEmployees:()=>Ie,onEmpCliChange:()=>He,onEmpRoleChange:()=>Be,renderEmployees:()=>Pt,updateEmployee:()=>C});async function Ie(){let e=await f("/api/employees");l.employees=e||[],Pt()}function Pt(){let e=document.getElementById("employeesList");if(!e)return;let t=l.employees;if(t.length===0){e.innerHTML=`<div style="color:var(--text-dim);font-size:11px;padding:4px 0">${c("emp.addPrompt")}</div>`;return}let n=w();e.innerHTML=t.map(o=>{let i=B[o.cli]||[],a=Cn[o.role||""],s=a?U.find(g=>g.value===a):U.find(g=>g.prompt===o.role),d=s?s.value:o.role?"custom":"frontend",r=d==="custom",u=At(o.id),p=u?.phase||o.phase,v=u?.phaseLabel||o.phaseLabel,H=p?`<span style="background:${Hn[p]||"#888"};color:#000;padding:1px 6px;border-radius:9px;font-size:9px">${v||"P"+p}</span>`:"";return`
|
|
2
2
|
<div class="settings-group" style="margin-bottom:8px;padding:8px 10px">
|
|
3
3
|
<div style="display:flex;align-items:center;gap:6px;margin-bottom:6px">
|
|
4
4
|
<span style="width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block;flex-shrink:0"></span>
|
|
@@ -34,7 +34,7 @@ var Tn=Object.defineProperty;var b=(e,t)=>()=>(e&&(t=e(e=0)),t);var R=(e,t)=>{fo
|
|
|
34
34
|
<span style="color:${o.status==="running"?"#fbbf24":"var(--green)"}">\u25CF ${o.status||"idle"}</span>
|
|
35
35
|
${H}
|
|
36
36
|
</div>
|
|
37
|
-
</div>`}).join("")}async function we(){await y("/api/employees","POST",{})}async function C(e,t){await y(`/api/employees/${e}`,"PUT",t)}async function Ce(e){I(`/api/employees/${e}`,"DELETE")}function He(e,t){let n=B[t]||[],o=document.querySelector(`[data-emp-model="${e}"]`);o&&(o.innerHTML='<option value="default" selected>default</option>'+n.map(i=>`<option>${m(i)}</option>`).join("")+`<option value="__custom__">${c("emp.customModel")}</option>`),C(e,{cli:t,model:"default"})}function Be(e,t){let n=U.find(i=>i.value===t),o=document.querySelector(`[data-emp-custom="${e}"]`);o&&(t==="custom"?(o.style.display="block",o.focus()):(o.style.display="none",o.value="",C(e,{role:n?.prompt||""})))}var
|
|
37
|
+
</div>`}).join("")}async function we(){await y("/api/employees","POST",{})}async function C(e,t){await y(`/api/employees/${e}`,"PUT",t)}async function Ce(e){I(`/api/employees/${e}`,"DELETE")}function He(e,t){let n=B[t]||[],o=document.querySelector(`[data-emp-model="${e}"]`);o&&(o.innerHTML='<option value="default" selected>default</option>'+n.map(i=>`<option>${m(i)}</option>`).join("")+`<option value="__custom__">${c("emp.customModel")}</option>`),C(e,{cli:t,model:"default"})}function Be(e,t){let n=U.find(i=>i.value===t),o=document.querySelector(`[data-emp-custom="${e}"]`);o&&(t==="custom"?(o.style.display="block",o.focus()):(o.style.display="none",o.value="",C(e,{role:n?.prompt||""})))}var Cn,Hn,D=b(()=>{"use strict";T();ae();$();$e();x();L();Cn={"React/Vue \uAE30\uBC18 UI \uCEF4\uD3EC\uB10C\uD2B8 \uAC1C\uBC1C, \uC2A4\uD0C0\uC77C\uB9C1":"frontend","API \uC11C\uBC84, DB \uC2A4\uD0A4\uB9C8, \uBE44\uC988\uB2C8\uC2A4 \uB85C\uC9C1 \uAD6C\uD604":"backend","\uD504\uB860\uD2B8\uC5D4\uB4DC\uC640 \uBC31\uC5D4\uB4DC \uBAA8\uB450 \uB2F4\uB2F9":"frontend","CI/CD, Docker, \uC778\uD504\uB77C \uC790\uB3D9\uD654":"backend","\uD14C\uC2A4\uD2B8 \uC791\uC131, \uBC84\uADF8 \uC7AC\uD604, \uD488\uC9C8 \uAD00\uB9AC":"custom","\uB370\uC774\uD130 \uD30C\uC774\uD504\uB77C\uC778, ETL, \uBD84\uC11D \uCFFC\uB9AC":"data","API \uBB38\uC11C\uD654, README, \uAC00\uC774\uB4DC \uC791\uC131":"docs","UI/UX \uAD6C\uD604, CSS, \uCEF4\uD3EC\uB10C\uD2B8 \uAC1C\uBC1C":"frontend","API, DB, \uC11C\uBC84 \uB85C\uC9C1 \uAD6C\uD604":"backend","\uB370\uC774\uD130 \uD30C\uC774\uD504\uB77C\uC778, \uBD84\uC11D, ML":"data","\uBB38\uC11C\uD654, README, API docs":"docs","UI/UX, CSS, components":"frontend","API, DB, server logic":"backend","Data pipeline, analysis, ML":"data","Documentation, README, API docs":"docs"},Hn={1:"#60a5fa",2:"#a78bfa",3:"#34d399",4:"#fbbf24",5:"#f472b6"}});var De={};R(De,{filterSkills:()=>Re,loadSkills:()=>Rt,renderSkills:()=>Pe,toggleSkill:()=>Ae});async function Rt(){try{let e=await Dt("/api/skills");l.allSkills=await e.json(),Pe()}catch{let e=document.getElementById("skillsList");e&&(e.innerHTML=`<div style="color:var(--text-dim);font-size:11px">${c("skill.loadFail")}</div>`)}}function Pe(){let e=document.getElementById("skillsList"),t=document.getElementById("skillsCount");if(!e||!t)return;let n=l.allSkills,o=n;l.currentSkillFilter==="installed"?o=n.filter(a=>a.enabled):l.currentSkillFilter==="other"?o=n.filter(a=>!Bn.includes(a.category||"")):l.currentSkillFilter!=="all"&&(o=n.filter(a=>a.category===l.currentSkillFilter));let i=n.filter(a=>a.enabled).length;t.textContent=c("skill.count",{active:i,total:n.length}),e.innerHTML=o.map(a=>{let s=[];return a.requires?.env&&s.push("\u{1F511} "+a.requires.env.join(", ")),a.requires?.bins&&s.push("\u2699\uFE0F "+a.requires.bins.join(", ")),a.install&&s.push(a.install),`
|
|
38
38
|
<div class="skill-card ${a.enabled?"enabled":""}">
|
|
39
39
|
<div class="skill-card-header">
|
|
40
40
|
<span class="skill-emoji">${m(a.emoji||"\u{1F527}")}</span>
|
|
@@ -44,7 +44,7 @@ var Tn=Object.defineProperty;var b=(e,t)=>()=>(e&&(t=e(e=0)),t);var R=(e,t)=>{fo
|
|
|
44
44
|
</div>
|
|
45
45
|
<div class="skill-desc">${m(a.description||"")}</div>
|
|
46
46
|
${s.length?`<div class="skill-req">${s.join(" \xB7 ")}</div>`:""}
|
|
47
|
-
</div>`}).join("")}async function
|
|
47
|
+
</div>`}).join("")}async function Ae(e,t){let n=t?"/api/skills/disable":"/api/skills/enable";try{await y(n,"POST",{id:e}),await Rt()}catch(o){console.error("toggleSkill error:",o)}}function Re(e,t){l.currentSkillFilter=e,document.querySelectorAll(".skill-filter").forEach(n=>n.classList.remove("active")),t&&t.classList.add("active"),Pe()}var Bn,se=b(()=>{"use strict";T();x();L();$();Bn=["productivity","communication","devtools","ai-media","utility","smarthome","automation"]});function le(){try{for(let e of Ot){let t=localStorage.getItem(e);if(t)return t}}catch{}return navigator.language||"ko"}function jt(e){let t=String(e||"").trim();if(t)try{for(let n of Ot)localStorage.setItem(n,t)}catch{}}var Ot,re=b(()=>{"use strict";Ot=["claw_locale","claw.locale"]});var ze={};R(ze,{close:()=>S,handleClick:()=>Ne,handleKeydown:()=>qe,handleOutsideClick:()=>Je,isDropdownOpen:()=>Pn,loadCommands:()=>_e,update:()=>me});function _t(e){let n=String(e||"").slice(1).trim().split(/\s+/)[0]||"";return n.includes("/")||n.includes("\\")}function Oe(e){return String(e||"").replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,""")}function $n(e){let t=String(e||"").toLowerCase();return je.filter(n=>`/${n.name}`.startsWith(t))}function Ft(){let e=de(),t=j();!e||!t||(P&&(clearTimeout(P),P=null),e.style.display="block",requestAnimationFrame(()=>e.classList.add("visible")),O=!0,t.setAttribute("aria-expanded","true"))}function ce(){let e=de(),t=j();if(!e||!t)return;if(!M.length){if(!t.value.startsWith("/")||_t(t.value)){S();return}e.innerHTML=`
|
|
48
48
|
<div class="cmd-item cmd-empty" role="option" aria-disabled="true">
|
|
49
49
|
${c("cmd.noMatch")}
|
|
50
50
|
</div>
|
|
@@ -56,8 +56,8 @@ var Tn=Object.defineProperty;var b=(e,t)=>()=>(e&&(t=e(e=0)),t);var R=(e,t)=>{fo
|
|
|
56
56
|
<span class="cmd-name">/${Oe(o.name)}</span>
|
|
57
57
|
<span class="cmd-desc">${Oe(o.desc)}</span>
|
|
58
58
|
${o.args?`<span class="cmd-args">${Oe(o.args)}</span>`:""}
|
|
59
|
-
</div>`}).join(""),Ft(),t.setAttribute("aria-activedescendant",E>=0?`cmd-item-${E}`:"");let n=e.querySelector(".selected");n&&n.scrollIntoView({block:"nearest"})}function Fe(e){let t=M[E],n=j();if(!t||!n){S();return}if(S(),t.args||!e){n.value=`/${t.name} `,n.focus(),n.selectionStart=n.selectionEnd=n.value.length;return}n.value=`/${t.name}`,n.dispatchEvent(new Event("cmd-execute",{bubbles:!0}))}async function _e(){try{let e=le(),t=`/api/commands?interface=web&locale=${encodeURIComponent(e)}`;je=await f(t,{headers:{"Accept-Language":e}})||[]}catch(e){console.warn("[slash-commands] loadCommands failed:",e.message),je=[]}}function S(){let e=de();
|
|
60
|
-
`)||_t(t)){S();return}M
|
|
59
|
+
</div>`}).join(""),Ft(),t.setAttribute("aria-activedescendant",E>=0?`cmd-item-${E}`:"");let n=e.querySelector(".selected");n&&n.scrollIntoView({block:"nearest"})}function Fe(e){let t=M[E],n=j();if(!t||!n){S();return}if(S(),t.args||!e){n.value=`/${t.name} `,n.focus(),n.selectionStart=n.selectionEnd=n.value.length;return}n.value=`/${t.name}`,n.dispatchEvent(new Event("cmd-execute",{bubbles:!0}))}async function _e(){try{let e=le(),t=`/api/commands?interface=web&locale=${encodeURIComponent(e)}`;je=await f(t,{headers:{"Accept-Language":e}})||[]}catch(e){console.warn("[slash-commands] loadCommands failed:",e.message),je=[]}}function S(){let e=de();P&&(clearTimeout(P),P=null),e&&(e.classList.remove("visible"),P=setTimeout(()=>{e.classList.contains("visible")||(e.style.display="none",e.innerHTML="")},150)),O=!1,E=-1,M=[];let t=j();t&&(t.setAttribute("aria-expanded","false"),t.setAttribute("aria-activedescendant",""))}function me(e){let t=String(e||"");if(!t.startsWith("/")||t.includes(" ")||t.includes(`
|
|
60
|
+
`)||_t(t)){S();return}M=$n(t),E=M.length?0:-1,ce()}function qe(e){return O?M.length?e.key==="ArrowDown"?(e.preventDefault(),E=Math.min(M.length-1,E+1),ce(),!0):e.key==="ArrowUp"?(e.preventDefault(),E=Math.max(0,E-1),ce(),!0):e.key==="Tab"?(e.preventDefault(),Fe(!1),!0):e.key==="Enter"&&!e.shiftKey&&!e.isComposing?(e.preventDefault(),Fe(!0),!0):e.key==="Escape"?(e.preventDefault(),S(),!0):!1:e.key==="Escape"?(e.preventDefault(),S(),!0):!1:(e.key==="ArrowDown"||e.key==="ArrowUp")&&!e.isComposing?(me(j()?.value||""),O?(E=e.key==="ArrowUp"?M.length-1:0,ce(),e.preventDefault(),!0):!1):!1}function Ne(e){let n=e.target.closest(".cmd-item");if(!n)return;let o=parseInt(n.dataset.index||"-1",10);Number.isNaN(o)||o<0||(E=Math.min(o,M.length-1),Fe(!0))}function Je(e){if(!O)return;let t=de(),n=j();if(!t||!n)return;let o=e.target;!t.contains(o)&&o!==n&&S()}function Pn(){return O}var je,M,E,O,P,de,j,ue=b(()=>{"use strict";re();x();L();je=[],M=[],E=-1,O=!1,P=null;de=()=>document.getElementById("cmdDropdown"),j=()=>document.getElementById("chatInput")});var V={};R(V,{applyCustomModel:()=>et,closePromptModal:()=>_,getModelValue:()=>Kt,handleModelSelect:()=>Ze,installMcpGlobal:()=>Xe,loadCliStatus:()=>ye,loadFallbackOrder:()=>Ut,loadMcpServers:()=>Ye,loadSettings:()=>Qe,onCliChange:()=>pe,openPromptModal:()=>nt,saveActiveCliSettings:()=>F,saveFallbackOrder:()=>tt,savePerCli:()=>Y,savePromptFromModal:()=>ot,saveTelegramSettings:()=>ge,setPerm:()=>zt,setTelegram:()=>fe,syncMcpServers:()=>Ve,updateSettings:()=>Ue});function We(e){return e.charAt(0).toUpperCase()+e.slice(1)}function Q(e){return document.getElementById("model"+We(e))}function Nt(e){return document.getElementById("customModel"+We(e))}function Ge(e){return document.getElementById("effort"+We(e))}function Jt(e,t,{includeCustom:n=!1,includeDefault:o=!1,selected:i=""}={}){if(!e)return;let a=o?'<option value="default">default</option>':"",s=n?`<option value="__custom__">${c("model.customOption")}</option>`:"",d=(t||[]).map(r=>`<option value="${m(r)}">${m(r)}</option>`).join("");e.innerHTML=a+d+s,i&&Array.from(e.options).some(r=>r.value===i)&&(e.value=i)}function G(e,t){if(!e||!t||Array.from(e.options).some(i=>i.value===t))return;let n=document.createElement("option");n.value=t,n.textContent=t;let o=e.querySelector('option[value="__custom__"]');o?e.insertBefore(n,o):e.appendChild(n)}function An(e=null){let t=w(),n=document.getElementById("selCli");if(n){let i=e?.cli||n.value||t[0]||"claude";n.innerHTML=t.map(a=>{let s=ie(a)?.label||a;return`<option value="${m(a)}">${m(s)}</option>`}).join(""),Array.from(n.options).some(a=>a.value===i)&&(n.value=i)}let o=document.getElementById("memCli");if(o){let i=e?.memory?.cli||o.value||"";o.innerHTML='<option value="">(active CLI)</option>'+t.map(a=>`<option value="${m(a)}">${m(a)}</option>`).join(""),Array.from(o.options).some(a=>a.value===i)&&(o.value=i)}}function Rn(e=null){for(let t of w()){let n=Q(t);if(n){let i=e?.perCli?.[t]?.model||n.value||"";Jt(n,B[t]||[],{includeCustom:!0,selected:i}),i&&!Array.from(n.options).some(a=>a.value===i)&&(G(n,i),n.value=i)}let o=Ge(t);if(o){let i=ie(t),a=[""].concat(i?.efforts||[]),s=e?.perCli?.[t]?.effort||o.value||"",d=[...new Set(a)],r=i?.efforts?.length===0&&i?.effortNote?i.effortNote:"\u2014 none";o.innerHTML=d.map(u=>u?`<option value="${m(u)}">${m(u)}</option>`:`<option value="">${m(r)}</option>`).join(""),i?.effortNote&&(o.title=i.effortNote),o.disabled=i?.efforts?.length===0&&!!i?.effortNote,Array.from(o.options).some(u=>u.value===s)&&(o.value=s)}}}function Ke(e,t=""){let n=document.getElementById("selEffort");if(!n)return;let o=ie(e);if(o?.effortNote){n.innerHTML=`<option value="">${m(o.effortNote)}</option>`,n.title=o.effortNote,n.disabled=!0;return}let i=[""].concat(o?.efforts||[]),a=[...new Set(i)];n.innerHTML=a.map(s=>s?`<option value="${m(s)}">${m(s)}</option>`:'<option value="">\u2014 none</option>').join(""),n.disabled=!1,n.title="",Array.from(n.options).some(s=>s.value===t)&&(n.value=t)}async function Qe(){await oe();let e=await f("/api/settings");if(!e)return;jt(e.locale??""),An(e),Rn(e);let t=document.getElementById("selCli");t&&Array.from(t.options).some(u=>u.value===e.cli)&&(t.value=e.cli);let n=document.getElementById("inpCwd");n&&(n.textContent=e.workingDir);let o=document.getElementById("headerCli");if(o&&(o.textContent=e.cli),zt(e.permissions,!1),e.perCli)for(let[u,p]of Object.entries(e.perCli)){let v=Q(u),H=Ge(u);v&&p.model&&(G(v,p.model),v.value=p.model),H&&(H.value=p.effort||"")}pe(!1);let i=e.activeOverrides?.[e.cli]||{},a=e.perCli?.[e.cli]||{},s=i.model||a.model,d=i.effort||a.effort||"",r=document.getElementById("selModel");s&&r&&(r.value=s),Ke(e.cli,d),Dn(e),Ut(e),Ye()}async function Ye(){try{let e=await f("/api/mcp");if(!e)return;let t=document.getElementById("mcpServerList");if(!t)return;let n=Object.entries(e.servers||{});if(!n.length){t.textContent=c("mcp.noServers");return}t.innerHTML=n.map(([o,i])=>`<div style="padding:2px 0">\u2022 <b>${o}</b> <span style="opacity:.6">${i.command} ${(i.args||[]).slice(0,2).join(" ")}</span></div>`).join("")}catch{}}async function Ve(){let e=document.getElementById("mcpSyncResult");if(e){e.style.display="block",e.textContent=c("mcp.syncing");try{let t=await y("/api/mcp/sync","POST",{});if(!t){e.textContent="\u274C sync failed";return}let n=t.results||{};e.innerHTML=Object.entries(n).map(([o,i])=>`${i?"\u2705":"\u23ED\uFE0F"} ${o}`).join(" ")}catch(t){e.textContent="\u274C "+t.message}}}async function Xe(){let e=document.getElementById("mcpSyncResult");if(e){e.style.display="block",e.textContent=c("mcp.installing");try{let t=await y("/api/mcp/install","POST",{});if(!t){e.textContent="\u274C install failed";return}e.innerHTML=Object.entries(t.results||{}).map(([n,o])=>`${o.status==="installed"?"\u2705":o.status==="skip"?"\u23ED\uFE0F":"\u274C"} <b>${n}</b>: ${o.status}${o.bin?" \u2192 "+o.bin:""}`).join("<br>"),Ye()}catch(t){e.textContent="\u274C "+t.message}}}async function Ue(){let e={cli:document.getElementById("selCli")?.value||"claude"},t=document.getElementById("headerCli");t&&(t.textContent=e.cli),await y("/api/settings","PUT",e)}function zt(e,t=!0){t&&I("/api/settings","PUT",{permissions:"auto"})}function Kt(e){let t=Q(e);return t?t.value==="__custom__"?Nt(e)?.value?.trim()||t.options[0]?.value||"default":t.value:"default"}function Ze(e,t){let n=Nt(e);n&&(t.value==="__custom__"?(n.style.display="block",n.focus()):(n.style.display="none",Y()))}function et(e,t){let n=t.value.trim();if(!n)return;let o=Q(e);o&&(G(o,n),o.value=n,t.style.display="none",Y())}async function Y(){let e={};for(let t of w()){if(!Q(t))continue;let o=Ge(t);e[t]={model:Kt(t),effort:o?o.value:""}}await y("/api/settings","PUT",{perCli:e})}function pe(e=!0){let t=document.getElementById("selCli")?.value||"claude",n=B[t]||[],o=document.getElementById("selModel");Jt(o,n,{includeCustom:!0,includeDefault:!0});let i=document.getElementById("headerCli");i&&(i.textContent=t),Ke(t);let a=document.getElementById("selModelCustom");a&&a.remove();let s=document.createElement("input");if(s.type="text",s.id="selModelCustom",s.className="custom-model-input",s.placeholder=c("model.placeholder"),s.style.display="none",s.onchange=function(){let d=this.value.trim();!d||!o||(G(o,d),o.value=d,this.style.display="none",F())},!o){e&&Ue();return}o.parentElement?.appendChild(s),o.onchange=function(){this.value==="__custom__"?(s.style.display="block",s.focus()):(s.style.display="none",F())},f("/api/settings").then(d=>{if(!d)return;let r=d.activeOverrides?.[t]||{},u=d.perCli?.[t]||{},p=r.model||u.model,v=r.effort||u.effort||"";p&&o&&(G(o,p),o.value=p),Ke(t,v)}),e&&Ue()}async function F(){let e=document.getElementById("selCli")?.value||"claude",n=document.getElementById("selModel")?.value||"default";n==="__custom__"&&(n=document.getElementById("selModelCustom")?.value?.trim()||"default");let o=document.getElementById("selEffort"),i={};i[e]={model:n},o&&!o.disabled&&(i[e].effort=o.value||""),await y("/api/settings","PUT",{activeOverrides:i})}async function ge(){let e=document.getElementById("tgToken")?.value.trim()||"",t=document.getElementById("tgChatIds")?.value.trim()||"",n=t?t.split(",").map(o=>parseInt(o.trim(),10)).filter(o=>!isNaN(o)):[];await y("/api/settings","PUT",{telegram:{token:e,allowedChatIds:n}})}async function fe(e){document.getElementById("tgOn")?.classList.toggle("active",e),document.getElementById("tgOff")?.classList.toggle("active",!e),await y("/api/settings","PUT",{telegram:{enabled:e}})}function Dn(e){if(!e.telegram)return;let t=e.telegram;document.getElementById("tgOn")?.classList.toggle("active",!!t.enabled),document.getElementById("tgOff")?.classList.toggle("active",!t.enabled);let n=document.getElementById("tgToken");t.token&&n&&(n.value=t.token);let o=document.getElementById("tgChatIds");t.allowedChatIds?.length&&o&&(o.value=t.allowedChatIds.join(", "))}function Ut(e){let t=document.getElementById("fallbackOrderList");if(!t)return;let n=Object.keys(e.perCli||{}),o=e.fallbackOrder||[],i=Math.min(n.length-1,3),a="";for(let s=0;s<i;s++){let d=o[s]||"",r=n.map(u=>`<option value="${u}" ${u===d?"selected":""}>${u}</option>`).join("");a+=`
|
|
61
61
|
<div class="settings-row sub-row">
|
|
62
62
|
<label style="min-width:60px">Fallback ${s+1}</label>
|
|
63
63
|
<select id="fallback${s}"
|
|
@@ -71,11 +71,11 @@ var Tn=Object.defineProperty;var b=(e,t)=>()=>(e&&(t=e(e=0)),t);var R=(e,t)=>{fo
|
|
|
71
71
|
<div style="color:var(--text-dim)"><code style="font-size:10px;background:var(--border);padding:1px 4px;border-radius:2px">${m(g.install)}</code></div>
|
|
72
72
|
<div style="color:var(--text-dim);margin-top:2px"><code style="font-size:10px;background:var(--border);padding:1px 4px;border-radius:2px">${m(g.auth)}</code></div>
|
|
73
73
|
</div>
|
|
74
|
-
`)}let H="";r?.windows?.length&&(H=r.windows.map(g=>{let ne=Math.round(g.percent),
|
|
74
|
+
`)}let H="";r?.windows?.length&&(H=r.windows.map(g=>{let ne=Math.round(g.percent),In=ne>80?"#ef4444":ne>50?"#fbbf24":"#38bdf8";return`
|
|
75
75
|
<div style="display:flex;align-items:center;gap:6px;margin-left:16px;font-size:10px;color:var(--text-dim)">
|
|
76
76
|
<span style="width:42px">${g.label}</span>
|
|
77
77
|
<div style="flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden">
|
|
78
|
-
<div style="width:${ne}%;height:100%;background:${
|
|
78
|
+
<div style="width:${ne}%;height:100%;background:${In};border-radius:2px"></div>
|
|
79
79
|
</div>
|
|
80
80
|
<span style="width:28px;text-align:right">${ne}%</span>
|
|
81
81
|
</div>
|
|
@@ -89,18 +89,18 @@ var Tn=Object.defineProperty;var b=(e,t)=>()=>(e&&(t=e(e=0)),t);var R=(e,t)=>{fo
|
|
|
89
89
|
${v}
|
|
90
90
|
${H}
|
|
91
91
|
</div>
|
|
92
|
-
`}o&&(o.innerHTML=a)}function nt(){f("/api/prompt").then(e=>{if(!e)return;let t=document.getElementById("modalPromptEditor");t&&(t.value=e.content||""),document.getElementById("promptModal")?.classList.add("open")})}function _(e){e&&e.target!==e.currentTarget||document.getElementById("promptModal")?.classList.remove("open")}async function ot(){let t=document.getElementById("modalPromptEditor")?.value||"";await y("/api/prompt","PUT",{content:t}),document.getElementById("promptModal")?.classList.remove("open")}var q=b(()=>{"use strict";ae();$();re();x();L();T()});async function Wt(){let e=null;try{e=localStorage.getItem("claw_locale")}catch{}if(!e){let t=(navigator.language||"ko").split(/[-_]/)[0].toLowerCase();e=["en","ko"].includes(t)?t:"ko"}ve=await it("ko"),e==="ko"?Z=ve:Z=await it(e),X=e,Gt()}async function it(e){try{let{api:t}=await Promise.resolve().then(()=>(L(),It));return await t(`/api/i18n/${e}`)||{}}catch{return{}}}function c(e,t={}){let n=Z[e]??ve[e]??e;for(let[o,i]of Object.entries(t))n=n.replaceAll(`{${o}}`,String(i));return n}function Gt(){document.querySelectorAll("[data-i18n]").forEach(e=>{let t=e.getAttribute("data-i18n");t&&(e.textContent=c(t))}),document.querySelectorAll("[data-i18n-placeholder]").forEach(e=>{let t=e.getAttribute("data-i18n-placeholder");t&&(e.placeholder=c(t))}),document.querySelectorAll("[data-i18n-title]").forEach(e=>{let t=e.getAttribute("data-i18n-title");t&&(e.title=c(t))}),document.querySelectorAll("[data-i18n-aria]").forEach(e=>{let t=e.getAttribute("data-i18n-aria");t&&e.setAttribute("aria-label",c(t))})}async function Qt(e){if(e!==X){e==="ko"?Z=ve:Z=await it(e),X=e;try{localStorage.setItem("claw_locale",e)}catch{}Gt();try{let{loadEmployees:t}=await Promise.resolve().then(()=>(D(),W));t()}catch{}try{let{loadSkills:t}=await Promise.resolve().then(()=>(se(),De));t()}catch{}try{let{loadCommands:t}=await Promise.resolve().then(()=>(ue(),ze));t()}catch{}try{let{loadSettings:t}=await Promise.resolve().then(()=>(q(),V));t()}catch{}}}function ee(){return X}function Dt(e,t={}){let n=new URL(e,location.origin);return n.searchParams.has("locale")||n.searchParams.set("locale",X),fetch(n.toString(),t)}var X,Z,ve,x=b(()=>{"use strict";X="ko",Z={},ve={}});function m(e){return e.replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,""").replace(/'/g,"'")}function
|
|
92
|
+
`}o&&(o.innerHTML=a)}function nt(){f("/api/prompt").then(e=>{if(!e)return;let t=document.getElementById("modalPromptEditor");t&&(t.value=e.content||""),document.getElementById("promptModal")?.classList.add("open")})}function _(e){e&&e.target!==e.currentTarget||document.getElementById("promptModal")?.classList.remove("open")}async function ot(){let t=document.getElementById("modalPromptEditor")?.value||"";await y("/api/prompt","PUT",{content:t}),document.getElementById("promptModal")?.classList.remove("open")}var q=b(()=>{"use strict";ae();$();re();x();L();T()});async function Wt(){let e=null;try{e=localStorage.getItem("claw_locale")}catch{}if(!e){let t=(navigator.language||"ko").split(/[-_]/)[0].toLowerCase();e=["en","ko"].includes(t)?t:"ko"}ve=await it("ko"),e==="ko"?Z=ve:Z=await it(e),X=e,Gt()}async function it(e){try{let{api:t}=await Promise.resolve().then(()=>(L(),It));return await t(`/api/i18n/${e}`)||{}}catch{return{}}}function c(e,t={}){let n=Z[e]??ve[e]??e;for(let[o,i]of Object.entries(t))n=n.replaceAll(`{${o}}`,String(i));return n}function Gt(){document.querySelectorAll("[data-i18n]").forEach(e=>{let t=e.getAttribute("data-i18n");t&&(e.textContent=c(t))}),document.querySelectorAll("[data-i18n-placeholder]").forEach(e=>{let t=e.getAttribute("data-i18n-placeholder");t&&(e.placeholder=c(t))}),document.querySelectorAll("[data-i18n-title]").forEach(e=>{let t=e.getAttribute("data-i18n-title");t&&(e.title=c(t))}),document.querySelectorAll("[data-i18n-aria]").forEach(e=>{let t=e.getAttribute("data-i18n-aria");t&&e.setAttribute("aria-label",c(t))})}async function Qt(e){if(e!==X){e==="ko"?Z=ve:Z=await it(e),X=e;try{localStorage.setItem("claw_locale",e)}catch{}Gt();try{let{loadEmployees:t}=await Promise.resolve().then(()=>(D(),W));t()}catch{}try{let{loadSkills:t}=await Promise.resolve().then(()=>(se(),De));t()}catch{}try{let{loadCommands:t}=await Promise.resolve().then(()=>(ue(),ze));t()}catch{}try{let{loadSettings:t}=await Promise.resolve().then(()=>(q(),V));t()}catch{}}}function ee(){return X}function Dt(e,t={}){let n=new URL(e,location.origin);return n.searchParams.has("locale")||n.searchParams.set("locale",X),fetch(n.toString(),t)}var X,Z,ve,x=b(()=>{"use strict";X="ko",Z={},ve={}});function Yt(e){let t=[],n=e.replace(/```[\s\S]*?```/g,o=>(t.push(o),`\0P${t.length-1}\0`)).replace(/`[^`]+`/g,o=>(t.push(o),`\0P${t.length-1}\0`));return n=n.replace(/([\p{P}])\*\*(?=[^\s\p{P}])/gu,(o,i)=>i==="*"?o:i+"\u200B**"),n=n.replace(/\x00P(\d+)\x00/g,(o,i)=>t[Number(i)]),n}var Vt=b(()=>{"use strict"});function m(e){return e.replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,""").replace(/'/g,"'")}function en(e){return typeof DOMPurify<"u"?DOMPurify.sanitize(e,{USE_PROFILES:{html:!0,svg:!0,svgFilters:!0},FORBID_TAGS:["script","style","iframe","object","embed","form"],FORBID_ATTR:["onerror","onclick","onload","onmouseover","onfocus","onblur"],ADD_TAGS:["use"]}):e.replace(/<script[\s\S]*?>[\s\S]*?<\/script>/gi,"").replace(/\bon\w+\s*=/gi,"data-removed=").replace(/javascript\s*:/gi,"about:blank")}function On(e){let t=e.replace(/```json\n[\s\S]*?\n```/g,"");return t=t.replace(/\{[\s\S]*"subtasks"\s*:\s*\[[\s\S]*?\]\s*\}/g,"").trim(),t}function jn(e){return typeof katex>"u"||(e=e.replace(/\$\$([\s\S]+?)\$\$/g,(t,n)=>{try{return katex.renderToString(n.trim(),{displayMode:!0,throwOnError:!1})}catch{return`<code>${m(n)}</code>`}}),e=e.replace(/(?<!\$)\$(?!\$)([^\n$]+?)\$(?!\$)/g,(t,n)=>{try{return katex.renderToString(n.trim(),{displayMode:!1,throwOnError:!1})}catch{return`<code>${m(n)}</code>`}})),e}function _n(){typeof mermaid>"u"||document.querySelectorAll(".mermaid-pending").forEach(async e=>{e.classList.remove("mermaid-pending");let t=e.textContent||"",n=`mermaid-${++Fn}`;try{let{svg:o}=await mermaid.render(n,t);e.innerHTML=en(o),e.classList.add("mermaid-rendered")}catch(o){let i=o?.message||o?.str||"Unknown error";e.innerHTML=`
|
|
93
93
|
<div style="border:1px solid #ef4444;border-radius:6px;padding:8px;margin:4px 0">
|
|
94
94
|
<div style="color:#ef4444;font-size:11px;margin-bottom:4px">\u26A0\uFE0F ${m(c("mermaid.renderFail")||"Mermaid render failed")}</div>
|
|
95
95
|
<div style="color:#fbbf24;font-size:10px;margin-bottom:6px">${m(i.slice(0,200))}</div>
|
|
96
96
|
<pre style="margin:0;font-size:11px;overflow-x:auto"><code>${m(t)}</code></pre>
|
|
97
|
-
</div>`}})}function
|
|
98
|
-
`);i=`<details class="tool-summary"><summary>${s}</summary><div class="tool-log">${d}</div></details>`}o&&(o.innerHTML=i+at(e))}l.currentAgentDiv=null,
|
|
99
|
-
`);n&&(u+=c("chat.file.sentWithMsg",{text:n})),Ee(),await y("/api/message","POST",{prompt:u})}catch(r){h(c("chat.file.uploadFail",{msg:r.message})),Ee()}}else{k("user",n),e.value="",vt();let s=await fetch("/api/message",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({prompt:n})}),d=await s.json().catch(()=>({}));if(!s.ok){h(`\u274C ${d.error||c("chat.requestFail",{status:s.status})}`,"","error");return}if(d.queued){let{updateQueueBadge:r}=await Promise.resolve().then(()=>(z(),gt));r(d.pending||1)}else d.continued&&h(c("chat.continue"))}}function
|
|
97
|
+
</div>`}})}function qn(){if(Xt)return!0;if(typeof marked>"u")return!1;let e=new marked.Renderer;return e.code=function({text:t,lang:n}){if(n==="mermaid")return`<div class="mermaid-container mermaid-pending">${m(t)}</div>`;let o=m(t);if(typeof hljs<"u"&&n&&hljs.getLanguage(n))try{o=hljs.highlight(t,{language:n}).value}catch{}else if(typeof hljs<"u")try{o=hljs.highlightAuto(t).value}catch{}let i=n?m(n):c("code.copy");return`<div class="code-block-wrapper">${`<span class="code-lang-label" data-lang="${n?m(n):""}">${i}</span>`}<pre><code class="hljs${n?` language-${m(n)}`:""}">${o}</code></pre></div>`},marked.setOptions({renderer:e,gfm:!0,breaks:!0}),typeof window.mermaid<"u"&&window.mermaid.initialize({startOnLoad:!1,theme:"dark",securityLevel:"strict"}),Xt=!0,!0}function Nn(e){return m(e).replace(/`{3,}(\w*)\n([\s\S]*?)`{3,}/g,"<pre><code>$2</code></pre>").replace(/`([^`]+)`/g,"<code>$1</code>").replace(/\*\*(.+?)\*\*/g,"<strong>$1</strong>").replace(/^### (.+)$/gm,'<div style="font-weight:700;margin:8px 0 4px">$1</div>').replace(/^## (.+)$/gm,'<div style="font-weight:700;font-size:14px;margin:10px 0 4px">$1</div>').replace(/^# (.+)$/gm,'<div style="font-weight:700;font-size:16px;margin:12px 0 4px">$1</div>').replace(/\n/g,"<br>")}function tn(){typeof hljs>"u"||document.querySelectorAll(".code-block-wrapper pre code").forEach(e=>{if(e.dataset.highlighted==="yes")return;let t=[...e.classList].find(o=>o.startsWith("language-"))?.replace("language-",""),n=e.textContent||"";try{t&&hljs.getLanguage(t)?e.innerHTML=hljs.highlight(n,{language:t}).value:e.innerHTML=hljs.highlightAuto(n).value,e.dataset.highlighted="yes"}catch{}})}function Jn(){Zt||(Zt=!0,document.addEventListener("click",e=>{let t=e.target?.closest(".code-lang-label");if(!t)return;let n=t.closest(".code-block-wrapper");if(!n)return;let o=n.querySelector("pre code");o&&navigator.clipboard.writeText(o.textContent||"").then(()=>{let i=t.textContent||"";t.textContent=c("code.copied"),t.classList.add("copied"),setTimeout(()=>{t.textContent=i,t.classList.remove("copied")},1500)}).catch(()=>{})}))}function at(e){let t=On(e);if(!t)return`<em style="color:var(--text-dim)">${m(c("orchestrator.dispatching"))}</em>`;let n;if(qn()){let o=Yt(t);n=marked.parse(o),n=n.replace(/<table/g,'<div class="table-wrapper"><table').replace(/<\/table>/g,"</table></div>")}else n=Nn(t);return n=jn(n),n=en(n),requestAnimationFrame(()=>{_n(),tn()}),Jn(),n}var Fn,Xt,Zt,$=b(()=>{"use strict";x();Vt();Fn=0;Xt=!1;(function e(){if(typeof hljs<"u"){tn();return}setTimeout(e,200)})();Zt=!1});function an(){return N}function nn(e){N=(e||"").trim()||st,localStorage.setItem(on,N);let t=document.getElementById("appNameInput");t&&(t.value=N)}function sn(){N=localStorage.getItem(on)||st;let e=document.getElementById("appNameInput");e&&(e.value=N),document.getElementById("appNameSave")?.addEventListener("click",()=>{let t=document.getElementById("appNameInput");t&&nn(t.value)}),document.getElementById("appNameInput")?.addEventListener("keydown",t=>{let n=t;n.key==="Enter"&&(n.preventDefault(),nn(n.target.value),n.target.blur())})}var on,st,N,lt=b(()=>{"use strict";on="agentName",st="CLI-JAW",N=st});var gt={};R(gt,{addMessage:()=>k,addSystemMsg:()=>h,appendAgentText:()=>rt,finalizeAgent:()=>be,handleSave:()=>mt,initMsgCopy:()=>pt,loadMemory:()=>ut,loadMessages:()=>zn,loadStats:()=>rn,scrollToBottom:()=>ct,setStatus:()=>J,switchTab:()=>dt,updateQueueBadge:()=>he});function J(e){let t=document.getElementById("statusBadge"),n=document.getElementById("btnSend");l.agentBusy=e==="running",document.getElementById("typingIndicator")?.classList.toggle("active",l.agentBusy),e==="running"?(t&&(t.className="status-badge status-running",t.textContent="\u23F3 running"),n&&(n.textContent="\u25A0",n.title=c("btn.stop"),n.classList.add("stop-mode"))):(t&&(t.className="status-badge status-idle",t.textContent="\u26A1 idle"),n&&(n.textContent="\u27A4",n.title="Send",n.classList.remove("stop-mode")),he(0))}function he(e){let t=document.getElementById("queueBadge");if(!t){t=document.createElement("span"),t.id="queueBadge",t.style.cssText="position:absolute;top:-6px;right:-6px;background:#f80;color:#fff;border-radius:50%;font-size:11px;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-weight:bold";let n=document.getElementById("btnSend");n?.parentElement&&(n.parentElement.style.position="relative"),n&&(n.style.position="relative",n.appendChild(t))}t.textContent=e>0?String(e):"",t.style.display=e>0?"flex":"none"}function h(e,t,n){let o=document.getElementById("chatMessages");if(!o)return;let i=document.createElement("div"),a=n?` msg-type-${n}`:"";i.className="msg msg-system"+a+(t?" "+t:""),i.textContent=e,o.appendChild(i),o.scrollTop=o.scrollHeight}function rt(e){if(!e)return;l.currentAgentDiv||(l.currentAgentDiv=k("agent",""));let t=l.currentAgentDiv?.querySelector(".msg-content");t&&(t.textContent+=e),ct()}function be(e,t){let n=Date.now();if(!(!l.currentAgentDiv&&n-ln<500)){if(document.querySelectorAll(".msg-system.tool-activity").forEach(o=>o.remove()),e){l.currentAgentDiv||(l.currentAgentDiv=k("agent",""));let o=l.currentAgentDiv?.querySelector(".msg-content"),i="";if(t&&t.length>0){let a={};t.forEach(r=>{a[r.icon]=(a[r.icon]||0)+1});let s=Object.entries(a).map(([r,u])=>`${r}\xD7${u}`).join(" "),d=t.map(r=>`${r.icon} ${m(r.label)}`).join(`
|
|
98
|
+
`);i=`<details class="tool-summary"><summary>${s}</summary><div class="tool-log">${d}</div></details>`}o&&(o.innerHTML=i+at(e))}l.currentAgentDiv=null,ln=Date.now(),J("idle"),rn()}}function k(e,t){let n=document.getElementById("chatMessages"),o=document.createElement("div");o.className=`msg msg-${e}`;let i=at(t);return o.innerHTML=`<div class="msg-label">${e==="user"?c("msg.you"):an()}</div><div class="msg-content">${i}</div>`,n?.appendChild(o),ct(),o}function ct(){let e=document.getElementById("chatMessages");e&&(e.scrollTop=e.scrollHeight)}function dt(e,t){document.querySelectorAll(".tab-btn").forEach(o=>o.classList.remove("active")),document.querySelectorAll(".tab-content").forEach(o=>o.classList.remove("active"));let n={agents:"tabAgents",settings:"tabSettings",skills:"tabSkills"};document.getElementById(n[e])?.classList.add("active"),t&&t.classList.add("active"),e==="settings"&&Promise.resolve().then(()=>(q(),V)).then(o=>o.loadSettings()),e==="agents"&&Promise.resolve().then(()=>(D(),W)).then(o=>o.loadEmployees()),e==="skills"&&Promise.resolve().then(()=>(se(),De)).then(o=>o.loadSkills())}function mt(){document.getElementById("tabSettings")?.classList.contains("active")?Promise.resolve().then(()=>(q(),V)).then(t=>t.savePerCli()):Promise.resolve().then(()=>(q(),V)).then(t=>t.updateSettings())}async function rn(){let e=await f("/api/messages");if(!e)return;let t=document.getElementById("statMsgs");t&&(t.textContent=c("stat.messages",{count:e.length}))}async function zn(){let e=await f("/api/messages");e&&e.forEach(t=>k(t.role==="assistant"?"agent":t.role,t.content))}async function ut(){try{let e=await f("/api/memory"),t=document.getElementById("memoryList");if(!t||!e)return;if(e.length===0){t.innerHTML=`<li style="color:var(--text-dim)">${c("mem.empty")}</li>`;return}t.innerHTML=e.map(n=>`<li><span class="memory-key">${m(n.key)}</span>: ${m(n.value)}</li>`).join("")}catch{}}function pt(){document.getElementById("chatMessages")?.addEventListener("click",e=>{e.target?.closest(".msg-content")}),document.getElementById("chatMessages")?.addEventListener("dblclick",e=>{let t=e.target?.closest(".msg-content");if(!t)return;let n=t.innerText||t.textContent||"";navigator.clipboard.writeText(n).catch(()=>{})})}var ln,z=b(()=>{"use strict";T();$();lt();x();L();ln=0});function ft(){l.ws=new WebSocket(`ws://${location.host}?lang=${ee()}`),l.ws.onmessage=e=>{let t=JSON.parse(e.data);if(t.type==="agent_status")t.running!==void 0?J(t.running?"running":"idle"):J(t.status||"idle"),t.agentId&&t.phase&&(cn[t.agentId]={phase:t.phase,phaseLabel:t.phaseLabel||""},Promise.resolve().then(()=>(D(),W)).then(n=>n.loadEmployees()));else if(t.type==="queue_update")he(t.pending||0);else if(t.type==="worklog_created")h(`\u{1F4CB} Worklog: ${t.path||""}`);else if(t.type==="round_start"){let n=t.agentPhases||t.subtasks||[],o=n.map(i=>i.agent||i.name||"").join(", ");h(c("ws.roundStart",{round:t.round||0,count:n.length,names:o}))}else if(t.type==="round_done")t.action==="complete"?h(c("ws.roundDone",{round:t.round||0})):t.action==="next"?h(c("ws.roundNext",{round:t.round||0})):h(c("ws.roundRetry",{round:t.round||0}));else if(t.type==="agent_tool")h(`${t.icon||""} ${t.label||""}`,"tool-activity");else if(t.type==="agent_output")rt(t.text||"");else if(t.type==="agent_fallback")h(c("ws.fallback",{from:t.from||"",to:t.to||""}),"tool-activity");else if(t.type==="agent_done")be(t.text||"",t.toolLog);else if(t.type==="orchestrate_done")be(t.text||"");else if(t.type==="clear"){let n=document.getElementById("chatMessages");n&&(n.innerHTML="")}else t.type==="agent_added"||t.type==="agent_updated"||t.type==="agent_deleted"?Promise.resolve().then(()=>(D(),W)).then(n=>n.loadEmployees()):t.type==="new_message"&&t.source==="telegram"&&k(t.role==="assistant"?"agent":t.role||"user",t.content||"")},l.ws.onopen=()=>{console.log("[ws] connected"),Promise.resolve().then(()=>(z(),gt)).then(e=>{let t=document.getElementById("chatMessages");t&&(t.innerHTML=""),e.loadMessages(),e.setStatus("idle")})},l.ws.onclose=()=>{console.log("[ws] disconnected, reconnecting in 2s..."),J("idle"),setTimeout(ft,2e3)}}function At(e){return cn[e]||null}var cn,$e=b(()=>{"use strict";T();z();x();cn={}});$e();z();T();z();re();x();ue();L();async function Le(){let e=document.getElementById("chatInput"),t=document.getElementById("btnSend");if(!e||!t)return;if(t.classList.contains("stop-mode")&&!e.value.trim()&&!l.attachedFiles.length){I("/api/stop","POST");return}let n=e.value.trim();if(!n&&!l.attachedFiles.length)return;let i=n.slice(1).trim().split(/\s+/)[0]||"",a=i.includes("/")||i.includes("\\");if(n.startsWith("/")&&!l.attachedFiles.length&&!a){e.value="",vt(),S();try{let s,d;if(typeof AbortSignal?.timeout=="function")s=AbortSignal.timeout(1e4);else{let v=new AbortController;s=v.signal,d=setTimeout(()=>v.abort(),1e4)}let r=le(),u=await fetch("/api/command",{method:"POST",headers:{"Content-Type":"application/json","Accept-Language":r},body:JSON.stringify({text:n,locale:r}),signal:s});d&&clearTimeout(d);let p=await u.json().catch(()=>({}));if(p?.code==="not_command"){k("user",n),await y("/api/message","POST",{prompt:n});return}if(!u.ok&&!p?.text)throw new Error(`HTTP ${u.status}`);if(p?.code==="clear_screen"){let v=document.getElementById("chatMessages");v&&(v.innerHTML="")}p?.text&&h(p.text,"",p.type)}catch(s){h(c("chat.cmd.fail",{msg:s.message}),"","error")}return}if(l.attachedFiles.length){let d=`[\u{1F4CE} ${l.attachedFiles.map(r=>r.name).join(", ")}] ${n}`;k("user",d),e.value="",vt();try{let u=(await Promise.all(l.attachedFiles.map(p=>Kn(p)))).map(p=>c("chat.file.sent",{path:p})).join(`
|
|
99
|
+
`);n&&(u+=c("chat.file.sentWithMsg",{text:n})),Ee(),await y("/api/message","POST",{prompt:u})}catch(r){h(c("chat.file.uploadFail",{msg:r.message})),Ee()}}else{k("user",n),e.value="",vt();let s=await fetch("/api/message",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({prompt:n})}),d=await s.json().catch(()=>({}));if(!s.ok){h(`\u274C ${d.error||c("chat.requestFail",{status:s.status})}`,"","error");return}if(d.queued){let{updateQueueBadge:r}=await Promise.resolve().then(()=>(z(),gt));r(d.pending||1)}else d.continued&&h(c("chat.continue"))}}function dn(e){e.key==="Enter"&&!e.shiftKey&&!e.isComposing&&(e.preventDefault(),Le())}async function Kn(e){let t=await fetch("/api/upload",{method:"POST",headers:{"X-Filename":encodeURIComponent(e.name)},body:e});if(!t.ok)throw new Error("upload failed");return(await t.json()).path}function yt(e){for(let t of e)l.attachedFiles.some(n=>n.name===t.name)||l.attachedFiles.push(t);ht(),document.getElementById("chatInput")?.focus()}function mn(e){l.attachedFiles.splice(e,1),ht()}function Ee(){l.attachedFiles=[],ht();let e=document.getElementById("fileInput");e&&(e.value="")}function ht(){let e=document.getElementById("filePreview"),t=document.getElementById("filePreviewList");if(e){if(!l.attachedFiles.length){e.classList.remove("visible"),t&&(t.innerHTML="");return}e.classList.add("visible"),t&&(t.innerHTML=l.attachedFiles.map((n,o)=>{let i=(n.size/1024).toFixed(1);return`<div class="file-chip">
|
|
100
100
|
${n.type.startsWith("image/")?`<img src="${URL.createObjectURL(n)}" class="file-chip-thumb" alt="">`:""}
|
|
101
101
|
<span class="file-chip-name">\u{1F4CE} ${n.name} (${i}KB)</span>
|
|
102
102
|
<button class="file-chip-remove" data-file-idx="${o}" title="Remove">\u2715</button>
|
|
103
|
-
</div>`}).join(""))}}async function
|
|
103
|
+
</div>`}).join(""))}}async function un(){I("/api/clear","POST");let e=document.getElementById("chatMessages");e&&(e.innerHTML="")}function Un(e){e.style.height="auto",e.style.height=e.scrollHeight+"px"}function pn(){let e=document.getElementById("chatInput");e&&e.addEventListener("input",()=>Un(e))}function vt(){let e=document.getElementById("chatInput");e&&(e.style.height="auto")}function gn(){let e=document.querySelector(".chat-area"),t=document.getElementById("dragOverlay");if(!e||!t)return;let n=0;e.addEventListener("dragenter",o=>{o.preventDefault(),n++,t.classList.add("visible")}),e.addEventListener("dragleave",o=>{o.preventDefault(),n--,n<=0&&(n=0,t.classList.remove("visible"))}),e.addEventListener("dragover",o=>o.preventDefault()),e.addEventListener("drop",o=>{o.preventDefault(),n=0,t.classList.remove("visible");let a=[...o.dataTransfer?.files||[]];a.length&&yt(a)}),document.getElementById("fileInput")?.addEventListener("change",o=>{let i=o.target,a=[...i.files||[]];a.length&&yt(a),i.value=""}),document.addEventListener("paste",o=>{let i=o.clipboardData?.items;if(!i)return;let a=[];for(let s of i){if(s.kind!=="file")continue;let d=s.getAsFile();if(d)if(!d.name||d.name==="image.png"){let r=new Date().toISOString().replace(/[:.]/g,"-"),u=d.type.split("/")[1]||"png",p=new File([d],`pasted-${r}.${u}`,{type:d.type});a.push(p)}else a.push(d)}a.length&&(o.preventDefault(),yt(a))})}ue();se();q();D();T();x();L();$();async function fn(){let e=await f("/api/heartbeat");l.heartbeatJobs=e?.jobs||[],xe(),document.getElementById("heartbeatModal")?.classList.add("open")}function bt(e){e&&e.target!==e.currentTarget||document.getElementById("heartbeatModal")?.classList.remove("open")}function xe(){let e=document.getElementById("hbJobsList");if(!e)return;let t=l.heartbeatJobs;t.length===0?e.innerHTML=`<p style="color:var(--text-dim);font-size:12px;text-align:center">${c("hb.empty")}</p>`:e.innerHTML=t.map((i,a)=>`
|
|
104
104
|
<div class="hb-job-card">
|
|
105
105
|
<div class="hb-job-header">
|
|
106
106
|
<input type="text" value="${m(String(i.name||""))}" placeholder="${c("hb.name")}"
|
|
@@ -116,7 +116,7 @@ var Tn=Object.defineProperty;var b=(e,t)=>()=>(e&&(t=e(e=0)),t);var R=(e,t)=>{fo
|
|
|
116
116
|
<textarea class="hb-prompt" rows="2" placeholder="${c("hb.prompt")}"
|
|
117
117
|
data-hb-prompt="${a}">${m(String(i.prompt||""))}</textarea>
|
|
118
118
|
</div>
|
|
119
|
-
`).join("");let n=t.filter(i=>i.enabled).length,o=document.getElementById("hbSidebarBtn");o&&(o.textContent=`\u{1F493} Heartbeat (${n})`)}function
|
|
119
|
+
`).join("");let n=t.filter(i=>i.enabled).length,o=document.getElementById("hbSidebarBtn");o&&(o.textContent=`\u{1F493} Heartbeat (${n})`)}function yn(){l.heartbeatJobs.push({id:"hb_"+Date.now(),name:"",enabled:!0,schedule:{kind:"every",minutes:5},prompt:""}),xe(),A()}function vn(e){l.heartbeatJobs.splice(e,1),xe(),A()}function hn(e){let t=l.heartbeatJobs;t[e].enabled=!t[e].enabled,xe(),A()}async function A(){await y("/api/heartbeat","PUT",{jobs:l.heartbeatJobs})}async function bn(){try{let t=((await f("/api/heartbeat"))?.jobs||[]).filter(o=>o.enabled).length,n=document.getElementById("hbSidebarBtn");n&&(n.textContent=`\u{1F493} Heartbeat (${t})`)}catch{}}$();L();async function Me(){let e=await f("/api/memory-files");if(!e)return;let t=p=>document.getElementById(p);t("memOn")?.classList.toggle("active",e.enabled),t("memOff")?.classList.toggle("active",!e.enabled);let n=t("memFlushEvery");n&&(n.value=String(e.flushEvery));let o=t("memCli");o&&(o.value=e.cli||"");let i=t("memModel");i&&(i.value=e.model||"");let a=t("memRetention");a&&(a.value=String(e.retentionDays));let s=t("memPath");s&&(s.textContent=e.path);let d=t("memCounter");d&&(d.textContent=String(e.counter));let r=t("memThreshold");r&&(r.textContent=String(e.flushEvery)),Wn(e.files);let u=t("memorySidebarBtn");u&&(u.textContent=`\u{1F9E0} Memory (${e.files.length})`),t("memoryModal")?.classList.add("open")}function Et(e){e&&e.target!==e.currentTarget||document.getElementById("memoryModal")?.classList.remove("open")}function Lt(e){let t=document.getElementById("memTabSettings"),n=document.getElementById("memTabFiles");t&&(t.style.display=e==="settings"?"":"none"),n&&(n.style.display=e==="files"?"":"none"),document.getElementById("memTabBtnSettings")?.classList.toggle("active",e==="settings"),document.getElementById("memTabBtnFiles")?.classList.toggle("active",e==="files")}async function xt(e){document.getElementById("memOn")?.classList.toggle("active",e),document.getElementById("memOff")?.classList.toggle("active",!e),await y("/api/memory-files/settings","PUT",{enabled:e})}async function te(){let e=document.getElementById("memFlushEvery"),t=document.getElementById("memCli"),n=document.getElementById("memModel"),o=document.getElementById("memRetention");await y("/api/memory-files/settings","PUT",{flushEvery:+(e?.value||10),cli:t?.value||"",model:n?.value||"",retentionDays:+(o?.value||30)});let i=document.getElementById("memThreshold");i&&e&&(i.textContent=e.value)}function Wn(e){let t=document.getElementById("memFilesList");if(t){if(!e||e.length===0){t.innerHTML='<p style="color:var(--text-dim);font-size:12px;text-align:center">No memory files yet</p>';return}t.innerHTML=e.map(n=>`
|
|
120
120
|
<div style="display:flex;align-items:center;justify-content:space-between;padding:6px 8px;border:1px solid var(--border);border-radius:4px;margin-bottom:4px;cursor:pointer"
|
|
121
121
|
data-mem-view="${m(n.name)}">
|
|
122
122
|
<div>
|
|
@@ -125,11 +125,11 @@ var Tn=Object.defineProperty;var b=(e,t)=>()=>(e&&(t=e(e=0)),t);var R=(e,t)=>{fo
|
|
|
125
125
|
</div>
|
|
126
126
|
<button data-mem-delete="${m(n.name)}" style="background:none;border:none;color:#f55;cursor:pointer;font-size:14px">\u{1F5D1}\uFE0F</button>
|
|
127
127
|
</div>
|
|
128
|
-
`).join("")}}async function
|
|
128
|
+
`).join("")}}async function En(e){confirm("Delete "+e+"?")&&(await y("/api/memory-files/"+e,"DELETE",{}),Me())}async function Ln(e){let t=await f("/api/memory-files/"+e);if(!t)return;let n=document.getElementById("memFilesList");n&&(n.innerHTML=`
|
|
129
129
|
<div style="margin-bottom:8px;display:flex;justify-content:space-between;align-items:center">
|
|
130
130
|
<span style="font-size:12px;font-weight:600">${t.name}</span>
|
|
131
131
|
<button data-mem-back style="background:none;border:none;color:var(--accent);cursor:pointer;font-size:11px">\u2190 back</button>
|
|
132
132
|
</div>
|
|
133
133
|
<pre style="background:var(--bg);padding:8px;border-radius:4px;font-size:11px;white-space:pre-wrap;max-height:50vh;overflow-y:auto;color:var(--text)">${m(t.content)}</pre>
|
|
134
|
-
`)}T();ae();lt();var Mt="sidebarState";function En(){let e=JSON.parse(localStorage.getItem(Mt)||"{}");e.left&&document.body.classList.add("left-collapsed"),e.right&&document.body.classList.add("right-collapsed"),document.getElementById("toggleLeft")?.addEventListener("click",St),document.getElementById("toggleRight")?.addEventListener("click",kt),window.addEventListener("resize",()=>{if(window.innerWidth>900){document.body.classList.remove("left-expanded","right-expanded");let t=JSON.parse(localStorage.getItem(Mt)||"{}");document.body.classList.toggle("left-collapsed",!!t.left),document.body.classList.toggle("right-collapsed",!!t.right)}else document.body.classList.remove("left-collapsed","right-collapsed");Se()}),window.innerWidth<=900&&document.body.classList.remove("left-collapsed","right-collapsed"),Se()}function ke(){return window.innerWidth<=900}function St(){ke()?document.body.classList.toggle("left-expanded"):document.body.classList.toggle("left-collapsed"),Ln(),Se()}function kt(){ke()?document.body.classList.toggle("right-expanded"):document.body.classList.toggle("right-collapsed"),Ln(),Se()}function Un(){return ke()?document.body.classList.contains("left-expanded"):!document.body.classList.contains("left-collapsed")}function Wn(){return ke()?document.body.classList.contains("right-expanded"):!document.body.classList.contains("right-collapsed")}function Se(){let e=document.getElementById("toggleLeft"),t=document.getElementById("toggleRight");e&&(e.textContent=Un()?"\u25C0":"\u25B6"),t&&(t.textContent=Wn()?"\u25B6":"\u25C0")}function Ln(){localStorage.setItem(Mt,JSON.stringify({left:document.body.classList.contains("left-collapsed"),right:document.body.classList.contains("right-collapsed")}))}var xn="theme",Gn="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.11.1/styles/github-dark.min.css",Qn="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.11.1/styles/github.min.css";function Mn(){let e=localStorage.getItem(xn),t=window.matchMedia("(prefers-color-scheme: light)").matches?"light":"dark";Sn(e||t),document.getElementById("toggleTheme")?.addEventListener("click",Yn)}function Yn(){let t=(document.documentElement.getAttribute("data-theme")||"dark")==="dark"?"light":"dark";Sn(t),localStorage.setItem(xn,t)}function Sn(e){document.documentElement.setAttribute("data-theme",e);let t=document.getElementById("toggleTheme");t&&t.classList.toggle("is-light",e==="light");let n=document.getElementById("hljsTheme");n&&(n.href=e==="dark"?Gn:Qn)}x();window.addEventListener("unhandledrejection",e=>{console.error("[unhandled]",e.reason),e.preventDefault()});window.addEventListener("error",e=>{console.error("[error]",e.message,e.filename,e.lineno)});document.getElementById("btnSend")?.addEventListener("click",Le);var Tt=document.getElementById("chatInput");Tt?.addEventListener("keydown",e=>{qe(e)||rn(e)});var Te=0;Tt?.addEventListener("input",e=>{e.isComposing||(Te&&cancelAnimationFrame(Te),Te=requestAnimationFrame(()=>{me(e.target?.value||""),Te=0}))});Tt?.addEventListener("cmd-execute",()=>{Le()});document.getElementById("cmdDropdown")?.addEventListener("click",Ne);document.addEventListener("click",Je);document.getElementById("filePreviewClear")?.addEventListener("click",Ee);document.getElementById("filePreviewList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-file-idx]");t&&cn(+(t.dataset.fileIdx||"0"))});document.querySelector(".btn-attach")?.addEventListener("click",()=>{document.getElementById("fileInput")?.click()});document.getElementById("memorySidebarBtn")?.addEventListener("click",Me);document.getElementById("btnClearChat")?.addEventListener("click",dn);document.getElementById("hbSidebarBtn")?.addEventListener("click",pn);document.getElementById("langToggle")?.addEventListener("click",async()=>{let e=ee()==="ko"?"en":"ko";await Qt(e);let t=document.getElementById("langToggle");t&&(t.textContent=`\u{1F310} ${c("lang."+e)}`),l.ws&&l.ws.close()});document.querySelector(".tab-bar")?.addEventListener("click",e=>{let t=e.target?.closest(".tab-btn");if(!t)return;let o=[...t.parentElement?.children||[]].filter(a=>a.classList.contains("tab-btn")).indexOf(t),i=["agents","skills","settings"];i[o]&&dt(i[o],t)});document.querySelector(".sidebar-save-bar .btn-save")?.addEventListener("click",mt);document.getElementById("selCli")?.addEventListener("change",()=>pe());document.getElementById("selModel")?.addEventListener("change",()=>F());document.getElementById("selEffort")?.addEventListener("change",()=>F());document.querySelector('[data-action="addEmployee"]')?.addEventListener("click",we);document.getElementById("employeesList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-emp-delete]");if(t){Ce(t.dataset.empDelete||"");return}});document.getElementById("employeesList")?.addEventListener("change",e=>{let t=e.target,n=t.closest("[data-emp-name]");if(n){C(n.dataset.empName||"",{name:t.value});return}let o=t.closest("[data-emp-cli]");if(o){He(o.dataset.empCli||"",t.value);return}let i=t.closest("[data-emp-model]");if(i){if(t.value==="__custom__"){let d=prompt(c("model.promptInput"));if(d?.trim()){let r=document.createElement("option");r.value=d.trim(),r.textContent=d.trim();let u=t.querySelector('option[value="__custom__"]');u&&t.insertBefore(r,u),t.value=d.trim(),C(i.dataset.empModel||"",{model:d.trim()})}else t.value="default"}else C(i.dataset.empModel||"",{model:t.value});return}let a=t.closest("[data-emp-role]");if(a){Be(a.dataset.empRole||"",t.value);return}let s=t.closest("[data-emp-custom]");if(s){C(s.dataset.empCustom||"",{role:t.value});return}});document.getElementById("skillsList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-skill-id]");t&&Pe(t.dataset.skillId||"",t.dataset.skillEnabled==="true")});document.querySelector("#tabSkills")?.addEventListener("click",e=>{let t=e.target?.closest(".skill-filter");if(t){let n=t.dataset.filter||"all";Re(n,t)}});document.querySelector('[data-action="openPrompt"]')?.addEventListener("click",nt);document.getElementById("tgOff")?.addEventListener("click",()=>fe(!1));document.getElementById("tgOn")?.addEventListener("click",()=>fe(!0));document.getElementById("tgToken")?.addEventListener("change",ge);document.getElementById("tgChatIds")?.addEventListener("change",ge);document.getElementById("fallbackOrderList")?.addEventListener("change",tt);function Vn(){for(let e of w()){let t=e.charAt(0).toUpperCase()+e.slice(1),n=document.getElementById("model"+t);n&&n.addEventListener("change",function(){Ze(e,this)});let o=document.getElementById("customModel"+t);o&&o.addEventListener("change",function(){et(e,this)});let i=document.getElementById("effort"+t);i&&i.addEventListener("change",Y)}}document.querySelector('[data-action="syncMcp"]')?.addEventListener("click",Ve);document.querySelector('[data-action="installMcp"]')?.addEventListener("click",Xe);document.querySelector('[data-action="refreshCli"]')?.addEventListener("click",()=>ye(!0));document.getElementById("cliStatusInterval")?.addEventListener("change",function(){localStorage.setItem("cliStatusInterval",this.value)});document.getElementById("promptModal")?.addEventListener("click",e=>_(e));document.querySelector("#promptModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.querySelector('[data-action="closePrompt"]')?.addEventListener("click",()=>_());document.querySelector('[data-action="cancelPrompt"]')?.addEventListener("click",()=>_());document.querySelector('[data-action="savePrompt"]')?.addEventListener("click",ot);document.addEventListener("keydown",e=>{e.key==="Escape"&&_()});document.getElementById("heartbeatModal")?.addEventListener("click",e=>bt(e));document.querySelector("#heartbeatModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.querySelector('[data-action="closeHeartbeat"]')?.addEventListener("click",()=>bt());document.querySelector('[data-action="addHeartbeat"]')?.addEventListener("click",gn);document.getElementById("hbJobsList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-hb-toggle]");if(t){yn(+(t.dataset.hbToggle||"0"));return}let n=e.target?.closest("[data-hb-remove]");if(n){fn(+(n.dataset.hbRemove||"0"));return}});document.getElementById("hbJobsList")?.addEventListener("change",e=>{let t=e.target,n=t.closest("[data-hb-name]");if(n){l.heartbeatJobs[+(n.dataset.hbName||"0")].name=t.value,P();return}let o=t.closest("[data-hb-minutes]");if(o){l.heartbeatJobs[+(o.dataset.hbMinutes||"0")].schedule={kind:"every",minutes:+t.value},P();return}let i=t.closest("[data-hb-prompt]");if(i){l.heartbeatJobs[+(i.dataset.hbPrompt||"0")].prompt=t.value,P();return}});document.getElementById("memoryModal")?.addEventListener("click",e=>Et(e));document.querySelector("#memoryModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.querySelector('[data-action="closeMemory"]')?.addEventListener("click",()=>Et());document.getElementById("memTabBtnSettings")?.addEventListener("click",()=>Lt("settings"));document.getElementById("memTabBtnFiles")?.addEventListener("click",()=>Lt("files"));document.getElementById("memOn")?.addEventListener("click",()=>xt(!0));document.getElementById("memOff")?.addEventListener("click",()=>xt(!1));document.getElementById("memFlushEvery")?.addEventListener("change",te);document.getElementById("memCli")?.addEventListener("change",te);document.getElementById("memModel")?.addEventListener("change",te);document.getElementById("memRetention")?.addEventListener("change",te);document.getElementById("memFilesList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-mem-delete]");if(t){e.stopPropagation(),hn(t.dataset.memDelete||"");return}let n=e.target?.closest("[data-mem-view]");if(n){bn(n.dataset.memView||"");return}if(e.target?.closest("[data-mem-back]")){Me();return}});async function Xn(){await Wt();let e=document.getElementById("langToggle");e&&(e.textContent=`\u{1F310} ${c("lang."+ee())}`),await oe(),Vn(),ft(),un(),mn(),await _e(),await Qe(),ye(),ut(),Ie(),vn(),on(),En(),Mn(),pt()}Xn().catch(e=>{console.error("[bootstrap]",e)});document.addEventListener("keydown",e=>{e.key==="Escape"&&document.querySelectorAll(".modal-overlay.open").forEach(t=>{t.classList.remove("open")})});document.getElementById("mobileMenuLeft")?.addEventListener("click",St);document.getElementById("mobileMenuRight")?.addEventListener("click",kt);
|
|
134
|
+
`)}T();ae();lt();var Mt="sidebarState";function xn(){let e=JSON.parse(localStorage.getItem(Mt)||"{}");e.left&&document.body.classList.add("left-collapsed"),e.right&&document.body.classList.add("right-collapsed"),document.getElementById("toggleLeft")?.addEventListener("click",St),document.getElementById("toggleRight")?.addEventListener("click",kt),window.addEventListener("resize",()=>{if(window.innerWidth>900){document.body.classList.remove("left-expanded","right-expanded");let t=JSON.parse(localStorage.getItem(Mt)||"{}");document.body.classList.toggle("left-collapsed",!!t.left),document.body.classList.toggle("right-collapsed",!!t.right)}else document.body.classList.remove("left-collapsed","right-collapsed");Se()}),window.innerWidth<=900&&document.body.classList.remove("left-collapsed","right-collapsed"),Se()}function ke(){return window.innerWidth<=900}function St(){ke()?document.body.classList.toggle("left-expanded"):document.body.classList.toggle("left-collapsed"),Mn(),Se()}function kt(){ke()?document.body.classList.toggle("right-expanded"):document.body.classList.toggle("right-collapsed"),Mn(),Se()}function Gn(){return ke()?document.body.classList.contains("left-expanded"):!document.body.classList.contains("left-collapsed")}function Qn(){return ke()?document.body.classList.contains("right-expanded"):!document.body.classList.contains("right-collapsed")}function Se(){let e=document.getElementById("toggleLeft"),t=document.getElementById("toggleRight");e&&(e.textContent=Gn()?"\u25C0":"\u25B6"),t&&(t.textContent=Qn()?"\u25B6":"\u25C0")}function Mn(){localStorage.setItem(Mt,JSON.stringify({left:document.body.classList.contains("left-collapsed"),right:document.body.classList.contains("right-collapsed")}))}var Sn="theme",Yn="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.11.1/styles/github-dark.min.css",Vn="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.11.1/styles/github.min.css";function kn(){let e=localStorage.getItem(Sn),t=window.matchMedia("(prefers-color-scheme: light)").matches?"light":"dark";Tn(e||t),document.getElementById("toggleTheme")?.addEventListener("click",Xn)}function Xn(){let t=(document.documentElement.getAttribute("data-theme")||"dark")==="dark"?"light":"dark";Tn(t),localStorage.setItem(Sn,t)}function Tn(e){document.documentElement.setAttribute("data-theme",e);let t=document.getElementById("toggleTheme");t&&t.classList.toggle("is-light",e==="light");let n=document.getElementById("hljsTheme");n&&(n.href=e==="dark"?Yn:Vn)}x();window.addEventListener("unhandledrejection",e=>{console.error("[unhandled]",e.reason),e.preventDefault()});window.addEventListener("error",e=>{console.error("[error]",e.message,e.filename,e.lineno)});document.getElementById("btnSend")?.addEventListener("click",Le);var Tt=document.getElementById("chatInput");Tt?.addEventListener("keydown",e=>{qe(e)||dn(e)});var Te=0;Tt?.addEventListener("input",e=>{e.isComposing||(Te&&cancelAnimationFrame(Te),Te=requestAnimationFrame(()=>{me(e.target?.value||""),Te=0}))});Tt?.addEventListener("cmd-execute",()=>{Le()});document.getElementById("cmdDropdown")?.addEventListener("click",Ne);document.addEventListener("click",Je);document.getElementById("filePreviewClear")?.addEventListener("click",Ee);document.getElementById("filePreviewList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-file-idx]");t&&mn(+(t.dataset.fileIdx||"0"))});document.querySelector(".btn-attach")?.addEventListener("click",()=>{document.getElementById("fileInput")?.click()});document.getElementById("memorySidebarBtn")?.addEventListener("click",Me);document.getElementById("btnClearChat")?.addEventListener("click",un);document.getElementById("hbSidebarBtn")?.addEventListener("click",fn);document.getElementById("langToggle")?.addEventListener("click",async()=>{let e=ee()==="ko"?"en":"ko";await Qt(e);let t=document.getElementById("langToggle");t&&(t.textContent=`\u{1F310} ${c("lang."+e)}`),l.ws&&l.ws.close()});document.querySelector(".tab-bar")?.addEventListener("click",e=>{let t=e.target?.closest(".tab-btn");if(!t)return;let o=[...t.parentElement?.children||[]].filter(a=>a.classList.contains("tab-btn")).indexOf(t),i=["agents","skills","settings"];i[o]&&dt(i[o],t)});document.querySelector(".sidebar-save-bar .btn-save")?.addEventListener("click",mt);document.getElementById("selCli")?.addEventListener("change",()=>pe());document.getElementById("selModel")?.addEventListener("change",()=>F());document.getElementById("selEffort")?.addEventListener("change",()=>F());document.querySelector('[data-action="addEmployee"]')?.addEventListener("click",we);document.getElementById("employeesList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-emp-delete]");if(t){Ce(t.dataset.empDelete||"");return}});document.getElementById("employeesList")?.addEventListener("change",e=>{let t=e.target,n=t.closest("[data-emp-name]");if(n){C(n.dataset.empName||"",{name:t.value});return}let o=t.closest("[data-emp-cli]");if(o){He(o.dataset.empCli||"",t.value);return}let i=t.closest("[data-emp-model]");if(i){if(t.value==="__custom__"){let d=prompt(c("model.promptInput"));if(d?.trim()){let r=document.createElement("option");r.value=d.trim(),r.textContent=d.trim();let u=t.querySelector('option[value="__custom__"]');u&&t.insertBefore(r,u),t.value=d.trim(),C(i.dataset.empModel||"",{model:d.trim()})}else t.value="default"}else C(i.dataset.empModel||"",{model:t.value});return}let a=t.closest("[data-emp-role]");if(a){Be(a.dataset.empRole||"",t.value);return}let s=t.closest("[data-emp-custom]");if(s){C(s.dataset.empCustom||"",{role:t.value});return}});document.getElementById("skillsList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-skill-id]");t&&Ae(t.dataset.skillId||"",t.dataset.skillEnabled==="true")});document.querySelector("#tabSkills")?.addEventListener("click",e=>{let t=e.target?.closest(".skill-filter");if(t){let n=t.dataset.filter||"all";Re(n,t)}});document.querySelector('[data-action="openPrompt"]')?.addEventListener("click",nt);document.getElementById("tgOff")?.addEventListener("click",()=>fe(!1));document.getElementById("tgOn")?.addEventListener("click",()=>fe(!0));document.getElementById("tgToken")?.addEventListener("change",ge);document.getElementById("tgChatIds")?.addEventListener("change",ge);document.getElementById("fallbackOrderList")?.addEventListener("change",tt);function Zn(){for(let e of w()){let t=e.charAt(0).toUpperCase()+e.slice(1),n=document.getElementById("model"+t);n&&n.addEventListener("change",function(){Ze(e,this)});let o=document.getElementById("customModel"+t);o&&o.addEventListener("change",function(){et(e,this)});let i=document.getElementById("effort"+t);i&&i.addEventListener("change",Y)}}document.querySelector('[data-action="syncMcp"]')?.addEventListener("click",Ve);document.querySelector('[data-action="installMcp"]')?.addEventListener("click",Xe);document.querySelector('[data-action="refreshCli"]')?.addEventListener("click",()=>ye(!0));document.getElementById("cliStatusInterval")?.addEventListener("change",function(){localStorage.setItem("cliStatusInterval",this.value)});document.getElementById("promptModal")?.addEventListener("click",e=>_(e));document.querySelector("#promptModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.querySelector('[data-action="closePrompt"]')?.addEventListener("click",()=>_());document.querySelector('[data-action="cancelPrompt"]')?.addEventListener("click",()=>_());document.querySelector('[data-action="savePrompt"]')?.addEventListener("click",ot);document.addEventListener("keydown",e=>{e.key==="Escape"&&_()});document.getElementById("heartbeatModal")?.addEventListener("click",e=>bt(e));document.querySelector("#heartbeatModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.querySelector('[data-action="closeHeartbeat"]')?.addEventListener("click",()=>bt());document.querySelector('[data-action="addHeartbeat"]')?.addEventListener("click",yn);document.getElementById("hbJobsList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-hb-toggle]");if(t){hn(+(t.dataset.hbToggle||"0"));return}let n=e.target?.closest("[data-hb-remove]");if(n){vn(+(n.dataset.hbRemove||"0"));return}});document.getElementById("hbJobsList")?.addEventListener("change",e=>{let t=e.target,n=t.closest("[data-hb-name]");if(n){l.heartbeatJobs[+(n.dataset.hbName||"0")].name=t.value,A();return}let o=t.closest("[data-hb-minutes]");if(o){l.heartbeatJobs[+(o.dataset.hbMinutes||"0")].schedule={kind:"every",minutes:+t.value},A();return}let i=t.closest("[data-hb-prompt]");if(i){l.heartbeatJobs[+(i.dataset.hbPrompt||"0")].prompt=t.value,A();return}});document.getElementById("memoryModal")?.addEventListener("click",e=>Et(e));document.querySelector("#memoryModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.querySelector('[data-action="closeMemory"]')?.addEventListener("click",()=>Et());document.getElementById("memTabBtnSettings")?.addEventListener("click",()=>Lt("settings"));document.getElementById("memTabBtnFiles")?.addEventListener("click",()=>Lt("files"));document.getElementById("memOn")?.addEventListener("click",()=>xt(!0));document.getElementById("memOff")?.addEventListener("click",()=>xt(!1));document.getElementById("memFlushEvery")?.addEventListener("change",te);document.getElementById("memCli")?.addEventListener("change",te);document.getElementById("memModel")?.addEventListener("change",te);document.getElementById("memRetention")?.addEventListener("change",te);document.getElementById("memFilesList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-mem-delete]");if(t){e.stopPropagation(),En(t.dataset.memDelete||"");return}let n=e.target?.closest("[data-mem-view]");if(n){Ln(n.dataset.memView||"");return}if(e.target?.closest("[data-mem-back]")){Me();return}});async function eo(){await Wt();let e=document.getElementById("langToggle");e&&(e.textContent=`\u{1F310} ${c("lang."+ee())}`),await oe(),Zn(),ft(),gn(),pn(),await _e(),await Qe(),ye(),ut(),Ie(),bn(),sn(),xn(),kn(),pt()}eo().catch(e=>{console.error("[bootstrap]",e)});document.addEventListener("keydown",e=>{e.key==="Escape"&&document.querySelectorAll(".modal-overlay.open").forEach(t=>{t.classList.remove("open")})});document.getElementById("mobileMenuLeft")?.addEventListener("click",St);document.getElementById("mobileMenuRight")?.addEventListener("click",kt);
|
|
135
135
|
//# sourceMappingURL=bundle.js.map
|