cli-jaw 1.2.9 → 1.3.0-preview.1

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 (40) hide show
  1. package/README.md +42 -19
  2. package/dist/lib/mcp-sync.js +3 -1
  3. package/dist/lib/mcp-sync.js.map +1 -1
  4. package/dist/lib/quota-copilot.js +93 -0
  5. package/dist/lib/quota-copilot.js.map +1 -1
  6. package/dist/lib/stt.js +95 -0
  7. package/dist/lib/stt.js.map +1 -0
  8. package/dist/lib/token-keepalive.js +34 -0
  9. package/dist/lib/token-keepalive.js.map +1 -0
  10. package/dist/server.js +68 -1
  11. package/dist/server.js.map +1 -1
  12. package/dist/src/prompt/builder.js +82 -264
  13. package/dist/src/prompt/builder.js.map +1 -1
  14. package/dist/src/prompt/template-loader.js +46 -0
  15. package/dist/src/prompt/template-loader.js.map +1 -0
  16. package/dist/src/prompt/templates/a1-system.md +106 -0
  17. package/dist/src/prompt/templates/a2-default.md +17 -0
  18. package/dist/src/prompt/templates/employee.md +37 -0
  19. package/dist/src/prompt/templates/heartbeat-default.md +4 -0
  20. package/dist/src/prompt/templates/heartbeat-jobs.md +4 -0
  21. package/dist/src/prompt/templates/orchestration.md +64 -0
  22. package/dist/src/prompt/templates/skills.md +18 -0
  23. package/dist/src/prompt/templates/vision-click.md +3 -0
  24. package/dist/src/prompt/templates/worker-context.md +8 -0
  25. package/dist/src/telegram/bot.js +2 -0
  26. package/dist/src/telegram/bot.js.map +1 -1
  27. package/dist/src/telegram/voice.js +25 -0
  28. package/dist/src/telegram/voice.js.map +1 -0
  29. package/package.json +2 -2
  30. package/public/css/chat.css +38 -0
  31. package/public/dist/bundle.js +59 -58
  32. package/public/dist/bundle.js.map +4 -4
  33. package/public/index.html +41 -0
  34. package/public/js/features/chat.ts +25 -0
  35. package/public/js/features/settings.ts +123 -2
  36. package/public/js/features/voice-recorder.ts +150 -0
  37. package/public/js/main.ts +13 -1
  38. package/public/js/state.ts +2 -0
  39. package/public/locales/en.json +15 -0
  40. package/public/locales/ko.json +15 -0
@@ -1,111 +1,112 @@
1
- var $n=Object.defineProperty;var x=(e,t)=>()=>(e&&(t=e(e=0)),t);var D=(e,t)=>{for(var n in t)$n(e,n,{get:t[n],enumerable:!0})};var r,w=x(()=>{"use strict";r={ws:null,agentBusy:!1,employees:[],allSkills:[],currentSkillFilter:"all",currentAgentDiv:null,attachedFiles:[],heartbeatJobs:[],cliStatusCache:null,cliStatusTs:0,orcState:"IDLE"}});var $t={};D($t,{api:()=>v,apiFire:()=>C,apiJson:()=>y});async function v(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 v(e,{method:t,headers:{"Content-Type":"application/json"},body:JSON.stringify(n)})}function C(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 M=x(()=>{"use strict"});function Pt(e){let t={};for(let[n,o]of Object.entries(e))t[n]=Array.isArray(o?.models)?[...o.models]:[];return t}function Rt(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 Ht(e){let t=Rt(e);return Object.keys(t).length?(U=t,Dt=Object.keys(t),H=Pt(t),!0):!1}async function oe(){try{let e=await v("/api/cli-registry");if(!e||!Ht(e))throw new Error("invalid registry")}catch(e){console.warn("[cli-registry] fallback:",e.message),Ht(At)}return U}function B(){return Dt}function ie(e){return U[e]||null}var At,U,Dt,H,W,ae=x(()=>{"use strict";M();At={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"]}};U=Rt(At),Dt=Object.keys(U),H=Pt(U);W=[{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 G={};D(G,{addEmployee:()=>$e,deleteEmployee:()=>He,loadEmployees:()=>Be,onEmpCliChange:()=>Ae,onEmpRoleChange:()=>Pe,renderEmployees:()=>Ot,updateEmployee:()=>$});async function Be(){let e=await v("/api/employees");r.employees=e||[],Ot()}function Ot(){let e=document.getElementById("employeesList");if(!e)return;let t=r.employees;if(t.length===0){e.innerHTML=`<div style="color:var(--text-dim);font-size:11px;padding:4px 0">${d("emp.addPrompt")}</div>`;return}let n=B();e.innerHTML=t.map(o=>{let i=H[o.cli]||[],a=Hn[o.role||""],l=a?W.find(f=>f.value===a):W.find(f=>f.prompt===o.role),c=l?l.value:o.role?"custom":"frontend",s=c==="custom",u=Ft(o.id),p=u?.phase||o.phase,g=u?.phaseLabel||o.phaseLabel,h=p?`<span style="background:${An[p]||"#888"};color:#000;padding:1px 6px;border-radius:9px;font-size:9px">${g||"P"+p}</span>`:"";return`
1
+ var Vn=Object.defineProperty;var x=(e,t)=>()=>(e&&(t=e(e=0)),t);var _=(e,t)=>{for(var n in t)Vn(e,n,{get:t[n],enumerable:!0})};var c,k=x(()=>{"use strict";c={ws:null,agentBusy:!1,employees:[],allSkills:[],currentSkillFilter:"all",currentAgentDiv:null,attachedFiles:[],heartbeatJobs:[],cliStatusCache:null,cliStatusTs:0,orcState:"IDLE",isRecording:!1}});var Jt={};_(Jt,{api:()=>f,apiFire:()=>H,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 H(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 T=x(()=>{"use strict"});function Wt(e){let t={};for(let[n,o]of Object.entries(e))t[n]=Array.isArray(o?.models)?[...o.models]:[];return t}function Gt(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 Kt(e){let t=Gt(e);return Object.keys(t).length?(V=t,Vt=Object.keys(t),R=Wt(t),!0):!1}async function re(){try{let e=await f("/api/cli-registry");if(!e||!Kt(e))throw new Error("invalid registry")}catch(e){console.warn("[cli-registry] fallback:",e.message),Kt(Ut)}return V}function A(){return Vt}function le(e){return V[e]||null}var Ut,V,Vt,R,Q,ce=x(()=>{"use strict";T();Ut={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"]}};V=Gt(Ut),Vt=Object.keys(V),R=Wt(V);Q=[{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 Y={};_(Y,{addEmployee:()=>Fe,deleteEmployee:()=>je,loadEmployees:()=>Oe,onEmpCliChange:()=>_e,onEmpRoleChange:()=>Ne,renderEmployees:()=>Qt,updateEmployee:()=>P});async function Oe(){let e=await f("/api/employees");c.employees=e||[],Qt()}function Qt(){let e=document.getElementById("employeesList");if(!e)return;let t=c.employees;if(t.length===0){e.innerHTML=`<div style="color:var(--text-dim);font-size:11px;padding:4px 0">${l("emp.addPrompt")}</div>`;return}let n=A();e.innerHTML=t.map(o=>{let i=R[o.cli]||[],a=Qn[o.role||""],s=a?Q.find(h=>h.value===a):Q.find(h=>h.prompt===o.role),r=s?s.value:o.role?"custom":"frontend",d=r==="custom",m=Yt(o.id),p=m?.phase||o.phase,g=m?.phaseLabel||o.phaseLabel,b=p?`<span style="background:${Yn[p]||"#888"};color:#000;padding:1px 6px;border-radius:9px;font-size:9px">${g||"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>
5
5
  <input style="flex:1;background:none;border:none;color:var(--text);font-size:12px;font-weight:600;font-family:inherit;outline:none"
6
- value="${m(o.name||"Agent")}"
6
+ value="${u(o.name||"Agent")}"
7
7
  data-emp-name="${o.id}">
8
- <button style="background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:12px" data-emp-delete="${o.id}" title="${d("emp.delete")}">\u2715</button>
8
+ <button style="background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:12px" data-emp-delete="${o.id}" title="${l("emp.delete")}">\u2715</button>
9
9
  </div>
10
10
  <div style="display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-bottom:4px">
11
11
  <div>
12
12
  <label>CLI</label>
13
13
  <select data-emp-cli="${o.id}">
14
- ${n.map(f=>`<option${o.cli===f?" selected":""}>${f}</option>`).join("")}
14
+ ${n.map(h=>`<option${o.cli===h?" selected":""}>${h}</option>`).join("")}
15
15
  </select>
16
16
  </div>
17
17
  <div>
18
18
  <label>Model</label>
19
19
  <select data-emp-model="${o.id}">
20
20
  <option value="default"${!o.model||o.model==="default"?" selected":""}>default</option>
21
- ${i.map(f=>`<option${o.model===f?" selected":""}>${f}</option>`).join("")}
21
+ ${i.map(h=>`<option${o.model===h?" selected":""}>${h}</option>`).join("")}
22
22
  ${o.model&&o.model!=="default"&&!i.includes(o.model)?`<option selected>${o.model}</option>`:""}
23
- <option value="__custom__">${d("emp.customModel")}</option>
23
+ <option value="__custom__">${l("emp.customModel")}</option>
24
24
  </select>
25
25
  </div>
26
26
  </div>
27
27
  <div>
28
28
  <label>Role</label>
29
29
  <select data-emp-role="${o.id}">
30
- ${W.map(f=>`<option value="${f.value}"${c===f.value?" selected":""}>${f.label}</option>`).join("")}
30
+ ${Q.map(h=>`<option value="${h.value}"${r===h.value?" selected":""}>${h.label}</option>`).join("")}
31
31
  </select>
32
- <textarea data-emp-custom="${o.id}" style="display:${s?"block":"none"};margin-top:4px;width:100%;height:40px;background:var(--bg);border:1px solid var(--border);color:var(--text);padding:4px 6px;border-radius:4px;font-size:10px;font-family:inherit;resize:vertical"
33
- placeholder="${d("emp.customRole")}">${s?m(o.role||""):""}</textarea>
32
+ <textarea data-emp-custom="${o.id}" style="display:${d?"block":"none"};margin-top:4px;width:100%;height:40px;background:var(--bg);border:1px solid var(--border);color:var(--text);padding:4px 6px;border-radius:4px;font-size:10px;font-family:inherit;resize:vertical"
33
+ placeholder="${l("emp.customRole")}">${d?u(o.role||""):""}</textarea>
34
34
  </div>
35
35
  <div style="margin-top:4px;font-size:10px;display:flex;align-items:center;gap:6px">
36
36
  <span style="color:${o.status==="running"?"#fbbf24":"var(--green)"}">\u25CF ${o.status||"idle"}</span>
37
- ${h}
37
+ ${b}
38
38
  </div>
39
- </div>`}).join("")}async function $e(){await y("/api/employees","POST",{})}async function $(e,t){await y(`/api/employees/${e}`,"PUT",t)}async function He(e){C(`/api/employees/${e}`,"DELETE")}function Ae(e,t){let n=H[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__">${d("emp.customModel")}</option>`),$(e,{cli:t,model:"default"})}function Pe(e,t){let n=W.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="",$(e,{role:n?.prompt||""})))}var Hn,An,O=x(()=>{"use strict";w();ae();A();Re();S();M();Hn={"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"},An={1:"#60a5fa",2:"#a78bfa",3:"#34d399",4:"#fbbf24",5:"#f472b6"}});var je={};D(je,{filterSkills:()=>Fe,loadSkills:()=>jt,renderSkills:()=>De,toggleSkill:()=>Oe});async function jt(){try{let e=await _t("/api/skills");r.allSkills=await e.json(),De()}catch{let e=document.getElementById("skillsList");e&&(e.innerHTML=`<div style="color:var(--text-dim);font-size:11px">${d("skill.loadFail")}</div>`)}}function De(){let e=document.getElementById("skillsList"),t=document.getElementById("skillsCount");if(!e||!t)return;let n=r.allSkills,o=n;r.currentSkillFilter==="installed"?o=n.filter(a=>a.enabled):r.currentSkillFilter==="other"?o=n.filter(a=>!Pn.includes(a.category||"")):r.currentSkillFilter!=="all"&&(o=n.filter(a=>a.category===r.currentSkillFilter));let i=n.filter(a=>a.enabled).length;t.textContent=d("skill.count",{active:i,total:n.length}),e.innerHTML=o.map(a=>{let l=[];return a.requires?.env&&l.push("\u{1F511} "+a.requires.env.join(", ")),a.requires?.bins&&l.push("\u2699\uFE0F "+a.requires.bins.join(", ")),a.install&&l.push(a.install),`
39
+ </div>`}).join("")}async function Fe(){await y("/api/employees","POST",{})}async function P(e,t){await y(`/api/employees/${e}`,"PUT",t)}async function je(e){H(`/api/employees/${e}`,"DELETE")}function _e(e,t){let n=R[t]||[],o=document.querySelector(`[data-emp-model="${e}"]`);o&&(o.innerHTML='<option value="default" selected>default</option>'+n.map(i=>`<option>${u(i)}</option>`).join("")+`<option value="__custom__">${l("emp.customModel")}</option>`),P(e,{cli:t,model:"default"})}function Ne(e,t){let n=Q.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="",P(e,{role:n?.prompt||""})))}var Qn,Yn,N=x(()=>{"use strict";k();ce();D();qe();L();T();Qn={"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"},Yn={1:"#60a5fa",2:"#a78bfa",3:"#34d399",4:"#fbbf24",5:"#f472b6"}});var Ue={};_(Ue,{filterSkills:()=>Ke,loadSkills:()=>Xt,renderSkills:()=>ze,toggleSkill:()=>Je});async function Xt(){try{let e=await Zt("/api/skills");c.allSkills=await e.json(),ze()}catch{let e=document.getElementById("skillsList");e&&(e.innerHTML=`<div style="color:var(--text-dim);font-size:11px">${l("skill.loadFail")}</div>`)}}function ze(){let e=document.getElementById("skillsList"),t=document.getElementById("skillsCount");if(!e||!t)return;let n=c.allSkills,o=n;c.currentSkillFilter==="installed"?o=n.filter(a=>a.enabled):c.currentSkillFilter==="other"?o=n.filter(a=>!Xn.includes(a.category||"")):c.currentSkillFilter!=="all"&&(o=n.filter(a=>a.category===c.currentSkillFilter));let i=n.filter(a=>a.enabled).length;t.textContent=l("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),`
40
40
  <div class="skill-card ${a.enabled?"enabled":""}">
41
41
  <div class="skill-card-header">
42
- <span class="skill-emoji">${m(a.emoji||"\u{1F527}")}</span>
43
- <span class="skill-name">${m(a.name||a.id)}</span>
42
+ <span class="skill-emoji">${u(a.emoji||"\u{1F527}")}</span>
43
+ <span class="skill-name">${u(a.name||a.id)}</span>
44
44
  <button class="skill-toggle ${a.enabled?"on":"off"}"
45
- data-skill-id="${m(a.id)}" data-skill-enabled="${a.enabled}"></button>
45
+ data-skill-id="${u(a.id)}" data-skill-enabled="${a.enabled}"></button>
46
46
  </div>
47
- <div class="skill-desc">${m(a.description||"")}</div>
48
- ${l.length?`<div class="skill-req">${l.join(" \xB7 ")}</div>`:""}
49
- </div>`}).join("")}async function Oe(e,t){let n=t?"/api/skills/disable":"/api/skills/enable";try{await y(n,"POST",{id:e}),await jt()}catch(o){console.error("toggleSkill error:",o)}}function Fe(e,t){r.currentSkillFilter=e,document.querySelectorAll(".skill-filter").forEach(n=>n.classList.remove("active")),t&&t.classList.add("active"),De()}var Pn,se=x(()=>{"use strict";w();S();M();A();Pn=["productivity","communication","devtools","ai-media","utility","smarthome","automation"]});function le(){try{for(let e of Nt){let t=localStorage.getItem(e);if(t)return t}}catch{}return navigator.language||"ko"}function qt(e){let t=String(e||"").trim();if(t)try{for(let n of Nt)localStorage.setItem(n,t)}catch{}}var Nt,re=x(()=>{"use strict";Nt=["claw_locale","claw.locale"]});var We={};D(We,{close:()=>T,handleClick:()=>Ke,handleKeydown:()=>ze,handleOutsideClick:()=>Ue,isDropdownOpen:()=>Dn,loadCommands:()=>Je,update:()=>me});function zt(e){let n=String(e||"").slice(1).trim().split(/\s+/)[0]||"";return n.includes("/")||n.includes("\\")}function _e(e){return String(e||"").replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;")}function Rn(e){let t=String(e||"").toLowerCase();return Ne.filter(n=>`/${n.name}`.startsWith(t))}function Jt(){let e=de(),t=j();!e||!t||(P&&(clearTimeout(P),P=null),e.style.display="block",requestAnimationFrame(()=>e.classList.add("visible")),F=!0,t.setAttribute("aria-expanded","true"))}function ce(){let e=de(),t=j();if(!e||!t)return;if(!k.length){if(!t.value.startsWith("/")||zt(t.value)){T();return}e.innerHTML=`
47
+ <div class="skill-desc">${u(a.description||"")}</div>
48
+ ${s.length?`<div class="skill-req">${s.join(" \xB7 ")}</div>`:""}
49
+ </div>`}).join("")}async function Je(e,t){let n=t?"/api/skills/disable":"/api/skills/enable";try{await y(n,"POST",{id:e}),await Xt()}catch(o){console.error("toggleSkill error:",o)}}function Ke(e,t){c.currentSkillFilter=e,document.querySelectorAll(".skill-filter").forEach(n=>n.classList.remove("active")),t&&t.classList.add("active"),ze()}var Xn,de=x(()=>{"use strict";k();L();T();D();Xn=["productivity","communication","devtools","ai-media","utility","smarthome","automation"]});function me(){try{for(let e of en){let t=localStorage.getItem(e);if(t)return t}}catch{}return navigator.language||"ko"}function tn(e){let t=String(e||"").trim();if(t)try{for(let n of en)localStorage.setItem(n,t)}catch{}}var en,ue=x(()=>{"use strict";en=["claw_locale","claw.locale"]});var et={};_(et,{close:()=>w,handleClick:()=>Xe,handleKeydown:()=>Ye,handleOutsideClick:()=>Ze,isDropdownOpen:()=>eo,loadCommands:()=>Qe,update:()=>fe});function on(e){let n=String(e||"").slice(1).trim().split(/\s+/)[0]||"";return n.includes("/")||n.includes("\\")}function We(e){return String(e||"").replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;")}function Zn(e){let t=String(e||"").toLowerCase();return Ge.filter(n=>`/${n.name}`.startsWith(t))}function nn(){let e=ge(),t=z();!e||!t||(O&&(clearTimeout(O),O=null),e.style.display="block",requestAnimationFrame(()=>e.classList.add("visible")),q=!0,t.setAttribute("aria-expanded","true"))}function pe(){let e=ge(),t=z();if(!e||!t)return;if(!I.length){if(!t.value.startsWith("/")||on(t.value)){w();return}e.innerHTML=`
50
50
  <div class="cmd-item cmd-empty" role="option" aria-disabled="true">
51
- ${d("cmd.noMatch")}
51
+ ${l("cmd.noMatch")}
52
52
  </div>
53
- `,Jt(),t.setAttribute("aria-activedescendant","");return}e.innerHTML=k.map((o,i)=>{let a=i===L;return`<div class="cmd-item${a?" selected":""}"
53
+ `,nn(),t.setAttribute("aria-activedescendant","");return}e.innerHTML=I.map((o,i)=>{let a=i===M;return`<div class="cmd-item${a?" selected":""}"
54
54
  role="option"
55
55
  id="cmd-item-${i}"
56
56
  aria-selected="${a}"
57
57
  data-index="${i}">
58
- <span class="cmd-name">/${_e(o.name)}</span>
59
- <span class="cmd-desc">${_e(o.desc)}</span>
60
- ${o.args?`<span class="cmd-args">${_e(o.args)}</span>`:""}
61
- </div>`}).join(""),Jt(),t.setAttribute("aria-activedescendant",L>=0?`cmd-item-${L}`:"");let n=e.querySelector(".selected");n&&n.scrollIntoView({block:"nearest"})}function qe(e){let t=k[L],n=j();if(!t||!n){T();return}if(T(),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 Je(){try{let e=le(),t=`/api/commands?interface=web&locale=${encodeURIComponent(e)}`;Ne=await v(t,{headers:{"Accept-Language":e}})||[]}catch(e){console.warn("[slash-commands] loadCommands failed:",e.message),Ne=[]}}function T(){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)),F=!1,L=-1,k=[];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(`
62
- `)||zt(t)){T();return}k=Rn(t),L=k.length?0:-1,ce()}function ze(e){return F?k.length?e.key==="ArrowDown"?(e.preventDefault(),L=Math.min(k.length-1,L+1),ce(),!0):e.key==="ArrowUp"?(e.preventDefault(),L=Math.max(0,L-1),ce(),!0):e.key==="Tab"?(e.preventDefault(),qe(!1),!0):e.key==="Enter"&&!e.shiftKey&&!e.isComposing?(e.preventDefault(),qe(!0),!0):e.key==="Escape"?(e.preventDefault(),T(),!0):!1:e.key==="Escape"?(e.preventDefault(),T(),!0):!1:(e.key==="ArrowDown"||e.key==="ArrowUp")&&!e.isComposing?(me(j()?.value||""),F?(L=e.key==="ArrowUp"?k.length-1:0,ce(),e.preventDefault(),!0):!1):!1}function Ke(e){let n=e.target.closest(".cmd-item");if(!n)return;let o=parseInt(n.dataset.index||"-1",10);Number.isNaN(o)||o<0||(L=Math.min(o,k.length-1),qe(!0))}function Ue(e){if(!F)return;let t=de(),n=j();if(!t||!n)return;let o=e.target;!t.contains(o)&&o!==n&&T()}function Dn(){return F}var Ne,k,L,F,P,de,j,ue=x(()=>{"use strict";re();S();M();Ne=[],k=[],L=-1,F=!1,P=null;de=()=>document.getElementById("cmdDropdown"),j=()=>document.getElementById("chatInput")});var X={};D(X,{applyCustomModel:()=>ot,closePromptModal:()=>N,getModelValue:()=>Qt,handleModelSelect:()=>nt,installMcpGlobal:()=>tt,loadCliStatus:()=>ve,loadFallbackOrder:()=>Yt,loadMcpServers:()=>Ze,loadSettings:()=>Xe,onCliChange:()=>pe,openPromptModal:()=>at,saveActiveCliSettings:()=>_,saveFallbackOrder:()=>it,savePerCli:()=>V,savePromptFromModal:()=>st,saveTelegramSettings:()=>ge,setForwardAll:()=>ye,setPerm:()=>Gt,setTelegram:()=>fe,syncMcpServers:()=>et,updateSettings:()=>Qe});function Ye(e){return e.charAt(0).toUpperCase()+e.slice(1)}function Y(e){return document.getElementById("model"+Ye(e))}function Ut(e){return document.getElementById("customModel"+Ye(e))}function Ve(e){return document.getElementById("effort"+Ye(e))}function Wt(e,t,{includeCustom:n=!1,includeDefault:o=!1,selected:i=""}={}){if(!e)return;let a=o?'<option value="default">default</option>':"",l=n?`<option value="__custom__">${d("model.customOption")}</option>`:"",c=(t||[]).map(s=>`<option value="${m(s)}">${m(s)}</option>`).join("");e.innerHTML=a+c+l,i&&Array.from(e.options).some(s=>s.value===i)&&(e.value=i)}function Q(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 On(e=null){let t=B(),n=document.getElementById("selCli");if(n){let i=e?.cli||n.value||t[0]||"claude";n.innerHTML=t.map(a=>{let l=ie(a)?.label||a;return`<option value="${m(a)}">${m(l)}</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 Fn(e=null){for(let t of B()){let n=Y(t);if(n){let i=e?.perCli?.[t]?.model||n.value||"";Wt(n,H[t]||[],{includeCustom:!0,selected:i}),i&&!Array.from(n.options).some(a=>a.value===i)&&(Q(n,i),n.value=i)}let o=Ve(t);if(o){let i=ie(t),a=[""].concat(i?.efforts||[]),l=e?.perCli?.[t]?.effort||o.value||"",c=[...new Set(a)],s=i?.efforts?.length===0&&i?.effortNote?i.effortNote:"\u2014 none";o.innerHTML=c.map(u=>u?`<option value="${m(u)}">${m(u)}</option>`:`<option value="">${m(s)}</option>`).join(""),i?.effortNote&&(o.title=i.effortNote),o.disabled=i?.efforts?.length===0&&!!i?.effortNote,Array.from(o.options).some(u=>u.value===l)&&(o.value=l)}}}function Ge(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(l=>l?`<option value="${m(l)}">${m(l)}</option>`:'<option value="">\u2014 none</option>').join(""),n.disabled=!1,n.title="",Array.from(n.options).some(l=>l.value===t)&&(n.value=t)}async function Xe(){await oe();let e=await v("/api/settings");if(!e)return;qt(e.locale??""),On(e),Fn(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),Gt(e.permissions,!1),e.perCli)for(let[u,p]of Object.entries(e.perCli)){let g=Y(u),h=Ve(u);g&&p.model&&(Q(g,p.model),g.value=p.model),h&&(h.value=p.effort||"")}pe(!1);let i=e.activeOverrides?.[e.cli]||{},a=e.perCli?.[e.cli]||{},l=i.model||a.model,c=i.effort||a.effort||"",s=document.getElementById("selModel");l&&s&&(s.value=l),Ge(e.cli,c),jn(e),Yt(e),Ze()}async function Ze(){try{let e=await v("/api/mcp");if(!e)return;let t=document.getElementById("mcpServerList");if(!t)return;let n=Object.entries(e.servers||{});if(!n.length){t.textContent=d("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 et(){let e=document.getElementById("mcpSyncResult");if(e){e.style.display="block",e.textContent=d("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(" &nbsp; ")}catch(t){e.textContent="\u274C "+t.message}}}async function tt(){let e=document.getElementById("mcpSyncResult");if(e){e.style.display="block",e.textContent=d("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>"),Ze()}catch(t){e.textContent="\u274C "+t.message}}}async function Qe(){let e={cli:document.getElementById("selCli")?.value||"claude"},t=document.getElementById("headerCli");t&&(t.textContent=e.cli),await y("/api/settings","PUT",e)}function Gt(e,t=!0){t&&C("/api/settings","PUT",{permissions:"auto"})}function Qt(e){let t=Y(e);return t?t.value==="__custom__"?Ut(e)?.value?.trim()||t.options[0]?.value||"default":t.value:"default"}function nt(e,t){let n=Ut(e);n&&(t.value==="__custom__"?(n.style.display="block",n.focus()):(n.style.display="none",V()))}function ot(e,t){let n=t.value.trim();if(!n)return;let o=Y(e);o&&(Q(o,n),o.value=n,t.style.display="none",V())}async function V(){let e={};for(let t of B()){if(!Y(t))continue;let o=Ve(t);e[t]={model:Qt(t),effort:o?o.value:""}}await y("/api/settings","PUT",{perCli:e})}function pe(e=!0){let t=document.getElementById("selCli")?.value||"claude",n=H[t]||[],o=document.getElementById("selModel");Wt(o,n,{includeCustom:!0,includeDefault:!0});let i=document.getElementById("headerCli");i&&(i.textContent=t),Ge(t);let a=document.getElementById("selModelCustom");a&&a.remove();let l=document.createElement("input");if(l.type="text",l.id="selModelCustom",l.className="custom-model-input",l.placeholder=d("model.placeholder"),l.style.display="none",l.onchange=function(){let c=this.value.trim();!c||!o||(Q(o,c),o.value=c,this.style.display="none",_())},!o){e&&Qe();return}o.parentElement?.appendChild(l),o.onchange=function(){this.value==="__custom__"?(l.style.display="block",l.focus()):(l.style.display="none",_())},v("/api/settings").then(c=>{if(!c)return;let s=c.activeOverrides?.[t]||{},u=c.perCli?.[t]||{},p=s.model||u.model,g=s.effort||u.effort||"";p&&o&&(Q(o,p),o.value=p),Ge(t,g)}),e&&Qe()}async function _(){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}})}async function ye(e){document.getElementById("tgForwardOn")?.classList.toggle("active",e),document.getElementById("tgForwardOff")?.classList.toggle("active",!e),await y("/api/settings","PUT",{telegram:{forwardAll:e}})}function jn(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(", "));let i=t.forwardAll!==!1;document.getElementById("tgForwardOn")?.classList.toggle("active",i),document.getElementById("tgForwardOff")?.classList.toggle("active",!i)}function Yt(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 l=0;l<i;l++){let c=o[l]||"",s=n.map(u=>`<option value="${u}" ${u===c?"selected":""}>${u}</option>`).join("");a+=`
58
+ <span class="cmd-name">/${We(o.name)}</span>
59
+ <span class="cmd-desc">${We(o.desc)}</span>
60
+ ${o.args?`<span class="cmd-args">${We(o.args)}</span>`:""}
61
+ </div>`}).join(""),nn(),t.setAttribute("aria-activedescendant",M>=0?`cmd-item-${M}`:"");let n=e.querySelector(".selected");n&&n.scrollIntoView({block:"nearest"})}function Ve(e){let t=I[M],n=z();if(!t||!n){w();return}if(w(),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 Qe(){try{let e=me(),t=`/api/commands?interface=web&locale=${encodeURIComponent(e)}`;Ge=await f(t,{headers:{"Accept-Language":e}})||[]}catch(e){console.warn("[slash-commands] loadCommands failed:",e.message),Ge=[]}}function w(){let e=ge();O&&(clearTimeout(O),O=null),e&&(e.classList.remove("visible"),O=setTimeout(()=>{e.classList.contains("visible")||(e.style.display="none",e.innerHTML="")},150)),q=!1,M=-1,I=[];let t=z();t&&(t.setAttribute("aria-expanded","false"),t.setAttribute("aria-activedescendant",""))}function fe(e){let t=String(e||"");if(!t.startsWith("/")||t.includes(" ")||t.includes(`
62
+ `)||on(t)){w();return}I=Zn(t),M=I.length?0:-1,pe()}function Ye(e){return q?I.length?e.key==="ArrowDown"?(e.preventDefault(),M=Math.min(I.length-1,M+1),pe(),!0):e.key==="ArrowUp"?(e.preventDefault(),M=Math.max(0,M-1),pe(),!0):e.key==="Tab"?(e.preventDefault(),Ve(!1),!0):e.key==="Enter"&&!e.shiftKey&&!e.isComposing?(e.preventDefault(),Ve(!0),!0):e.key==="Escape"?(e.preventDefault(),w(),!0):!1:e.key==="Escape"?(e.preventDefault(),w(),!0):!1:(e.key==="ArrowDown"||e.key==="ArrowUp")&&!e.isComposing?(fe(z()?.value||""),q?(M=e.key==="ArrowUp"?I.length-1:0,pe(),e.preventDefault(),!0):!1):!1}function Xe(e){let n=e.target.closest(".cmd-item");if(!n)return;let o=parseInt(n.dataset.index||"-1",10);Number.isNaN(o)||o<0||(M=Math.min(o,I.length-1),Ve(!0))}function Ze(e){if(!q)return;let t=ge(),n=z();if(!t||!n)return;let o=e.target;!t.contains(o)&&o!==n&&w()}function eo(){return q}var Ge,I,M,q,O,ge,z,ye=x(()=>{"use strict";ue();L();T();Ge=[],I=[],M=-1,q=!1,O=null;ge=()=>document.getElementById("cmdDropdown"),z=()=>document.getElementById("chatInput")});var ne={};_(ne,{applyCustomModel:()=>dt,closePromptModal:()=>K,closeTemplateModal:()=>xe,getModelValue:()=>cn,handleModelSelect:()=>ct,installMcpGlobal:()=>lt,loadCliStatus:()=>te,loadFallbackOrder:()=>dn,loadMcpServers:()=>st,loadSettings:()=>at,onCliChange:()=>ve,openPromptModal:()=>ut,openTemplateModal:()=>ft,saveActiveCliSettings:()=>J,saveFallbackOrder:()=>mt,savePerCli:()=>ee,savePromptFromModal:()=>pt,saveTelegramSettings:()=>he,saveTemplateFromModal:()=>vt,setForwardAll:()=>Ee,setPerm:()=>ln,setTelegram:()=>be,syncMcpServers:()=>rt,templateGoBack:()=>bt,toggleDevMode:()=>yt,updateSettings:()=>nt});function ot(e){return e.charAt(0).toUpperCase()+e.slice(1)}function Z(e){return document.getElementById("model"+ot(e))}function sn(e){return document.getElementById("customModel"+ot(e))}function it(e){return document.getElementById("effort"+ot(e))}function rn(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__">${l("model.customOption")}</option>`:"",r=(t||[]).map(d=>`<option value="${u(d)}">${u(d)}</option>`).join("");e.innerHTML=a+r+s,i&&Array.from(e.options).some(d=>d.value===i)&&(e.value=i)}function X(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 to(e=null){let t=A(),n=document.getElementById("selCli");if(n){let i=e?.cli||n.value||t[0]||"claude";n.innerHTML=t.map(a=>{let s=le(a)?.label||a;return`<option value="${u(a)}">${u(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="${u(a)}">${u(a)}</option>`).join(""),Array.from(o.options).some(a=>a.value===i)&&(o.value=i)}}function no(e=null){for(let t of A()){let n=Z(t);if(n){let i=e?.perCli?.[t]?.model||n.value||"";rn(n,R[t]||[],{includeCustom:!0,selected:i}),i&&!Array.from(n.options).some(a=>a.value===i)&&(X(n,i),n.value=i)}let o=it(t);if(o){let i=le(t),a=[""].concat(i?.efforts||[]),s=e?.perCli?.[t]?.effort||o.value||"",r=[...new Set(a)],d=i?.efforts?.length===0&&i?.effortNote?i.effortNote:"\u2014 none";o.innerHTML=r.map(m=>m?`<option value="${u(m)}">${u(m)}</option>`:`<option value="">${u(d)}</option>`).join(""),i?.effortNote&&(o.title=i.effortNote),o.disabled=i?.efforts?.length===0&&!!i?.effortNote,Array.from(o.options).some(m=>m.value===s)&&(o.value=s)}}}function tt(e,t=""){let n=document.getElementById("selEffort");if(!n)return;let o=le(e);if(o?.effortNote){n.innerHTML=`<option value="">${u(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="${u(s)}">${u(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 at(){await re();let e=await f("/api/settings");if(!e)return;tn(e.locale??""),to(e),no(e);let t=document.getElementById("selCli");t&&Array.from(t.options).some(m=>m.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),ln(e.permissions,!1),e.perCli)for(let[m,p]of Object.entries(e.perCli)){let g=Z(m),b=it(m);g&&p.model&&(X(g,p.model),g.value=p.model),b&&(b.value=p.effort||"")}ve(!1);let i=e.activeOverrides?.[e.cli]||{},a=e.perCli?.[e.cli]||{},s=i.model||a.model,r=i.effort||a.effort||"",d=document.getElementById("selModel");s&&d&&(d.value=s),tt(e.cli,r),oo(e),dn(e),st()}async function st(){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=l("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 rt(){let e=document.getElementById("mcpSyncResult");if(e){e.style.display="block",e.textContent=l("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(" &nbsp; ")}catch(t){e.textContent="\u274C "+t.message}}}async function lt(){let e=document.getElementById("mcpSyncResult");if(e){e.style.display="block",e.textContent=l("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>"),st()}catch(t){e.textContent="\u274C "+t.message}}}async function nt(){let e={cli:document.getElementById("selCli")?.value||"claude"},t=document.getElementById("headerCli");t&&(t.textContent=e.cli),await y("/api/settings","PUT",e)}function ln(e,t=!0){t&&H("/api/settings","PUT",{permissions:"auto"})}function cn(e){let t=Z(e);return t?t.value==="__custom__"?sn(e)?.value?.trim()||t.options[0]?.value||"default":t.value:"default"}function ct(e,t){let n=sn(e);n&&(t.value==="__custom__"?(n.style.display="block",n.focus()):(n.style.display="none",ee()))}function dt(e,t){let n=t.value.trim();if(!n)return;let o=Z(e);o&&(X(o,n),o.value=n,t.style.display="none",ee())}async function ee(){let e={};for(let t of A()){if(!Z(t))continue;let o=it(t);e[t]={model:cn(t),effort:o?o.value:""}}await y("/api/settings","PUT",{perCli:e})}function ve(e=!0){let t=document.getElementById("selCli")?.value||"claude",n=R[t]||[],o=document.getElementById("selModel");rn(o,n,{includeCustom:!0,includeDefault:!0});let i=document.getElementById("headerCli");i&&(i.textContent=t),tt(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=l("model.placeholder"),s.style.display="none",s.onchange=function(){let r=this.value.trim();!r||!o||(X(o,r),o.value=r,this.style.display="none",J())},!o){e&&nt();return}o.parentElement?.appendChild(s),o.onchange=function(){this.value==="__custom__"?(s.style.display="block",s.focus()):(s.style.display="none",J())},f("/api/settings").then(r=>{if(!r)return;let d=r.activeOverrides?.[t]||{},m=r.perCli?.[t]||{},p=d.model||m.model,g=d.effort||m.effort||"";p&&o&&(X(o,p),o.value=p),tt(t,g)}),e&&nt()}async function J(){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 he(){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 be(e){document.getElementById("tgOn")?.classList.toggle("active",e),document.getElementById("tgOff")?.classList.toggle("active",!e),await y("/api/settings","PUT",{telegram:{enabled:e}})}async function Ee(e){document.getElementById("tgForwardOn")?.classList.toggle("active",e),document.getElementById("tgForwardOff")?.classList.toggle("active",!e),await y("/api/settings","PUT",{telegram:{forwardAll:e}})}function oo(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(", "));let i=t.forwardAll!==!1;document.getElementById("tgForwardOn")?.classList.toggle("active",i),document.getElementById("tgForwardOff")?.classList.toggle("active",!i)}function dn(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 r=o[s]||"",d=n.map(m=>`<option value="${m}" ${m===r?"selected":""}>${m}</option>`).join("");a+=`
63
63
  <div class="settings-row sub-row">
64
- <label style="min-width:60px">Fallback ${l+1}</label>
65
- <select id="fallback${l}"
64
+ <label style="min-width:60px">Fallback ${s+1}</label>
65
+ <select id="fallback${s}"
66
66
  style="font-size:11px;padding:4px;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:4px;flex:1">
67
- <option value="">${d("settings.none")}</option>
68
- ${s}
67
+ <option value="">${l("settings.none")}</option>
68
+ ${d}
69
69
  </select>
70
- </div>`}t.innerHTML=a}async function it(){let t=[...document.querySelectorAll("#fallbackOrderList select")].map(n=>n.value).filter(Boolean);await y("/api/settings","PUT",{fallbackOrder:t})}async function ve(e=!1){let t=Number(localStorage.getItem("cliStatusInterval")||300);if(!e&&r.cliStatusCache&&t>0&&Date.now()-r.cliStatusTs<t*1e3){Kt({cliStatus:r.cliStatusCache?.cliStatus,quota:r.cliStatusCache?.quota});return}let n=document.getElementById("cliStatusList");n&&(n.innerHTML='<div style="color:var(--text-dim);font-size:11px">Loading...</div>');let[o,i]=await Promise.all([v("/api/cli-status"),v("/api/quota")]);r.cliStatusCache={cliStatus:o,quota:i},r.cliStatusTs=Date.now(),Kt({cliStatus:o,quota:i})}function Kt(e){let{cliStatus:t,quota:n}=e,o=document.getElementById("cliStatusList"),i={claude:{install:"npm i -g @anthropic-ai/claude-code",auth:"claude auth"},codex:{install:"npm i -g @openai/codex",auth:"codex login"},gemini:{install:"npm i -g @google/gemini-cli",auth:`gemini (${d("cli.gemini.auth")})`},opencode:{install:"npm i -g opencode-ai",auth:"opencode auth"},copilot:{install:"npm i -g copilot",auth:"copilot login \uB610\uB294 gh auth login"}},a="";if(!t||typeof t!="object"){o&&(o.innerHTML='<div style="color:var(--text-dim);font-size:11px">Failed to load CLI status</div>');return}for(let[l,c]of Object.entries(t)){let s=n?.[l],u;c.available?!s||s.error?u="ok":s.authenticated===!1?u="warn":u="ok":u="missing";let p="";if(s?.account){let f=[];s.account.email&&f.push(s.account.email),s.account.type&&f.push(s.account.type),s.account.plan&&f.push(s.account.plan),s.account.tier&&f.push(s.account.tier),f.length&&(p=`<div style="font-size:10px;color:var(--text-dim);margin:2px 0 4px 16px">${m(f.join(" \xB7 "))}</div>`)}let g="";if(!c.available||u==="warn"){let f=i[l];if(f){let E=!c.available,Ce=E?d("cli.authRequired"):d("cli.notAuthenticated"),Bt=E?"#ef4444":"#fbbf24";g=`
71
- <div style="font-size:10px;margin:4px 0 2px 16px;padding:6px 8px;background:var(--bg-dim, #1e1e2e);border-radius:4px;border-left:2px solid ${Bt}">
72
- <div style="color:${Bt};margin-bottom:3px">${Ce}</div>
73
- ${E?`<div style="color:var(--text-dim)"><code style="font-size:10px;background:var(--border);padding:1px 4px;border-radius:2px">${m(f.install)}</code></div>`:""}
74
- <div style="color:var(--text-dim)${E?";margin-top:2px":""}"><code style="font-size:10px;background:var(--border);padding:1px 4px;border-radius:2px">${m(f.auth)}</code></div>
70
+ </div>`}t.innerHTML=a}async function mt(){let t=[...document.querySelectorAll("#fallbackOrderList select")].map(n=>n.value).filter(Boolean);await y("/api/settings","PUT",{fallbackOrder:t})}async function te(e=!1){let t=Number(localStorage.getItem("cliStatusInterval")||300);if(!e&&c.cliStatusCache&&t>0&&Date.now()-c.cliStatusTs<t*1e3){an({cliStatus:c.cliStatusCache?.cliStatus,quota:c.cliStatusCache?.quota});return}let n=document.getElementById("cliStatusList");n&&(n.innerHTML='<div style="color:var(--text-dim);font-size:11px">Loading...</div>');let[o,i]=await Promise.all([f("/api/cli-status"),f("/api/quota")]);c.cliStatusCache={cliStatus:o,quota:i},c.cliStatusTs=Date.now(),an({cliStatus:o,quota:i})}function an(e){let{cliStatus:t,quota:n}=e,o=document.getElementById("cliStatusList"),i={claude:{install:"npm i -g @anthropic-ai/claude-code",auth:"claude auth"},codex:{install:"npm i -g @openai/codex",auth:"codex login"},gemini:{install:"npm i -g @google/gemini-cli",auth:`gemini (${l("cli.gemini.auth")})`},opencode:{install:"npm i -g opencode-ai",auth:"opencode auth"},copilot:{install:"npm i -g copilot",auth:"copilot login \uB610\uB294 gh auth login"}},a="";if(!t||typeof t!="object"){o&&(o.innerHTML='<div style="color:var(--text-dim);font-size:11px">Failed to load CLI status</div>');return}for(let[r,d]of Object.entries(t)){let m=n?.[r],p;d.available?!m||m.error?p="ok":m.authenticated===!1?p="warn":p="ok":p="missing";let g="";if(m?.account){let E=[];m.account.email&&E.push(m.account.email),m.account.type&&E.push(m.account.type),m.account.plan&&E.push(m.account.plan),m.account.tier&&E.push(m.account.tier),E.length&&(g=`<div style="font-size:10px;color:var(--text-dim);margin:2px 0 4px 16px">${u(E.join(" \xB7 "))}</div>`)}let b="";if(!d.available||p==="warn"){let E=i[r];if(E){let B=!d.available,De=B?l("cli.authRequired"):l("cli.notAuthenticated"),zt=B?"#ef4444":"#fbbf24";b=`
71
+ <div style="font-size:10px;margin:4px 0 2px 16px;padding:6px 8px;background:var(--bg-dim, #1e1e2e);border-radius:4px;border-left:2px solid ${zt}">
72
+ <div style="color:${zt};margin-bottom:3px">${De}</div>
73
+ ${B?`<div style="color:var(--text-dim)"><code style="font-size:10px;background:var(--border);padding:1px 4px;border-radius:2px">${u(E.install)}</code></div>`:""}
74
+ <div style="color:var(--text-dim)${B?";margin-top:2px":""}"><code style="font-size:10px;background:var(--border);padding:1px 4px;border-radius:2px">${u(E.auth)}</code></div>
75
75
  </div>
76
- `}}let h="";s?.windows?.length&&(h=s.windows.map(f=>{let E=Math.round(f.percent),Ce=E>80?"#ef4444":E>50?"#fbbf24":"#38bdf8";return`
76
+ `}}let h="";m?.windows?.length&&(h=m.windows.map(E=>{let B=Math.round(E.percent),De=B>80?"#ef4444":B>50?"#fbbf24":"#38bdf8";return`
77
77
  <div style="display:flex;align-items:center;gap:6px;margin-left:16px;font-size:10px;color:var(--text-dim)">
78
- <span style="width:42px">${f.label}</span>
78
+ <span style="width:42px">${E.label}</span>
79
79
  <div style="flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden">
80
- <div style="width:${E}%;height:100%;background:${Ce};border-radius:2px"></div>
80
+ <div style="width:${B}%;height:100%;background:${De};border-radius:2px"></div>
81
81
  </div>
82
- <span style="width:28px;text-align:right">${E}%</span>
82
+ <span style="width:28px;text-align:right">${B}%</span>
83
83
  </div>
84
84
  `}).join("")),a+=`
85
85
  <div class="settings-group" style="margin-bottom:6px;padding:8px 10px">
86
86
  <div class="cli-status-row">
87
- <span class="cli-dot ${u}"></span>
88
- <span class="cli-name" style="font-weight:600">${l}</span>
87
+ <span class="cli-dot ${p}"></span>
88
+ <span class="cli-name" style="font-weight:600">${r}</span>${r==="copilot"?`<button id="copilotKeychainBtn" style="font-size:9px;margin-left:6px;padding:1px 5px;background:var(--border);color:var(--text-dim);border:1px solid var(--text-dim);border-radius:3px;cursor:pointer;vertical-align:middle;line-height:1" title="${l("copilot.keychainHint")}">\u{1F511}</button>`:""}
89
89
  </div>
90
- ${p}
91
90
  ${g}
91
+ ${b}
92
92
  ${h}
93
93
  </div>
94
- `}o&&(o.innerHTML=a)}function at(){v("/api/prompt").then(e=>{if(!e)return;let t=document.getElementById("modalPromptEditor");t&&(t.value=e.content||""),document.getElementById("promptModal")?.classList.add("open")})}function N(e){e&&e.target!==e.currentTarget||document.getElementById("promptModal")?.classList.remove("open")}async function st(){let t=document.getElementById("modalPromptEditor")?.value||"";await y("/api/prompt","PUT",{content:t}),document.getElementById("promptModal")?.classList.remove("open")}var q=x(()=>{"use strict";ae();A();re();S();M();w()});async function Vt(){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"}he=await lt("ko"),e==="ko"?ee=he:ee=await lt(e),Z=e,Xt()}async function lt(e){try{let{api:t}=await Promise.resolve().then(()=>(M(),$t));return await t(`/api/i18n/${e}`)||{}}catch{return{}}}function d(e,t={}){let n=ee[e]??he[e]??e;for(let[o,i]of Object.entries(t))n=n.replaceAll(`{${o}}`,String(i));return n}function Xt(){document.querySelectorAll("[data-i18n]").forEach(e=>{let t=e.getAttribute("data-i18n");t&&(e.textContent=d(t))}),document.querySelectorAll("[data-i18n-placeholder]").forEach(e=>{let t=e.getAttribute("data-i18n-placeholder");t&&(e.placeholder=d(t))}),document.querySelectorAll("[data-i18n-title]").forEach(e=>{let t=e.getAttribute("data-i18n-title");t&&(e.title=d(t))}),document.querySelectorAll("[data-i18n-aria]").forEach(e=>{let t=e.getAttribute("data-i18n-aria");t&&e.setAttribute("aria-label",d(t))})}async function Zt(e){if(e!==Z){e==="ko"?ee=he:ee=await lt(e),Z=e;try{localStorage.setItem("claw_locale",e)}catch{}Xt();try{let{loadEmployees:t}=await Promise.resolve().then(()=>(O(),G));t()}catch{}try{let{loadSkills:t}=await Promise.resolve().then(()=>(se(),je));t()}catch{}try{let{loadCommands:t}=await Promise.resolve().then(()=>(ue(),We));t()}catch{}try{let{loadSettings:t}=await Promise.resolve().then(()=>(q(),X));t()}catch{}}}function te(){return Z}function _t(e,t={}){let n=new URL(e,location.origin);return n.searchParams.has("locale")||n.searchParams.set("locale",Z),fetch(n.toString(),t)}var Z,ee,he,S=x(()=>{"use strict";Z="ko",ee={},he={}});function en(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 tn=x(()=>{"use strict"});function m(e){return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#39;")}function an(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"],ADD_ATTR:["aria-hidden","xmlns","viewBox"]}):e.replace(/<script[\s\S]*?>[\s\S]*?<\/script>/gi,"").replace(/\bon\w+\s*=/gi,"data-removed=").replace(/javascript\s*:/gi,"about:blank")}function be(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 _n(e){let t=[],n=[],o=e.replace(/```[\s\S]*?```/g,i=>(n.push(i),`\0C${n.length-1}\0`)).replace(/`[^`]+`/g,i=>(n.push(i),`\0C${n.length-1}\0`));return o=o.replace(/\$\$([\s\S]+?)\$\$/g,(i,a)=>(t.push({tex:a.trim(),displayMode:!0}),`\0MATH-${t.length-1}\0`)),o=o.replace(/\\\[([\s\S]+?)\\\]/g,(i,a)=>(t.push({tex:a.trim(),displayMode:!0}),`\0MATH-${t.length-1}\0`)),o=o.replace(/(?<!\$)\$(?!\$)([^\n$]+?)\$(?!\$)/g,(i,a)=>(t.push({tex:a.trim(),displayMode:!1}),`\0MATH-${t.length-1}\0`)),o=o.replace(/\\\((.+?)\\\)/g,(i,a)=>(t.push({tex:a.trim(),displayMode:!1}),`\0MATH-${t.length-1}\0`)),o=o.replace(/\x00C(\d+)\x00/g,(i,a)=>n[Number(a)]),{text:o,blocks:t}}function Nn(e,t){return e.replace(/\x00MATH-(\d+)\x00/g,(n,o)=>{let i=t[Number(o)];if(!i)return'<code title="math placeholder error">[math error]</code>';if(typeof katex>"u")return i.displayMode?`<pre><code>${m(i.tex)}</code></pre>`:`<code>${m(i.tex)}</code>`;try{return katex.renderToString(i.tex,{displayMode:i.displayMode,throwOnError:!1})}catch{return i.displayMode?`<pre><code>${m(i.tex)}</code></pre>`:`<code>${m(i.tex)}</code>`}})}function Jn(){typeof mermaid>"u"||document.querySelectorAll(".mermaid-pending").forEach(async e=>{e.classList.remove("mermaid-pending");let t=e.textContent||"",n=`mermaid-${++qn}`;try{let{svg:o}=await mermaid.render(n,t);e.innerHTML=an(o),e.classList.add("mermaid-rendered")}catch(o){let i=o?.message||o?.str||"Unknown error";e.innerHTML=`
94
+ `}o&&(o.innerHTML=a);let s=document.getElementById("copilotKeychainBtn");s&&s.addEventListener("click",async()=>{let r=s;r.disabled=!0,r.textContent="\u23F3";try{let d=await f("/api/copilot/refresh",{method:"POST"});r.textContent=d?.ok?"\u2705":"\u274C",d?.ok&&await te(!0)}catch{r.textContent="\u274C"}setTimeout(()=>{r.textContent="\u{1F511}",r.disabled=!1},2e3)})}function ut(){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 K(e){e&&e.target!==e.currentTarget||document.getElementById("promptModal")?.classList.remove("open")}async function pt(){let t=document.getElementById("modalPromptEditor")?.value||"";await y("/api/prompt","PUT",{content:t}),document.getElementById("promptModal")?.classList.remove("open")}async function ft(){let e=await f("/api/prompt-templates");e&&(gt=e.templates,C=!1,io(e.tree),ht("tree"),document.getElementById("templateModal")?.classList.add("open"))}function io(e){let t=document.getElementById("templateTree");if(t){t.innerHTML="";for(let n of e){let o=document.createElement("div");o.style.cssText="background:var(--bg);border:1px solid var(--accent);border-radius:6px;padding:8px 10px;margin:8px 0 4px;font-size:12px;color:var(--accent);font-weight:600",o.textContent=`${n.emoji} ${n.label}`,t.appendChild(o);for(let i of n.children){let a=gt.find(r=>r.id===i);if(!a)continue;let s=document.createElement("div");s.style.cssText="background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:6px 10px;margin:2px 0 2px 24px;font-size:12px;cursor:pointer;transition:border-color .15s",s.textContent=`\u{1F4C4} ${a.filename}`,s.addEventListener("mouseenter",()=>{s.style.borderColor="var(--accent2)"}),s.addEventListener("mouseleave",()=>{s.style.borderColor="var(--border)"}),s.addEventListener("click",()=>{ao(a)}),t.appendChild(s)}}}}function ao(e){let t=document.getElementById("templateEditor");t.value=e.content,t.dataset.templateId=e.id,t.readOnly=!0,C=!1;let n=document.getElementById("templateEditorLabel");n&&(n.textContent=`\u{1F4C4} ${e.filename}`);let o=e.content.match(/\{\{[A-Z_]+\}\}/g),i=document.getElementById("templateVars");i&&(i.textContent=o?`vars: ${[...new Set(o)].join(", ")}`:"no variables");let a=document.getElementById("templateSaveBtn");a&&(a.style.display="none");let s=document.getElementById("templateDevToggle");s&&(s.style.color="var(--text-dim)",s.style.borderColor="var(--border)",s.textContent="\u{1F527} \uAC1C\uBC1C\uC790 \uBAA8\uB4DC");let r=document.getElementById("templateModalTitle");r&&(r.textContent=`\u{1F4C4} ${e.filename}`),ht("editor")}function yt(){if(!C&&!confirm(`\u26A0\uFE0F \uD504\uB86C\uD504\uD2B8\uB97C \uC9C1\uC811 \uC218\uC815\uD558\uBA74 \uC608\uC0C1\uCE58 \uBABB\uD55C \uB3D9\uC791\uC774 \uBC1C\uC0DD\uD560 \uC218 \uC788\uC2B5\uB2C8\uB2E4.
95
+ \uACC4\uC18D\uD558\uC2DC\uACA0\uC2B5\uB2C8\uAE4C?`))return;C=!C;let e=document.getElementById("templateEditor");e.readOnly=!C;let t=document.getElementById("templateSaveBtn");t&&(t.style.display=C?"":"none");let n=document.getElementById("templateDevToggle");n&&(n.style.color=C?"var(--stop-btn)":"var(--text-dim)",n.style.borderColor=C?"var(--stop-btn)":"var(--border)",n.textContent=C?"\u{1F513} \uAC1C\uBC1C\uC790 \uBAA8\uB4DC ON":"\u{1F527} \uAC1C\uBC1C\uC790 \uBAA8\uB4DC")}async function vt(){let e=document.getElementById("templateEditor"),t=e.dataset.templateId;if(!t)return;await y(`/api/prompt-templates/${t}`,"PUT",{content:e.value});let n=document.getElementById("templateEditorLabel");n&&(n.textContent="\u2705 \uC800\uC7A5 + \uD56B\uB9AC\uB85C\uB4DC \uC644\uB8CC!",setTimeout(()=>{n.textContent=`\u{1F4C4} ${t}.md`},2e3));let o=gt.find(i=>i.id===t);o&&(o.content=e.value)}function ht(e){let t=document.getElementById("templateTreeView"),n=document.getElementById("templateEditorView");t&&(t.style.display=e==="tree"?"":"none"),n&&(n.style.display=e==="editor"?"flex":"none");let o=document.getElementById("templateModalTitle");o&&e==="tree"&&(o.textContent="\u{1F4DD} \uD504\uB86C\uD504\uD2B8 \uAD6C\uC870")}function bt(){ht("tree")}function xe(e){e&&e.target!==e.currentTarget||document.getElementById("templateModal")?.classList.remove("open")}var gt,C,U=x(()=>{"use strict";ce();D();ue();L();T();k();gt=[],C=!1});async function mn(){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"}Le=await Et("ko"),e==="ko"?ie=Le:ie=await Et(e),oe=e,un()}async function Et(e){try{let{api:t}=await Promise.resolve().then(()=>(T(),Jt));return await t(`/api/i18n/${e}`)||{}}catch{return{}}}function l(e,t={}){let n=ie[e]??Le[e]??e;for(let[o,i]of Object.entries(t))n=n.replaceAll(`{${o}}`,String(i));return n}function un(){document.querySelectorAll("[data-i18n]").forEach(e=>{let t=e.getAttribute("data-i18n");t&&(e.textContent=l(t))}),document.querySelectorAll("[data-i18n-placeholder]").forEach(e=>{let t=e.getAttribute("data-i18n-placeholder");t&&(e.placeholder=l(t))}),document.querySelectorAll("[data-i18n-title]").forEach(e=>{let t=e.getAttribute("data-i18n-title");t&&(e.title=l(t))}),document.querySelectorAll("[data-i18n-aria]").forEach(e=>{let t=e.getAttribute("data-i18n-aria");t&&e.setAttribute("aria-label",l(t))})}async function pn(e){if(e!==oe){e==="ko"?ie=Le:ie=await Et(e),oe=e;try{localStorage.setItem("claw_locale",e)}catch{}un();try{let{loadEmployees:t}=await Promise.resolve().then(()=>(N(),Y));t()}catch{}try{let{loadSkills:t}=await Promise.resolve().then(()=>(de(),Ue));t()}catch{}try{let{loadCommands:t}=await Promise.resolve().then(()=>(ye(),et));t()}catch{}try{let{loadSettings:t}=await Promise.resolve().then(()=>(U(),ne));t()}catch{}}}function ae(){return oe}function Zt(e,t={}){let n=new URL(e,location.origin);return n.searchParams.has("locale")||n.searchParams.set("locale",oe),fetch(n.toString(),t)}var oe,ie,Le,L=x(()=>{"use strict";oe="ko",ie={},Le={}});function gn(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 fn=x(()=>{"use strict"});function u(e){return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#39;")}function hn(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"],ADD_ATTR:["aria-hidden","xmlns","viewBox"]}):e.replace(/<script[\s\S]*?>[\s\S]*?<\/script>/gi,"").replace(/\bon\w+\s*=/gi,"data-removed=").replace(/javascript\s*:/gi,"about:blank")}function Me(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 so(e){let t=[],n=[],o=e.replace(/```[\s\S]*?```/g,i=>(n.push(i),`\0C${n.length-1}\0`)).replace(/`[^`]+`/g,i=>(n.push(i),`\0C${n.length-1}\0`));return o=o.replace(/\$\$([\s\S]+?)\$\$/g,(i,a)=>(t.push({tex:a.trim(),displayMode:!0}),`\0MATH-${t.length-1}\0`)),o=o.replace(/\\\[([\s\S]+?)\\\]/g,(i,a)=>(t.push({tex:a.trim(),displayMode:!0}),`\0MATH-${t.length-1}\0`)),o=o.replace(/(?<!\$)\$(?!\$)([^\n$]+?)\$(?!\$)/g,(i,a)=>(t.push({tex:a.trim(),displayMode:!1}),`\0MATH-${t.length-1}\0`)),o=o.replace(/\\\((.+?)\\\)/g,(i,a)=>(t.push({tex:a.trim(),displayMode:!1}),`\0MATH-${t.length-1}\0`)),o=o.replace(/\x00C(\d+)\x00/g,(i,a)=>n[Number(a)]),{text:o,blocks:t}}function ro(e,t){return e.replace(/\x00MATH-(\d+)\x00/g,(n,o)=>{let i=t[Number(o)];if(!i)return'<code title="math placeholder error">[math error]</code>';if(typeof katex>"u")return i.displayMode?`<pre><code>${u(i.tex)}</code></pre>`:`<code>${u(i.tex)}</code>`;try{return katex.renderToString(i.tex,{displayMode:i.displayMode,throwOnError:!1})}catch{return i.displayMode?`<pre><code>${u(i.tex)}</code></pre>`:`<code>${u(i.tex)}</code>`}})}function co(){typeof mermaid>"u"||document.querySelectorAll(".mermaid-pending").forEach(async e=>{e.classList.remove("mermaid-pending");let t=e.textContent||"",n=`mermaid-${++lo}`;try{let{svg:o}=await mermaid.render(n,t);e.innerHTML=hn(o),e.classList.add("mermaid-rendered")}catch(o){let i=o?.message||o?.str||"Unknown error";e.innerHTML=`
95
96
  <div style="border:1px solid #ef4444;border-radius:6px;padding:8px;margin:4px 0">
96
- <div style="color:#ef4444;font-size:11px;margin-bottom:4px">\u26A0\uFE0F ${m(d("mermaid.renderFail")||"Mermaid render failed")}</div>
97
- <div style="color:#fbbf24;font-size:10px;margin-bottom:6px">${m(i.slice(0,200))}</div>
98
- <pre style="margin:0;font-size:11px;overflow-x:auto"><code>${m(t)}</code></pre>
99
- </div>`}})}function zn(){if(nn)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):d("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"}),nn=!0,!0}function Kn(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 sn(){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 Un(){on||(on=!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=d("code.copied"),t.classList.add("copied"),setTimeout(()=>{t.textContent=i,t.classList.remove("copied")},1500)}).catch(()=>{})}))}function rt(e){let t=be(e);if(!t)return`<em style="color:var(--text-dim)">${m(d("orchestrator.dispatching"))}</em>`;let{text:n,blocks:o}=_n(t),i;if(zn()){let a=en(n);i=marked.parse(a),i=i.replace(/<table/g,'<div class="table-wrapper"><table').replace(/<\/table>/g,"</table></div>")}else i=Kn(n);return i=Nn(i,o),i=an(i),requestAnimationFrame(()=>{Jn(),sn()}),Un(),i}var qn,nn,on,A=x(()=>{"use strict";S();tn();qn=0;nn=!1;(function e(){if(typeof hljs<"u"){sn();return}setTimeout(e,200)})();on=!1});function cn(){return J}function ln(e){J=(e||"").trim()||ct,localStorage.setItem(rn,J);let t=document.getElementById("appNameInput");t&&(t.value=J)}function dn(){J=localStorage.getItem(rn)||ct;let e=document.getElementById("appNameInput");e&&(e.value=J),document.getElementById("appNameSave")?.addEventListener("click",()=>{let t=document.getElementById("appNameInput");t&&ln(t.value)}),document.getElementById("appNameInput")?.addEventListener("keydown",t=>{let n=t;n.key==="Enter"&&(n.preventDefault(),ln(n.target.value),n.target.blur())})}var rn,ct,J,dt=x(()=>{"use strict";rn="agentName",ct="CLI-JAW",J=ct});var vt={};D(vt,{addMessage:()=>I,addSystemMsg:()=>b,appendAgentText:()=>mt,finalizeAgent:()=>xe,handleSave:()=>gt,initMsgCopy:()=>yt,loadMemory:()=>ft,loadMessages:()=>Wn,loadStats:()=>un,scrollToBottom:()=>ut,setStatus:()=>z,switchTab:()=>pt,updateQueueBadge:()=>Ee});function z(e){let t=document.getElementById("statusBadge"),n=document.getElementById("btnSend");r.agentBusy=e==="running",document.getElementById("typingIndicator")?.classList.toggle("active",r.agentBusy),e==="running"?(t&&(t.className="status-badge status-running",t.textContent="\u23F3 running"),n&&(n.textContent="\u25A0",n.title=d("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")),Ee(0))}function Ee(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 b(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 mt(e){if(!e)return;r.currentAgentDiv||(r.currentAgentDiv=I("agent",""));let t=r.currentAgentDiv?.querySelector(".msg-content");t&&(t.textContent+=e),ut()}function xe(e,t){let n=Date.now();if(!(!r.currentAgentDiv&&n-mn<500)){if(document.querySelectorAll(".msg-system.tool-activity").forEach(o=>o.remove()),e){r.currentAgentDiv||(r.currentAgentDiv=I("agent",""));let o=r.currentAgentDiv?.querySelector(".msg-content"),i="";if(t&&t.length>0){let a={};t.forEach(s=>{a[s.icon]=(a[s.icon]||0)+1});let l=Object.entries(a).map(([s,u])=>`${s}\xD7${u}`).join(" "),c=t.map(s=>`${s.icon} ${m(s.label)}`).join(`
100
- `);i=`<details class="tool-summary"><summary>${l}</summary><div class="tool-log">${c}</div></details>`}o&&(o.innerHTML=i+rt(e)),o&&o.setAttribute("data-raw",be(e))}r.currentAgentDiv=null,mn=Date.now(),z("idle"),un()}}function I(e,t){let n=document.getElementById("chatMessages"),o=document.createElement("div");o.className=`msg msg-${e}`;let i=rt(t);o.innerHTML=`<div class="msg-label">${e==="user"?d("msg.you"):cn()}</div><div class="msg-content">${i}</div><button class="msg-copy" title="Copy"></button>`;let a=o.querySelector(".msg-content");return a&&a.setAttribute("data-raw",be(t)),n?.appendChild(o),ut(),o}function ut(){let e=document.getElementById("chatMessages");e&&(e.scrollTop=e.scrollHeight)}function pt(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(),X)).then(o=>o.loadSettings()),e==="agents"&&Promise.resolve().then(()=>(O(),G)).then(o=>o.loadEmployees()),e==="skills"&&Promise.resolve().then(()=>(se(),je)).then(o=>o.loadSkills())}function gt(){document.getElementById("tabSettings")?.classList.contains("active")?Promise.resolve().then(()=>(q(),X)).then(t=>t.savePerCli()):Promise.resolve().then(()=>(q(),X)).then(t=>t.updateSettings())}async function un(){let e=await v("/api/messages");if(!e)return;let t=document.getElementById("statMsgs");t&&(t.textContent=d("stat.messages",{count:e.length}))}async function Wn(){let e=await v("/api/messages");e&&e.forEach(t=>I(t.role==="assistant"?"agent":t.role,t.content))}async function ft(){try{let e=await v("/api/memory"),t=document.getElementById("memoryList");if(!t||!e)return;if(e.length===0){t.innerHTML=`<li style="color:var(--text-dim)">${d("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 yt(){document.getElementById("chatMessages")?.addEventListener("click",e=>{let t=e.target?.closest(".msg-copy");if(!t)return;let o=t.closest(".msg")?.querySelector(".msg-content");if(!o)return;let i=o.getAttribute("data-raw")||o.innerText||o.textContent||"";navigator.clipboard.writeText(i).then(()=>{t.classList.add("copied"),setTimeout(()=>t.classList.remove("copied"),600)}).catch(()=>{})})}var mn,K=x(()=>{"use strict";w();A();dt();S();M();mn=0});function ht(){r.ws=new WebSocket(`ws://${location.host}?lang=${te()}`),r.ws.onmessage=e=>{let t=JSON.parse(e.data);if(t.type==="agent_status")t.running!==void 0?z(t.running?"running":"idle"):z(t.status||"idle"),t.agentId&&t.phase&&(pn[t.agentId]={phase:t.phase,phaseLabel:t.phaseLabel||""},Promise.resolve().then(()=>(O(),G)).then(n=>n.loadEmployees()));else if(t.type==="queue_update")Ee(t.pending||0);else if(t.type==="worklog_created")b(`\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(", ");b(d("ws.roundStart",{round:t.round||0,count:n.length,names:o}))}else if(t.type==="round_done")t.action==="complete"?b(d("ws.roundDone",{round:t.round||0})):t.action==="next"?b(d("ws.roundNext",{round:t.round||0})):b(d("ws.roundRetry",{round:t.round||0}));else if(t.type==="agent_tool")b(`${t.icon||""} ${t.label||""}`,"tool-activity");else if(t.type==="agent_output")mt(t.text||"");else if(t.type==="agent_retry")b(d("ws.retry",{cli:t.cli||"",delay:t.delay||10}),"tool-activity");else if(t.type==="agent_fallback")b(d("ws.fallback",{from:t.from||"",to:t.to||""}),"tool-activity");else if(t.type==="agent_done")xe(t.text||"",t.toolLog);else if(t.type==="orchestrate_done")xe(t.text||"");else if(t.type==="clear"){let n=document.getElementById("chatMessages");n&&(n.innerHTML="")}else if(t.type==="agent_added"||t.type==="agent_updated"||t.type==="agent_deleted")Promise.resolve().then(()=>(O(),G)).then(n=>n.loadEmployees());else if(t.type==="orc_state"){let n=new Set(["IDLE","P","A","B","C","D"]),o=typeof t.state=="string"?t.state:"IDLE",i=n.has(o)?o:"IDLE";if(r.orcState=i,i==="IDLE"||i==="D")document.body.removeAttribute("data-orc-state"),document.body.style.removeProperty("--orc-glow");else{document.body.setAttribute("data-orc-state",i);let p=`--orc-glow-${i}`,g=getComputedStyle(document.documentElement).getPropertyValue(p).trim();document.body.style.setProperty("--orc-glow",g)}document.body.classList.add("orc-pulse"),setTimeout(()=>document.body.classList.remove("orc-pulse"),700);let a=document.getElementById("orcStateBadge");if(a){let p={IDLE:"",P:"PLAN",A:"AUDIT",B:"BUILD",C:"CHECK",D:"DONE"};a.textContent=p[i],a.style.display=i==="IDLE"?"none":"inline-block"}let l=["P","A","B","C"],c=document.getElementById("pabcRoadmap"),s=document.getElementById("sharkRunner"),u=document.getElementById("pabcBrand");if(c&&s){if(i==="IDLE")c.classList.remove("visible","shimmer-out"),s.classList.remove("running");else if(i==="D"){l.forEach(p=>{let g=document.getElementById(`dot-${p}`);g&&(g.className="pabc-dot done",g.setAttribute("data-phase",p))});for(let p=0;p<4;p++){let g=document.getElementById(`pabc-conn-${p}`);g&&(g.className="pabc-connector done")}s.classList.remove("running"),c.classList.add("shimmer-out"),setTimeout(()=>c.classList.remove("visible","shimmer-out"),1e3)}else{c.classList.remove("shimmer-out"),c.classList.add("visible"),s.classList.add("running");let p=l.indexOf(i);l.forEach((g,h)=>{let f=document.getElementById(`dot-${g}`);f&&(f.className=`pabc-dot ${h<p?"done":h===p?"active":"future"}`,f.setAttribute("data-phase",g))});for(let g=0;g<4;g++){let h=document.getElementById(`pabc-conn-${g}`);h&&(h.className=`pabc-connector ${g<p?"done":""}`)}requestAnimationFrame(()=>{let g=c.getBoundingClientRect(),h=document.getElementById(`dot-${i}`);if(!h)return;let f=document.getElementById(`pabc-conn-${p}`);if(f&&i!=="C"){let E=f.getBoundingClientRect();s.style.left=E.left-g.left+E.width*.4-18+"px"}else{let E=h.getBoundingClientRect();s.style.left=E.left-g.left+E.width/2-18+"px"}})}u&&t.title&&(u.textContent=t.title)}}else t.type==="new_message"&&t.source==="telegram"&&I(t.role==="assistant"?"agent":t.role||"user",t.content||"")},r.ws.onopen=()=>{console.log("[ws] connected"),Promise.resolve().then(()=>(K(),vt)).then(e=>{let t=document.getElementById("chatMessages");t&&(t.innerHTML=""),e.loadMessages(),e.setStatus("idle")})},r.ws.onclose=()=>{console.log("[ws] disconnected, reconnecting in 2s..."),z("idle"),setTimeout(ht,2e3)}}function Ft(e){return pn[e]||null}var pn,Re=x(()=>{"use strict";w();K();S();pn={}});Re();K();w();K();re();S();ue();M();async function Me(){let e=document.getElementById("chatInput"),t=document.getElementById("btnSend");if(!e||!t)return;let n=document.activeElement===t;if(t.classList.contains("stop-mode")&&n&&!e.value.trim()&&!r.attachedFiles.length){C("/api/stop","POST");return}let o=e.value.trim();if(!o&&!r.attachedFiles.length)return;let a=o.slice(1).trim().split(/\s+/)[0]||"",l=a.includes("/")||a.includes("\\");if(o.startsWith("/")&&!r.attachedFiles.length&&!l){e.value="",Et(),T();try{let c,s;if(typeof AbortSignal?.timeout=="function")c=AbortSignal.timeout(1e4);else{let h=new AbortController;c=h.signal,s=setTimeout(()=>h.abort(),1e4)}let u=le(),p=await fetch("/api/command",{method:"POST",headers:{"Content-Type":"application/json","Accept-Language":u},body:JSON.stringify({text:o,locale:u}),signal:c});s&&clearTimeout(s);let g=await p.json().catch(()=>({}));if(g?.code==="not_command"){I("user",o),await y("/api/message","POST",{prompt:o});return}if(!p.ok&&!g?.text)throw new Error(`HTTP ${p.status}`);if(g?.code==="clear_screen"){let h=document.getElementById("chatMessages");h&&(h.innerHTML="")}g?.text&&b(g.text,"",g.type)}catch(c){b(d("chat.cmd.fail",{msg:c.message}),"","error")}return}if(r.attachedFiles.length){let s=`[\u{1F4CE} ${r.attachedFiles.map(u=>u.name).join(", ")}] ${o}`;I("user",s),e.value="",Et();try{let p=(await Promise.all(r.attachedFiles.map(g=>Gn(g)))).map(g=>d("chat.file.sent",{path:g})).join(`
101
- `);o&&(p+=d("chat.file.sentWithMsg",{text:o})),Le(),await y("/api/message","POST",{prompt:p})}catch(u){b(d("chat.file.uploadFail",{msg:u.message})),Le()}}else{I("user",o),e.value="",Et();let c=await fetch("/api/message",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({prompt:o})}),s=await c.json().catch(()=>({}));if(!c.ok){b(`\u274C ${s.error||d("chat.requestFail",{status:c.status})}`,"","error");return}if(s.queued){let{updateQueueBadge:u}=await Promise.resolve().then(()=>(K(),vt));u(s.pending||1)}else s.continued&&b(d("chat.continue"))}}function gn(e){e.key==="Enter"&&!e.shiftKey&&!e.isComposing&&(e.preventDefault(),Me())}async function Gn(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 bt(e){for(let t of e)r.attachedFiles.some(n=>n.name===t.name)||r.attachedFiles.push(t);xt(),document.getElementById("chatInput")?.focus()}function fn(e){r.attachedFiles.splice(e,1),xt()}function Le(){r.attachedFiles=[],xt();let e=document.getElementById("fileInput");e&&(e.value="")}function xt(){let e=document.getElementById("filePreview"),t=document.getElementById("filePreviewList");if(e){if(!r.attachedFiles.length){e.classList.remove("visible"),t&&(t.innerHTML="");return}e.classList.add("visible"),t&&(t.innerHTML=r.attachedFiles.map((n,o)=>{let i=(n.size/1024).toFixed(1);return`<div class="file-chip">
97
+ <div style="color:#ef4444;font-size:11px;margin-bottom:4px">\u26A0\uFE0F ${u(l("mermaid.renderFail")||"Mermaid render failed")}</div>
98
+ <div style="color:#fbbf24;font-size:10px;margin-bottom:6px">${u(i.slice(0,200))}</div>
99
+ <pre style="margin:0;font-size:11px;overflow-x:auto"><code>${u(t)}</code></pre>
100
+ </div>`}})}function mo(){if(yn)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">${u(t)}</div>`;let o=u(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?u(n):l("code.copy");return`<div class="code-block-wrapper">${`<span class="code-lang-label" data-lang="${n?u(n):""}">${i}</span>`}<pre><code class="hljs${n?` language-${u(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"}),yn=!0,!0}function uo(e){return u(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 bn(){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 po(){vn||(vn=!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=l("code.copied"),t.classList.add("copied"),setTimeout(()=>{t.textContent=i,t.classList.remove("copied")},1500)}).catch(()=>{})}))}function xt(e){let t=Me(e);if(!t)return`<em style="color:var(--text-dim)">${u(l("orchestrator.dispatching"))}</em>`;let{text:n,blocks:o}=so(t),i;if(mo()){let a=gn(n);i=marked.parse(a),i=i.replace(/<table/g,'<div class="table-wrapper"><table').replace(/<\/table>/g,"</table></div>")}else i=uo(n);return i=ro(i,o),i=hn(i),requestAnimationFrame(()=>{co(),bn()}),po(),i}var lo,yn,vn,D=x(()=>{"use strict";L();fn();lo=0;yn=!1;(function e(){if(typeof hljs<"u"){bn();return}setTimeout(e,200)})();vn=!1});function Ln(){return W}function En(e){W=(e||"").trim()||Lt,localStorage.setItem(xn,W);let t=document.getElementById("appNameInput");t&&(t.value=W)}function Mn(){W=localStorage.getItem(xn)||Lt;let e=document.getElementById("appNameInput");e&&(e.value=W),document.getElementById("appNameSave")?.addEventListener("click",()=>{let t=document.getElementById("appNameInput");t&&En(t.value)}),document.getElementById("appNameInput")?.addEventListener("keydown",t=>{let n=t;n.key==="Enter"&&(n.preventDefault(),En(n.target.value),n.target.blur())})}var xn,Lt,W,Mt=x(()=>{"use strict";xn="agentName",Lt="CLI-JAW",W=Lt});var Bt={};_(Bt,{addMessage:()=>S,addSystemMsg:()=>v,appendAgentText:()=>Tt,finalizeAgent:()=>Se,handleSave:()=>It,initMsgCopy:()=>Ct,loadMemory:()=>wt,loadMessages:()=>go,loadStats:()=>Sn,scrollToBottom:()=>St,setStatus:()=>G,switchTab:()=>kt,updateQueueBadge:()=>Te});function G(e){let t=document.getElementById("statusBadge"),n=document.getElementById("btnSend");c.agentBusy=e==="running",document.getElementById("typingIndicator")?.classList.toggle("active",c.agentBusy),e==="running"?(t&&(t.className="status-badge status-running",t.textContent="\u23F3 running"),n&&(n.textContent="\u25A0",n.title=l("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")),Te(0))}function Te(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 v(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 Tt(e){if(!e)return;c.currentAgentDiv||(c.currentAgentDiv=S("agent",""));let t=c.currentAgentDiv?.querySelector(".msg-content");t&&(t.textContent+=e),St()}function Se(e,t){let n=Date.now();if(!(!c.currentAgentDiv&&n-Tn<500)){if(document.querySelectorAll(".msg-system.tool-activity").forEach(o=>o.remove()),e){c.currentAgentDiv||(c.currentAgentDiv=S("agent",""));let o=c.currentAgentDiv?.querySelector(".msg-content"),i="";if(t&&t.length>0){let a={};t.forEach(d=>{a[d.icon]=(a[d.icon]||0)+1});let s=Object.entries(a).map(([d,m])=>`${d}\xD7${m}`).join(" "),r=t.map(d=>`${d.icon} ${u(d.label)}`).join(`
101
+ `);i=`<details class="tool-summary"><summary>${s}</summary><div class="tool-log">${r}</div></details>`}o&&(o.innerHTML=i+xt(e)),o&&o.setAttribute("data-raw",Me(e))}c.currentAgentDiv=null,Tn=Date.now(),G("idle"),Sn()}}function S(e,t){let n=document.getElementById("chatMessages"),o=document.createElement("div");o.className=`msg msg-${e}`;let i=xt(t);o.innerHTML=`<div class="msg-label">${e==="user"?l("msg.you"):Ln()}</div><div class="msg-content">${i}</div><button class="msg-copy" title="Copy"></button>`;let a=o.querySelector(".msg-content");return a&&a.setAttribute("data-raw",Me(t)),n?.appendChild(o),St(),o}function St(){let e=document.getElementById("chatMessages");e&&(e.scrollTop=e.scrollHeight)}function kt(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(()=>(U(),ne)).then(o=>o.loadSettings()),e==="agents"&&Promise.resolve().then(()=>(N(),Y)).then(o=>o.loadEmployees()),e==="skills"&&Promise.resolve().then(()=>(de(),Ue)).then(o=>o.loadSkills())}function It(){document.getElementById("tabSettings")?.classList.contains("active")?Promise.resolve().then(()=>(U(),ne)).then(t=>t.savePerCli()):Promise.resolve().then(()=>(U(),ne)).then(t=>t.updateSettings())}async function Sn(){let e=await f("/api/messages");if(!e)return;let t=document.getElementById("statMsgs");t&&(t.textContent=l("stat.messages",{count:e.length}))}async function go(){let e=await f("/api/messages");e&&e.forEach(t=>S(t.role==="assistant"?"agent":t.role,t.content))}async function wt(){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)">${l("mem.empty")}</li>`;return}t.innerHTML=e.map(n=>`<li><span class="memory-key">${u(n.key)}</span>: ${u(n.value)}</li>`).join("")}catch{}}function Ct(){document.getElementById("chatMessages")?.addEventListener("click",e=>{let t=e.target?.closest(".msg-copy");if(!t)return;let o=t.closest(".msg")?.querySelector(".msg-content");if(!o)return;let i=o.getAttribute("data-raw")||o.innerText||o.textContent||"";navigator.clipboard.writeText(i).then(()=>{t.classList.add("copied"),setTimeout(()=>t.classList.remove("copied"),600)}).catch(()=>{})})}var Tn,F=x(()=>{"use strict";k();D();Mt();L();T();Tn=0});function $t(){c.ws=new WebSocket(`ws://${location.host}?lang=${ae()}`),c.ws.onmessage=e=>{let t=JSON.parse(e.data);if(t.type==="agent_status")t.running!==void 0?G(t.running?"running":"idle"):G(t.status||"idle"),t.agentId&&t.phase&&(kn[t.agentId]={phase:t.phase,phaseLabel:t.phaseLabel||""},Promise.resolve().then(()=>(N(),Y)).then(n=>n.loadEmployees()));else if(t.type==="queue_update")Te(t.pending||0);else if(t.type==="worklog_created")v(`\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(", ");v(l("ws.roundStart",{round:t.round||0,count:n.length,names:o}))}else if(t.type==="round_done")t.action==="complete"?v(l("ws.roundDone",{round:t.round||0})):t.action==="next"?v(l("ws.roundNext",{round:t.round||0})):v(l("ws.roundRetry",{round:t.round||0}));else if(t.type==="agent_tool")v(`${t.icon||""} ${t.label||""}`,"tool-activity");else if(t.type==="agent_output")Tt(t.text||"");else if(t.type==="agent_retry")v(l("ws.retry",{cli:t.cli||"",delay:t.delay||10}),"tool-activity");else if(t.type==="agent_fallback")v(l("ws.fallback",{from:t.from||"",to:t.to||""}),"tool-activity");else if(t.type==="agent_done")Se(t.text||"",t.toolLog);else if(t.type==="orchestrate_done")Se(t.text||"");else if(t.type==="clear"){let n=document.getElementById("chatMessages");n&&(n.innerHTML="")}else if(t.type==="agent_added"||t.type==="agent_updated"||t.type==="agent_deleted")Promise.resolve().then(()=>(N(),Y)).then(n=>n.loadEmployees());else if(t.type==="orc_state"){let n=new Set(["IDLE","P","A","B","C","D"]),o=typeof t.state=="string"?t.state:"IDLE",i=n.has(o)?o:"IDLE";if(c.orcState=i,i==="IDLE"||i==="D")document.body.removeAttribute("data-orc-state"),document.body.style.removeProperty("--orc-glow");else{document.body.setAttribute("data-orc-state",i);let p=`--orc-glow-${i}`,g=getComputedStyle(document.documentElement).getPropertyValue(p).trim();document.body.style.setProperty("--orc-glow",g)}document.body.classList.add("orc-pulse"),setTimeout(()=>document.body.classList.remove("orc-pulse"),700);let a=document.getElementById("orcStateBadge");if(a){let p={IDLE:"",P:"PLAN",A:"AUDIT",B:"BUILD",C:"CHECK",D:"DONE"};a.textContent=p[i],a.style.display=i==="IDLE"?"none":"inline-block"}let s=["P","A","B","C"],r=document.getElementById("pabcRoadmap"),d=document.getElementById("sharkRunner"),m=document.getElementById("pabcBrand");if(r&&d){if(i==="IDLE")r.classList.remove("visible","shimmer-out"),d.classList.remove("running");else if(i==="D"){s.forEach(p=>{let g=document.getElementById(`dot-${p}`);g&&(g.className="pabc-dot done",g.setAttribute("data-phase",p))});for(let p=0;p<4;p++){let g=document.getElementById(`pabc-conn-${p}`);g&&(g.className="pabc-connector done")}d.classList.remove("running"),r.classList.add("shimmer-out"),setTimeout(()=>r.classList.remove("visible","shimmer-out"),1e3)}else{r.classList.remove("shimmer-out"),r.classList.add("visible"),d.classList.add("running");let p=s.indexOf(i);s.forEach((g,b)=>{let h=document.getElementById(`dot-${g}`);h&&(h.className=`pabc-dot ${b<p?"done":b===p?"active":"future"}`,h.setAttribute("data-phase",g))});for(let g=0;g<4;g++){let b=document.getElementById(`pabc-conn-${g}`);b&&(b.className=`pabc-connector ${g<p?"done":""}`)}requestAnimationFrame(()=>{let g=r.getBoundingClientRect(),b=document.getElementById(`dot-${i}`);if(!b)return;let h=document.getElementById(`pabc-conn-${p}`);if(h&&i!=="C"){let E=h.getBoundingClientRect();d.style.left=E.left-g.left+E.width*.4-18+"px"}else{let E=b.getBoundingClientRect();d.style.left=E.left-g.left+E.width/2-18+"px"}})}m&&t.title&&(m.textContent=t.title)}}else t.type==="new_message"&&t.source==="telegram"&&S(t.role==="assistant"?"agent":t.role||"user",t.content||"")},c.ws.onopen=()=>{console.log("[ws] connected"),Promise.resolve().then(()=>(F(),Bt)).then(e=>{let t=document.getElementById("chatMessages");t&&(t.innerHTML=""),e.loadMessages(),e.setStatus("idle")})},c.ws.onclose=()=>{console.log("[ws] disconnected, reconnecting in 2s..."),G("idle"),setTimeout($t,2e3)}}function Yt(e){return kn[e]||null}var kn,qe=x(()=>{"use strict";k();F();L();kn={}});qe();F();k();F();ue();L();ye();T();async function Ie(){let e=document.getElementById("chatInput"),t=document.getElementById("btnSend");if(!e||!t)return;let n=document.activeElement===t;if(t.classList.contains("stop-mode")&&n&&!e.value.trim()&&!c.attachedFiles.length){H("/api/stop","POST");return}let o=e.value.trim();if(!o&&!c.attachedFiles.length)return;let a=o.slice(1).trim().split(/\s+/)[0]||"",s=a.includes("/")||a.includes("\\");if(o.startsWith("/")&&!c.attachedFiles.length&&!s){e.value="",At(),w();try{let r,d;if(typeof AbortSignal?.timeout=="function")r=AbortSignal.timeout(1e4);else{let b=new AbortController;r=b.signal,d=setTimeout(()=>b.abort(),1e4)}let m=me(),p=await fetch("/api/command",{method:"POST",headers:{"Content-Type":"application/json","Accept-Language":m},body:JSON.stringify({text:o,locale:m}),signal:r});d&&clearTimeout(d);let g=await p.json().catch(()=>({}));if(g?.code==="not_command"){S("user",o),await y("/api/message","POST",{prompt:o});return}if(!p.ok&&!g?.text)throw new Error(`HTTP ${p.status}`);if(g?.code==="clear_screen"){let b=document.getElementById("chatMessages");b&&(b.innerHTML="")}g?.text&&v(g.text,"",g.type)}catch(r){v(l("chat.cmd.fail",{msg:r.message}),"","error")}return}if(c.attachedFiles.length){let d=`[\u{1F4CE} ${c.attachedFiles.map(m=>m.name).join(", ")}] ${o}`;S("user",d),e.value="",At();try{let p=(await Promise.all(c.attachedFiles.map(g=>fo(g)))).map(g=>l("chat.file.sent",{path:g})).join(`
102
+ `);o&&(p+=l("chat.file.sentWithMsg",{text:o})),ke(),await y("/api/message","POST",{prompt:p})}catch(m){v(l("chat.file.uploadFail",{msg:m.message})),ke()}}else{S("user",o),e.value="",At();let r=await fetch("/api/message",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({prompt:o})}),d=await r.json().catch(()=>({}));if(!r.ok){v(`\u274C ${d.error||l("chat.requestFail",{status:r.status})}`,"","error");return}if(d.queued){let{updateQueueBadge:m}=await Promise.resolve().then(()=>(F(),Bt));m(d.pending||1)}else d.continued&&v(l("chat.continue"))}}function In(e){e.key==="Enter"&&!e.shiftKey&&!e.isComposing&&(e.preventDefault(),Ie())}async function fo(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 Ht(e){for(let t of e)c.attachedFiles.some(n=>n.name===t.name)||c.attachedFiles.push(t);Pt(),document.getElementById("chatInput")?.focus()}function wn(e){c.attachedFiles.splice(e,1),Pt()}function ke(){c.attachedFiles=[],Pt();let e=document.getElementById("fileInput");e&&(e.value="")}function Pt(){let e=document.getElementById("filePreview"),t=document.getElementById("filePreviewList");if(e){if(!c.attachedFiles.length){e.classList.remove("visible"),t&&(t.innerHTML="");return}e.classList.add("visible"),t&&(t.innerHTML=c.attachedFiles.map((n,o)=>{let i=(n.size/1024).toFixed(1);return`<div class="file-chip">
102
103
  ${n.type.startsWith("image/")?`<img src="${URL.createObjectURL(n)}" class="file-chip-thumb" alt="">`:""}
103
104
  <span class="file-chip-name">\u{1F4CE} ${n.name} (${i}KB)</span>
104
105
  <button class="file-chip-remove" data-file-idx="${o}" title="Remove">\u2715</button>
105
- </div>`}).join(""))}}async function yn(){C("/api/clear","POST");let e=document.getElementById("chatMessages");e&&(e.innerHTML="")}function Qn(e){e.style.height="auto",e.style.height=e.scrollHeight+"px"}function vn(){let e=document.getElementById("chatInput");e&&e.addEventListener("input",()=>Qn(e))}function Et(){let e=document.getElementById("chatInput");e&&(e.style.height="auto")}function hn(){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&&bt(a)}),document.getElementById("fileInput")?.addEventListener("change",o=>{let i=o.target,a=[...i.files||[]];a.length&&bt(a),i.value=""}),document.addEventListener("paste",o=>{let i=o.clipboardData?.items;if(!i)return;let a=[];for(let l of i){if(l.kind!=="file")continue;let c=l.getAsFile();if(c)if(!c.name||c.name==="image.png"){let s=new Date().toISOString().replace(/[:.]/g,"-"),u=c.type.split("/")[1]||"png",p=new File([c],`pasted-${s}.${u}`,{type:c.type});a.push(p)}else a.push(c)}a.length&&(o.preventDefault(),bt(a))})}ue();se();q();O();w();S();M();A();async function bn(){let e=await v("/api/heartbeat");r.heartbeatJobs=e?.jobs||[],Se(),document.getElementById("heartbeatModal")?.classList.add("open")}function Lt(e){e&&e.target!==e.currentTarget||document.getElementById("heartbeatModal")?.classList.remove("open")}function Se(){let e=document.getElementById("hbJobsList");if(!e)return;let t=r.heartbeatJobs;t.length===0?e.innerHTML=`<p style="color:var(--text-dim);font-size:12px;text-align:center">${d("hb.empty")}</p>`:e.innerHTML=t.map((i,a)=>`
106
+ </div>`}).join(""))}}async function Cn(){H("/api/clear","POST");let e=document.getElementById("chatMessages");e&&(e.innerHTML="")}function yo(e){e.style.height="auto",e.style.height=e.scrollHeight+"px"}function Bn(){let e=document.getElementById("chatInput");e&&e.addEventListener("input",()=>yo(e))}function At(){let e=document.getElementById("chatInput");e&&(e.style.height="auto")}function $n(){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&&Ht(a)}),document.getElementById("fileInput")?.addEventListener("change",o=>{let i=o.target,a=[...i.files||[]];a.length&&Ht(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 r=s.getAsFile();if(r)if(!r.name||r.name==="image.png"){let d=new Date().toISOString().replace(/[:.]/g,"-"),m=r.type.split("/")[1]||"png",p=new File([r],`pasted-${d}.${m}`,{type:r.type});a.push(p)}else a.push(r)}a.length&&(o.preventDefault(),Ht(a))})}async function Hn(e,t,n){S("user","\u{1F3A4} [\uC74C\uC131 \uBA54\uC2DC\uC9C0]");try{let o=await fetch("/api/voice",{method:"POST",headers:{"Content-Type":n,"X-Voice-Ext":t},body:e});if(!o.ok){let a=await o.json().catch(()=>({}));throw new Error(a.error||`HTTP ${o.status}`)}let i=await o.json().catch(()=>null);i?.text&&v(`\u{1F3A4} STT (${i.engine}, ${i.elapsed?.toFixed(1)}s): "${i.text.slice(0,100)}"`,"","info")}catch(o){v(l("voice.sttFail",{msg:o.message}),"","error")}}ye();de();U();N();k();L();T();D();async function An(){let e=await f("/api/heartbeat");c.heartbeatJobs=e?.jobs||[],we(),document.getElementById("heartbeatModal")?.classList.add("open")}function Rt(e){e&&e.target!==e.currentTarget||document.getElementById("heartbeatModal")?.classList.remove("open")}function we(){let e=document.getElementById("hbJobsList");if(!e)return;let t=c.heartbeatJobs;t.length===0?e.innerHTML=`<p style="color:var(--text-dim);font-size:12px;text-align:center">${l("hb.empty")}</p>`:e.innerHTML=t.map((i,a)=>`
106
107
  <div class="hb-job-card">
107
108
  <div class="hb-job-header">
108
- <input type="text" value="${m(String(i.name||""))}" placeholder="${d("hb.name")}"
109
+ <input type="text" value="${u(String(i.name||""))}" placeholder="${l("hb.name")}"
109
110
  data-hb-name="${a}">
110
111
  <span style="font-size:11px;color:var(--text-dim)">every</span>
111
112
  <input type="number" value="${i.schedule?.minutes||5}" min="1"
@@ -115,23 +116,23 @@ var $n=Object.defineProperty;var x=(e,t)=>()=>(e&&(t=e(e=0)),t);var D=(e,t)=>{fo
115
116
  data-hb-toggle="${a}"></button>
116
117
  <button class="hb-del" data-hb-remove="${a}">\u2715</button>
117
118
  </div>
118
- <textarea class="hb-prompt" rows="2" placeholder="${d("hb.prompt")}"
119
- data-hb-prompt="${a}">${m(String(i.prompt||""))}</textarea>
119
+ <textarea class="hb-prompt" rows="2" placeholder="${l("hb.prompt")}"
120
+ data-hb-prompt="${a}">${u(String(i.prompt||""))}</textarea>
120
121
  </div>
121
- `).join("");let n=t.filter(i=>i.enabled).length,o=document.getElementById("hbSidebarBtn");o&&(o.textContent=`\u{1F493} Heartbeat (${n})`)}function En(){r.heartbeatJobs.push({id:"hb_"+Date.now(),name:"",enabled:!0,schedule:{kind:"every",minutes:5},prompt:""}),Se(),R()}function xn(e){r.heartbeatJobs.splice(e,1),Se(),R()}function Ln(e){let t=r.heartbeatJobs;t[e].enabled=!t[e].enabled,Se(),R()}async function R(){await y("/api/heartbeat","PUT",{jobs:r.heartbeatJobs})}async function Mn(){try{let t=((await v("/api/heartbeat"))?.jobs||[]).filter(o=>o.enabled).length,n=document.getElementById("hbSidebarBtn");n&&(n.textContent=`\u{1F493} Heartbeat (${t})`)}catch{}}A();M();async function ke(){let e=await v("/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 l=t("memPath");l&&(l.textContent=e.path);let c=t("memCounter");c&&(c.textContent=String(e.counter));let s=t("memThreshold");s&&(s.textContent=String(e.flushEvery)),Yn(e.files);let u=t("memorySidebarBtn");u&&(u.textContent=`\u{1F9E0} Memory (${e.files.length})`),t("memoryModal")?.classList.add("open")}function Mt(e){e&&e.target!==e.currentTarget||document.getElementById("memoryModal")?.classList.remove("open")}function St(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 kt(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 ne(){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 Yn(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=>`
122
+ `).join("");let n=t.filter(i=>i.enabled).length,o=document.getElementById("hbSidebarBtn");o&&(o.textContent=`\u{1F493} Heartbeat (${n})`)}function Pn(){c.heartbeatJobs.push({id:"hb_"+Date.now(),name:"",enabled:!0,schedule:{kind:"every",minutes:5},prompt:""}),we(),j()}function Rn(e){c.heartbeatJobs.splice(e,1),we(),j()}function Dn(e){let t=c.heartbeatJobs;t[e].enabled=!t[e].enabled,we(),j()}async function j(){await y("/api/heartbeat","PUT",{jobs:c.heartbeatJobs})}async function On(){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{}}D();T();async function Ce(){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 r=t("memCounter");r&&(r.textContent=String(e.counter));let d=t("memThreshold");d&&(d.textContent=String(e.flushEvery)),vo(e.files);let m=t("memorySidebarBtn");m&&(m.textContent=`\u{1F9E0} Memory (${e.files.length})`),t("memoryModal")?.classList.add("open")}function Dt(e){e&&e.target!==e.currentTarget||document.getElementById("memoryModal")?.classList.remove("open")}function Ot(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 Ft(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 se(){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 vo(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=>`
122
123
  <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"
123
- data-mem-view="${m(n.name)}">
124
+ data-mem-view="${u(n.name)}">
124
125
  <div>
125
- <span style="font-size:12px;font-family:monospace">${m(n.name)}</span>
126
+ <span style="font-size:12px;font-family:monospace">${u(n.name)}</span>
126
127
  <span style="font-size:10px;color:var(--accent);margin-left:6px">${n.entries} entries</span>
127
128
  </div>
128
- <button data-mem-delete="${m(n.name)}" style="background:none;border:none;color:#f55;cursor:pointer;font-size:14px">\u{1F5D1}\uFE0F</button>
129
+ <button data-mem-delete="${u(n.name)}" style="background:none;border:none;color:#f55;cursor:pointer;font-size:14px">\u{1F5D1}\uFE0F</button>
129
130
  </div>
130
- `).join("")}}async function Sn(e){confirm("Delete "+e+"?")&&(await y("/api/memory-files/"+e,"DELETE",{}),ke())}async function kn(e){let t=await v("/api/memory-files/"+e);if(!t)return;let n=document.getElementById("memFilesList");n&&(n.innerHTML=`
131
+ `).join("")}}async function Fn(e){confirm("Delete "+e+"?")&&(await y("/api/memory-files/"+e,"DELETE",{}),Ce())}async function jn(e){let t=await f("/api/memory-files/"+e);if(!t)return;let n=document.getElementById("memFilesList");n&&(n.innerHTML=`
131
132
  <div style="margin-bottom:8px;display:flex;justify-content:space-between;align-items:center">
132
133
  <span style="font-size:12px;font-weight:600">${t.name}</span>
133
134
  <button data-mem-back style="background:none;border:none;color:var(--accent);cursor:pointer;font-size:11px">\u2190 back</button>
134
135
  </div>
135
- <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>
136
- `)}w();ae();dt();var Tt="sidebarState";function Tn(){let e=JSON.parse(localStorage.getItem(Tt)||"{}");e.left&&document.body.classList.add("left-collapsed"),e.right&&document.body.classList.add("right-collapsed"),document.getElementById("toggleLeft")?.addEventListener("click",It),document.getElementById("toggleRight")?.addEventListener("click",wt),window.addEventListener("resize",()=>{if(window.innerWidth>900){document.body.classList.remove("left-expanded","right-expanded");let t=JSON.parse(localStorage.getItem(Tt)||"{}");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");Te()}),window.innerWidth<=900&&document.body.classList.remove("left-collapsed","right-collapsed"),Te()}function Ie(){return window.innerWidth<=900}function It(){Ie()?document.body.classList.toggle("left-expanded"):document.body.classList.toggle("left-collapsed"),In(),Te()}function wt(){Ie()?document.body.classList.toggle("right-expanded"):document.body.classList.toggle("right-collapsed"),In(),Te()}function Vn(){return Ie()?document.body.classList.contains("left-expanded"):!document.body.classList.contains("left-collapsed")}function Xn(){return Ie()?document.body.classList.contains("right-expanded"):!document.body.classList.contains("right-collapsed")}function Te(){let e=document.getElementById("toggleLeft"),t=document.getElementById("toggleRight");e&&(e.textContent=Vn()?"\u25C0":"\u25B6"),t&&(t.textContent=Xn()?"\u25B6":"\u25C0")}function In(){localStorage.setItem(Tt,JSON.stringify({left:document.body.classList.contains("left-collapsed"),right:document.body.classList.contains("right-collapsed")}))}var wn="theme",Zn="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.11.1/styles/github-dark.min.css",eo="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.11.1/styles/github.min.css";function Cn(){let e=localStorage.getItem(wn),t=window.matchMedia("(prefers-color-scheme: light)").matches?"light":"dark";Bn(e||t),document.getElementById("toggleTheme")?.addEventListener("click",to)}function to(){let t=(document.documentElement.getAttribute("data-theme")||"dark")==="dark"?"light":"dark";Bn(t),localStorage.setItem(wn,t)}function Bn(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"?Zn:eo)}S();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",Me);var Ct=document.getElementById("chatInput");Ct?.addEventListener("keydown",e=>{ze(e)||gn(e)});var we=0;Ct?.addEventListener("input",e=>{e.isComposing||(we&&cancelAnimationFrame(we),we=requestAnimationFrame(()=>{me(e.target?.value||""),we=0}))});Ct?.addEventListener("cmd-execute",()=>{Me()});document.getElementById("cmdDropdown")?.addEventListener("click",Ke);document.addEventListener("click",Ue);document.getElementById("filePreviewClear")?.addEventListener("click",Le);document.getElementById("filePreviewList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-file-idx]");t&&fn(+(t.dataset.fileIdx||"0"))});document.querySelector(".btn-attach")?.addEventListener("click",()=>{document.getElementById("fileInput")?.click()});document.getElementById("memorySidebarBtn")?.addEventListener("click",ke);document.getElementById("btnClearChat")?.addEventListener("click",yn);document.getElementById("hbSidebarBtn")?.addEventListener("click",bn);document.getElementById("langToggle")?.addEventListener("click",async()=>{let e=te()==="ko"?"en":"ko";await Zt(e);let t=document.getElementById("langToggle");t&&(t.textContent=`\u{1F310} ${d("lang."+e)}`),r.ws&&r.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]&&pt(i[o],t)});document.querySelector(".sidebar-save-bar .btn-save")?.addEventListener("click",gt);document.getElementById("selCli")?.addEventListener("change",()=>pe());document.getElementById("selModel")?.addEventListener("change",()=>_());document.getElementById("selEffort")?.addEventListener("change",()=>_());document.querySelector('[data-action="addEmployee"]')?.addEventListener("click",$e);document.getElementById("employeesList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-emp-delete]");if(t){He(t.dataset.empDelete||"");return}});document.getElementById("employeesList")?.addEventListener("change",e=>{let t=e.target,n=t.closest("[data-emp-name]");if(n){$(n.dataset.empName||"",{name:t.value});return}let o=t.closest("[data-emp-cli]");if(o){Ae(o.dataset.empCli||"",t.value);return}let i=t.closest("[data-emp-model]");if(i){if(t.value==="__custom__"){let c=prompt(d("model.promptInput"));if(c?.trim()){let s=document.createElement("option");s.value=c.trim(),s.textContent=c.trim();let u=t.querySelector('option[value="__custom__"]');u&&t.insertBefore(s,u),t.value=c.trim(),$(i.dataset.empModel||"",{model:c.trim()})}else t.value="default"}else $(i.dataset.empModel||"",{model:t.value});return}let a=t.closest("[data-emp-role]");if(a){Pe(a.dataset.empRole||"",t.value);return}let l=t.closest("[data-emp-custom]");if(l){$(l.dataset.empCustom||"",{role:t.value});return}});document.getElementById("skillsList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-skill-id]");t&&Oe(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";Fe(n,t)}});document.querySelector('[data-action="openPrompt"]')?.addEventListener("click",at);document.getElementById("tgOff")?.addEventListener("click",()=>fe(!1));document.getElementById("tgOn")?.addEventListener("click",()=>fe(!0));document.getElementById("tgForwardOff")?.addEventListener("click",()=>ye(!1));document.getElementById("tgForwardOn")?.addEventListener("click",()=>ye(!0));document.getElementById("tgToken")?.addEventListener("change",ge);document.getElementById("tgChatIds")?.addEventListener("change",ge);document.getElementById("fallbackOrderList")?.addEventListener("change",it);function no(){for(let e of B()){let t=e.charAt(0).toUpperCase()+e.slice(1),n=document.getElementById("model"+t);n&&n.addEventListener("change",function(){nt(e,this)});let o=document.getElementById("customModel"+t);o&&o.addEventListener("change",function(){ot(e,this)});let i=document.getElementById("effort"+t);i&&i.addEventListener("change",V)}}document.querySelector('[data-action="syncMcp"]')?.addEventListener("click",et);document.querySelector('[data-action="installMcp"]')?.addEventListener("click",tt);document.querySelector('[data-action="refreshCli"]')?.addEventListener("click",()=>ve(!0));document.getElementById("cliStatusInterval")?.addEventListener("change",function(){localStorage.setItem("cliStatusInterval",this.value)});document.getElementById("promptModal")?.addEventListener("click",e=>N(e));document.querySelector("#promptModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.querySelector('[data-action="closePrompt"]')?.addEventListener("click",()=>N());document.querySelector('[data-action="cancelPrompt"]')?.addEventListener("click",()=>N());document.querySelector('[data-action="savePrompt"]')?.addEventListener("click",st);document.addEventListener("keydown",e=>{e.key==="Escape"&&N()});document.getElementById("heartbeatModal")?.addEventListener("click",e=>Lt(e));document.querySelector("#heartbeatModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.querySelector('[data-action="closeHeartbeat"]')?.addEventListener("click",()=>Lt());document.querySelector('[data-action="addHeartbeat"]')?.addEventListener("click",En);document.getElementById("hbJobsList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-hb-toggle]");if(t){Ln(+(t.dataset.hbToggle||"0"));return}let n=e.target?.closest("[data-hb-remove]");if(n){xn(+(n.dataset.hbRemove||"0"));return}});document.getElementById("hbJobsList")?.addEventListener("change",e=>{let t=e.target,n=t.closest("[data-hb-name]");if(n){r.heartbeatJobs[+(n.dataset.hbName||"0")].name=t.value,R();return}let o=t.closest("[data-hb-minutes]");if(o){r.heartbeatJobs[+(o.dataset.hbMinutes||"0")].schedule={kind:"every",minutes:+t.value},R();return}let i=t.closest("[data-hb-prompt]");if(i){r.heartbeatJobs[+(i.dataset.hbPrompt||"0")].prompt=t.value,R();return}});document.getElementById("memoryModal")?.addEventListener("click",e=>Mt(e));document.querySelector("#memoryModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.querySelector('[data-action="closeMemory"]')?.addEventListener("click",()=>Mt());document.getElementById("memTabBtnSettings")?.addEventListener("click",()=>St("settings"));document.getElementById("memTabBtnFiles")?.addEventListener("click",()=>St("files"));document.getElementById("memOn")?.addEventListener("click",()=>kt(!0));document.getElementById("memOff")?.addEventListener("click",()=>kt(!1));document.getElementById("memFlushEvery")?.addEventListener("change",ne);document.getElementById("memCli")?.addEventListener("change",ne);document.getElementById("memModel")?.addEventListener("change",ne);document.getElementById("memRetention")?.addEventListener("change",ne);document.getElementById("memFilesList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-mem-delete]");if(t){e.stopPropagation(),Sn(t.dataset.memDelete||"");return}let n=e.target?.closest("[data-mem-view]");if(n){kn(n.dataset.memView||"");return}if(e.target?.closest("[data-mem-back]")){ke();return}});async function oo(){await Vt();let e=document.getElementById("langToggle");e&&(e.textContent=`\u{1F310} ${d("lang."+te())}`),await oe(),no(),ht(),hn(),vn(),await Je(),await Xe(),ve(),ft(),Be(),Mn(),dn(),Tn(),Cn(),yt()}oo().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",It);document.getElementById("mobileMenuRight")?.addEventListener("click",wt);
136
+ <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)">${u(t.content)}</pre>
137
+ `)}k();ce();Mt();var jt="sidebarState";function _n(){let e=JSON.parse(localStorage.getItem(jt)||"{}");e.left&&document.body.classList.add("left-collapsed"),e.right&&document.body.classList.add("right-collapsed"),document.getElementById("toggleLeft")?.addEventListener("click",_t),document.getElementById("toggleRight")?.addEventListener("click",Nt),window.addEventListener("resize",()=>{if(window.innerWidth>900){document.body.classList.remove("left-expanded","right-expanded");let t=JSON.parse(localStorage.getItem(jt)||"{}");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");Be()}),window.innerWidth<=900&&document.body.classList.remove("left-collapsed","right-collapsed"),Be()}function $e(){return window.innerWidth<=900}function _t(){$e()?document.body.classList.toggle("left-expanded"):document.body.classList.toggle("left-collapsed"),Nn(),Be()}function Nt(){$e()?document.body.classList.toggle("right-expanded"):document.body.classList.toggle("right-collapsed"),Nn(),Be()}function ho(){return $e()?document.body.classList.contains("left-expanded"):!document.body.classList.contains("left-collapsed")}function bo(){return $e()?document.body.classList.contains("right-expanded"):!document.body.classList.contains("right-collapsed")}function Be(){let e=document.getElementById("toggleLeft"),t=document.getElementById("toggleRight");e&&(e.textContent=ho()?"\u25C0":"\u25B6"),t&&(t.textContent=bo()?"\u25B6":"\u25C0")}function Nn(){localStorage.setItem(jt,JSON.stringify({left:document.body.classList.contains("left-collapsed"),right:document.body.classList.contains("right-collapsed")}))}var qn="theme",Eo="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.11.1/styles/github-dark.min.css",xo="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.11.1/styles/github.min.css";function zn(){let e=localStorage.getItem(qn),t=window.matchMedia("(prefers-color-scheme: light)").matches?"light":"dark";Jn(e||t),document.getElementById("toggleTheme")?.addEventListener("click",Lo)}function Lo(){let t=(document.documentElement.getAttribute("data-theme")||"dark")==="dark"?"light":"dark";Jn(t),localStorage.setItem(qn,t)}function Jn(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"?Eo:xo)}L();k();F();L();var $=null,He=[],Pe=null,Ae=null,Kn=0;function Mo(){if(typeof MediaRecorder>"u")return"";let e=["audio/webm;codecs=opus","audio/mp4","audio/ogg;codecs=opus"];for(let t of e)if(MediaRecorder.isTypeSupported(t))return t;return""}function To(e){let t=e;switch(t.name){case"NotAllowedError":return l("voice.micDenied");case"NotFoundError":return l("voice.micNotFound");case"NotReadableError":case"AbortError":return l("voice.micBusy");default:return t instanceof TypeError||!navigator.mediaDevices?l("voice.httpsRequired"):l("voice.micDenied")}}async function So(){if(c.isRecording)return;if(typeof MediaRecorder>"u"||!navigator.mediaDevices?.getUserMedia){v(l("voice.unsupported"),"","error");return}try{Pe=await navigator.mediaDevices.getUserMedia({audio:!0})}catch(n){v(To(n),"","error");return}let e=Mo(),t=e?{mimeType:e}:{};$=new MediaRecorder(Pe,t),He=[],$.ondataavailable=n=>{n.data.size>0&&He.push(n.data)},$.onerror=()=>{Un(),v(l("voice.interrupted"),"","error")},$.onstop=async()=>{let n=$?.mimeType||e||"audio/webm",o=n.includes("mp4")?".m4a":n.includes("ogg")?".ogg":".webm",i=new Blob(He,{type:n});if(He=[],ko(),i.size>20*1024*1024){v(l("voice.tooLarge"),"","error");return}if(i.size<1e3){v(l("voice.tooShort"),"","error");return}await Hn(i,o,n)},$.start(),c.isRecording=!0,Kn=Date.now(),Gn(!0),Io()}function Un(){!c.isRecording||!$||($.state==="recording"&&$.stop(),c.isRecording=!1,wo(),Gn(!1))}function Wn(){c.isRecording?Un():So()}function ko(){Pe?.getTracks().forEach(e=>e.stop()),Pe=null}function Io(){let e=document.getElementById("voiceTimer");e&&(e.style.display="inline",Ae=setInterval(()=>{let t=Math.floor((Date.now()-Kn)/1e3),n=String(Math.floor(t/60)).padStart(2,"0"),o=String(t%60).padStart(2,"0");e.textContent=`${n}:${o}`},500))}function wo(){Ae&&(clearInterval(Ae),Ae=null);let e=document.getElementById("voiceTimer");e&&(e.style.display="none",e.textContent="00:00")}function Gn(e){let t=document.getElementById("btnVoice");t&&(t.classList.toggle("recording",e),t.textContent=e?"\u23F9":"\u{1F3A4}",t.title=e?l("voice.stop"):l("voice.start"))}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",Ie);var qt=document.getElementById("chatInput");qt?.addEventListener("keydown",e=>{Ye(e)||In(e)});var Re=0;qt?.addEventListener("input",e=>{e.isComposing||(Re&&cancelAnimationFrame(Re),Re=requestAnimationFrame(()=>{fe(e.target?.value||""),Re=0}))});qt?.addEventListener("cmd-execute",()=>{Ie()});document.getElementById("cmdDropdown")?.addEventListener("click",Xe);document.addEventListener("click",Ze);document.getElementById("filePreviewClear")?.addEventListener("click",ke);document.getElementById("filePreviewList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-file-idx]");t&&wn(+(t.dataset.fileIdx||"0"))});document.querySelector(".btn-attach")?.addEventListener("click",()=>{document.getElementById("fileInput")?.click()});document.getElementById("btnVoice")?.addEventListener("click",()=>Wn());document.getElementById("memorySidebarBtn")?.addEventListener("click",Ce);document.getElementById("btnClearChat")?.addEventListener("click",Cn);document.getElementById("hbSidebarBtn")?.addEventListener("click",An);document.getElementById("langToggle")?.addEventListener("click",async()=>{let e=ae()==="ko"?"en":"ko";await pn(e);let t=document.getElementById("langToggle");t&&(t.textContent=`\u{1F310} ${l("lang."+e)}`),c.ws&&c.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]&&kt(i[o],t)});document.querySelector(".sidebar-save-bar .btn-save")?.addEventListener("click",It);document.getElementById("selCli")?.addEventListener("change",()=>ve());document.getElementById("selModel")?.addEventListener("change",()=>J());document.getElementById("selEffort")?.addEventListener("change",()=>J());document.querySelector('[data-action="addEmployee"]')?.addEventListener("click",Fe);document.getElementById("employeesList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-emp-delete]");if(t){je(t.dataset.empDelete||"");return}});document.getElementById("employeesList")?.addEventListener("change",e=>{let t=e.target,n=t.closest("[data-emp-name]");if(n){P(n.dataset.empName||"",{name:t.value});return}let o=t.closest("[data-emp-cli]");if(o){_e(o.dataset.empCli||"",t.value);return}let i=t.closest("[data-emp-model]");if(i){if(t.value==="__custom__"){let r=prompt(l("model.promptInput"));if(r?.trim()){let d=document.createElement("option");d.value=r.trim(),d.textContent=r.trim();let m=t.querySelector('option[value="__custom__"]');m&&t.insertBefore(d,m),t.value=r.trim(),P(i.dataset.empModel||"",{model:r.trim()})}else t.value="default"}else P(i.dataset.empModel||"",{model:t.value});return}let a=t.closest("[data-emp-role]");if(a){Ne(a.dataset.empRole||"",t.value);return}let s=t.closest("[data-emp-custom]");if(s){P(s.dataset.empCustom||"",{role:t.value});return}});document.getElementById("skillsList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-skill-id]");t&&Je(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";Ke(n,t)}});document.querySelector('[data-action="openPrompt"]')?.addEventListener("click",ut);document.getElementById("tgOff")?.addEventListener("click",()=>be(!1));document.getElementById("tgOn")?.addEventListener("click",()=>be(!0));document.getElementById("tgForwardOff")?.addEventListener("click",()=>Ee(!1));document.getElementById("tgForwardOn")?.addEventListener("click",()=>Ee(!0));document.getElementById("tgToken")?.addEventListener("change",he);document.getElementById("tgChatIds")?.addEventListener("change",he);document.getElementById("fallbackOrderList")?.addEventListener("change",mt);function Co(){for(let e of A()){let t=e.charAt(0).toUpperCase()+e.slice(1),n=document.getElementById("model"+t);n&&n.addEventListener("change",function(){ct(e,this)});let o=document.getElementById("customModel"+t);o&&o.addEventListener("change",function(){dt(e,this)});let i=document.getElementById("effort"+t);i&&i.addEventListener("change",ee)}}document.querySelector('[data-action="syncMcp"]')?.addEventListener("click",rt);document.querySelector('[data-action="installMcp"]')?.addEventListener("click",lt);document.querySelector('[data-action="refreshCli"]')?.addEventListener("click",()=>te(!0));document.getElementById("cliStatusInterval")?.addEventListener("change",function(){localStorage.setItem("cliStatusInterval",this.value)});document.getElementById("promptModal")?.addEventListener("click",e=>K(e));document.querySelector("#promptModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.querySelector('[data-action="closePrompt"]')?.addEventListener("click",()=>K());document.querySelector('[data-action="cancelPrompt"]')?.addEventListener("click",()=>K());document.querySelector('[data-action="savePrompt"]')?.addEventListener("click",pt);document.addEventListener("keydown",e=>{e.key==="Escape"&&K()});document.querySelector('[data-action="openTemplates"]')?.addEventListener("click",ft);document.querySelector('[data-action="saveTemplate"]')?.addEventListener("click",vt);document.querySelector('[data-action="closeTemplate"]')?.addEventListener("click",()=>xe());document.getElementById("templateModal")?.addEventListener("click",e=>xe(e));document.querySelector("#templateModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.getElementById("templateBack")?.addEventListener("click",bt);document.getElementById("templateDevToggle")?.addEventListener("click",yt);document.getElementById("heartbeatModal")?.addEventListener("click",e=>Rt(e));document.querySelector("#heartbeatModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.querySelector('[data-action="closeHeartbeat"]')?.addEventListener("click",()=>Rt());document.querySelector('[data-action="addHeartbeat"]')?.addEventListener("click",Pn);document.getElementById("hbJobsList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-hb-toggle]");if(t){Dn(+(t.dataset.hbToggle||"0"));return}let n=e.target?.closest("[data-hb-remove]");if(n){Rn(+(n.dataset.hbRemove||"0"));return}});document.getElementById("hbJobsList")?.addEventListener("change",e=>{let t=e.target,n=t.closest("[data-hb-name]");if(n){c.heartbeatJobs[+(n.dataset.hbName||"0")].name=t.value,j();return}let o=t.closest("[data-hb-minutes]");if(o){c.heartbeatJobs[+(o.dataset.hbMinutes||"0")].schedule={kind:"every",minutes:+t.value},j();return}let i=t.closest("[data-hb-prompt]");if(i){c.heartbeatJobs[+(i.dataset.hbPrompt||"0")].prompt=t.value,j();return}});document.getElementById("memoryModal")?.addEventListener("click",e=>Dt(e));document.querySelector("#memoryModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.querySelector('[data-action="closeMemory"]')?.addEventListener("click",()=>Dt());document.getElementById("memTabBtnSettings")?.addEventListener("click",()=>Ot("settings"));document.getElementById("memTabBtnFiles")?.addEventListener("click",()=>Ot("files"));document.getElementById("memOn")?.addEventListener("click",()=>Ft(!0));document.getElementById("memOff")?.addEventListener("click",()=>Ft(!1));document.getElementById("memFlushEvery")?.addEventListener("change",se);document.getElementById("memCli")?.addEventListener("change",se);document.getElementById("memModel")?.addEventListener("change",se);document.getElementById("memRetention")?.addEventListener("change",se);document.getElementById("memFilesList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-mem-delete]");if(t){e.stopPropagation(),Fn(t.dataset.memDelete||"");return}let n=e.target?.closest("[data-mem-view]");if(n){jn(n.dataset.memView||"");return}if(e.target?.closest("[data-mem-back]")){Ce();return}});async function Bo(){await mn();let e=document.getElementById("langToggle");e&&(e.textContent=`\u{1F310} ${l("lang."+ae())}`),await re(),Co(),$t(),$n(),Bn(),await Qe(),await at(),te(),wt(),Oe(),On(),Mn(),_n(),zn(),Ct()}Bo().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",_t);document.getElementById("mobileMenuRight")?.addEventListener("click",Nt);
137
138
  //# sourceMappingURL=bundle.js.map