cli-jaw 1.3.3 → 1.3.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/server.js +22 -4
- package/dist/server.js.map +1 -1
- package/dist/src/cli/registry.js +1 -1
- package/dist/src/cli/registry.js.map +1 -1
- package/dist/src/core/codex-config.js +66 -0
- package/dist/src/core/codex-config.js.map +1 -0
- package/package.json +1 -1
- package/public/dist/bundle.js +41 -41
- package/public/dist/bundle.js.map +3 -3
- package/public/index.html +28 -7
- package/public/js/constants.ts +1 -1
- package/public/js/features/settings.ts +20 -1
- package/public/js/main.ts +17 -0
package/public/dist/bundle.js
CHANGED
|
@@ -1,42 +1,42 @@
|
|
|
1
|
-
var
|
|
1
|
+
var ro=Object.defineProperty;var L=(e,t)=>()=>(e&&(t=e(e=0)),t);var K=(e,t)=>{for(var n in t)ro(e,n,{get:t[n],enumerable:!0})};var d,B=L(()=>{"use strict";d={ws:null,agentBusy:!1,employees:[],allSkills:[],currentSkillFilter:"all",currentAgentDiv:null,attachedFiles:[],heartbeatJobs:[],cliStatusCache:null,cliStatusTs:0,orcState:"IDLE",isRecording:!1}});var Zt={};K(Zt,{api:()=>h,apiFire:()=>R,apiJson:()=>v});async function h(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 v(e,t,n){return h(e,{method:t,headers:{"Content-Type":"application/json"},body:JSON.stringify(n)})}function R(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 k=L(()=>{"use strict"});function nn(e){let t={};for(let[n,o]of Object.entries(e))t[n]=Array.isArray(o?.models)?[...o.models]:[];return t}function on(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 en(e){let t=on(e);return Object.keys(t).length?(ee=t,an=Object.keys(t),F=nn(t),!0):!1}async function fe(){try{let e=await h("/api/cli-registry");if(!e||!en(e))throw new Error("invalid registry")}catch(e){console.warn("[cli-registry] fallback:",e.message),en(tn)}return ee}function O(){return an}function ye(e){return ee[e]||null}var tn,ee,an,F,te,ve=L(()=>{"use strict";k();tn={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.4","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.4-xhigh","openai/gpt-5.4-high","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.4","gpt-5.3-codex","gpt-5.2-codex","gpt-5.1-codex","gpt-4.1","gpt-5-mini","gemini-3-pro-preview"]}};ee=on(tn),an=Object.keys(ee),F=nn(ee);te=[{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 ne={};K(ne,{addEmployee:()=>Ke,deleteEmployee:()=>Je,loadEmployees:()=>ze,onEmpCliChange:()=>Ue,onEmpRoleChange:()=>We,renderEmployees:()=>sn,updateEmployee:()=>D});async function ze(){let e=await h("/api/employees");d.employees=e||[],sn()}function sn(){let e=document.getElementById("employeesList");if(!e)return;let t=d.employees;if(t.length===0){e.innerHTML=`<div style="color:var(--text-dim);font-size:11px;padding:4px 0">${m("emp.addPrompt")}</div>`;return}let n=O();e.innerHTML=t.map(o=>{let i=F[o.cli]||[],a=co[o.role||""],s=a?te.find(y=>y.value===a):te.find(y=>y.prompt===o.role),l=s?s.value:o.role?"custom":"frontend",c=l==="custom",r=ln(o.id),u=r?.phase||o.phase,g=r?.phaseLabel||o.phaseLabel,f=u?`<span style="background:${mo[u]||"#888"};color:#000;padding:1px 6px;border-radius:9px;font-size:9px">${g||"P"+u}</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
6
|
value="${p(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="${
|
|
8
|
+
<button style="background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:12px" data-emp-delete="${o.id}" title="${m("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(
|
|
14
|
+
${n.map(y=>`<option${o.cli===y?" selected":""}>${y}</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(
|
|
21
|
+
${i.map(y=>`<option${o.model===y?" selected":""}>${y}</option>`).join("")}
|
|
22
22
|
${o.model&&o.model!=="default"&&!i.includes(o.model)?`<option selected>${o.model}</option>`:""}
|
|
23
|
-
<option value="__custom__">${
|
|
23
|
+
<option value="__custom__">${m("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
|
-
${te.map(
|
|
30
|
+
${te.map(y=>`<option value="${y.value}"${l===y.value?" selected":""}>${y.label}</option>`).join("")}
|
|
31
31
|
</select>
|
|
32
|
-
<textarea data-emp-custom="${o.id}" style="display:${
|
|
33
|
-
placeholder="${
|
|
32
|
+
<textarea data-emp-custom="${o.id}" style="display:${c?"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="${m("emp.customRole")}">${c?p(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
37
|
${f}
|
|
38
38
|
</div>
|
|
39
|
-
</div>`}).join("")}async function
|
|
39
|
+
</div>`}).join("")}async function Ke(){await v("/api/employees","POST",{})}async function D(e,t){await v(`/api/employees/${e}`,"PUT",t)}async function Je(e){R(`/api/employees/${e}`,"DELETE")}function Ue(e,t){let n=F[t]||[],o=document.querySelector(`[data-emp-model="${e}"]`);o&&(o.innerHTML='<option value="default" selected>default</option>'+n.map(i=>`<option>${p(i)}</option>`).join("")+`<option value="__custom__">${m("emp.customModel")}</option>`),D(e,{cli:t,model:"default"})}function We(e,t){let n=te.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="",D(e,{role:n?.prompt||""})))}var co,mo,J=L(()=>{"use strict";B();ve();_();Ve();T();k();co={"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"},mo={1:"#60a5fa",2:"#a78bfa",3:"#34d399",4:"#fbbf24",5:"#f472b6"}});var Xe={};K(Xe,{filterSkills:()=>Ye,loadSkills:()=>rn,renderSkills:()=>Ge,toggleSkill:()=>Qe});async function rn(){try{let e=await cn("/api/skills");d.allSkills=await e.json(),Ge()}catch{let e=document.getElementById("skillsList");e&&(e.innerHTML=`<div style="color:var(--text-dim);font-size:11px">${m("skill.loadFail")}</div>`)}}function Ge(){let e=document.getElementById("skillsList"),t=document.getElementById("skillsCount");if(!e||!t)return;let n=d.allSkills,o=n;d.currentSkillFilter==="installed"?o=n.filter(a=>a.enabled):d.currentSkillFilter==="other"?o=n.filter(a=>!uo.includes(a.category||"")):d.currentSkillFilter!=="all"&&(o=n.filter(a=>a.category===d.currentSkillFilter));let i=n.filter(a=>a.enabled).length;t.textContent=m("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
42
|
<span class="skill-emoji">${p(a.emoji||"\u{1F527}")}</span>
|
|
@@ -46,11 +46,11 @@ var lo=Object.defineProperty;var x=(e,t)=>()=>(e&&(t=e(e=0)),t);var q=(e,t)=>{fo
|
|
|
46
46
|
</div>
|
|
47
47
|
<div class="skill-desc">${p(a.description||"")}</div>
|
|
48
48
|
${s.length?`<div class="skill-req">${s.join(" \xB7 ")}</div>`:""}
|
|
49
|
-
</div>`}).join("")}async function Qe(e,t){let n=t?"/api/skills/disable":"/api/skills/enable";try{await
|
|
49
|
+
</div>`}).join("")}async function Qe(e,t){let n=t?"/api/skills/disable":"/api/skills/enable";try{await v(n,"POST",{id:e}),await rn()}catch(o){console.error("toggleSkill error:",o)}}function Ye(e,t){d.currentSkillFilter=e,document.querySelectorAll(".skill-filter").forEach(n=>n.classList.remove("active")),t&&t.classList.add("active"),Ge()}var uo,he=L(()=>{"use strict";B();T();k();_();uo=["productivity","communication","devtools","ai-media","utility","smarthome","automation"]});function Ee(){try{for(let e of dn){let t=localStorage.getItem(e);if(t)return t}}catch{}return navigator.language||"ko"}function mn(e){let t=String(e||"").trim();if(t)try{for(let n of dn)localStorage.setItem(n,t)}catch{}}var dn,be=L(()=>{"use strict";dn=["claw_locale","claw.locale"]});var st={};K(st,{close:()=>$,handleClick:()=>it,handleKeydown:()=>ot,handleOutsideClick:()=>at,isDropdownOpen:()=>go,loadCommands:()=>nt,update:()=>Me});function pn(e){let n=String(e||"").slice(1).trim().split(/\s+/)[0]||"";return n.includes("/")||n.includes("\\")}function Ze(e){return String(e||"").replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,""")}function po(e){let t=String(e||"").toLowerCase();return et.filter(n=>`/${n.name}`.startsWith(t))}function un(){let e=Le(),t=W();!e||!t||(j&&(clearTimeout(j),j=null),e.style.display="block",requestAnimationFrame(()=>e.classList.add("visible")),U=!0,t.setAttribute("aria-expanded","true"))}function xe(){let e=Le(),t=W();if(!e||!t)return;if(!C.length){if(!t.value.startsWith("/")||pn(t.value)){$();return}e.innerHTML=`
|
|
50
50
|
<div class="cmd-item cmd-empty" role="option" aria-disabled="true">
|
|
51
|
-
${
|
|
51
|
+
${m("cmd.noMatch")}
|
|
52
52
|
</div>
|
|
53
|
-
`,un(),t.setAttribute("aria-activedescendant","");return}e.innerHTML=C.map((o,i)=>{let a=i===
|
|
53
|
+
`,un(),t.setAttribute("aria-activedescendant","");return}e.innerHTML=C.map((o,i)=>{let a=i===I;return`<div class="cmd-item${a?" selected":""}"
|
|
54
54
|
role="option"
|
|
55
55
|
id="cmd-item-${i}"
|
|
56
56
|
aria-selected="${a}"
|
|
@@ -58,57 +58,57 @@ var lo=Object.defineProperty;var x=(e,t)=>()=>(e&&(t=e(e=0)),t);var q=(e,t)=>{fo
|
|
|
58
58
|
<span class="cmd-name">/${Ze(o.name)}</span>
|
|
59
59
|
<span class="cmd-desc">${Ze(o.desc)}</span>
|
|
60
60
|
${o.args?`<span class="cmd-args">${Ze(o.args)}</span>`:""}
|
|
61
|
-
</div>`}).join(""),un(),t.setAttribute("aria-activedescendant",
|
|
62
|
-
`)||pn(t)){$();return}C=uo(t),T=C.length?0:-1,xe()}function ot(e){return z?C.length?e.key==="ArrowDown"?(e.preventDefault(),T=Math.min(C.length-1,T+1),xe(),!0):e.key==="ArrowUp"?(e.preventDefault(),T=Math.max(0,T-1),xe(),!0):e.key==="Tab"?(e.preventDefault(),tt(!1),!0):e.key==="Enter"&&!e.shiftKey&&!e.isComposing?(e.preventDefault(),tt(!0),!0):e.key==="Escape"?(e.preventDefault(),$(),!0):!1:e.key==="Escape"?(e.preventDefault(),$(),!0):!1:(e.key==="ArrowDown"||e.key==="ArrowUp")&&!e.isComposing?(Me(J()?.value||""),z?(T=e.key==="ArrowUp"?C.length-1:0,xe(),e.preventDefault(),!0):!1):!1}function it(e){let n=e.target.closest(".cmd-item");if(!n)return;let o=parseInt(n.dataset.index||"-1",10);Number.isNaN(o)||o<0||(T=Math.min(o,C.length-1),tt(!0))}function at(e){if(!z)return;let t=Le(),n=J();if(!t||!n)return;let o=e.target;!t.contains(o)&&o!==n&&$()}function po(){return z}var et,C,T,z,F,Le,J,Te=x(()=>{"use strict";Ee();M();k();et=[],C=[],T=-1,z=!1,F=null;Le=()=>document.getElementById("cmdDropdown"),J=()=>document.getElementById("chatInput")});var se={};q(se,{applyCustomModel:()=>yt,closePromptModal:()=>G,closeTemplateModal:()=>Be,getModelValue:()=>hn,handleModelSelect:()=>ft,installMcpGlobal:()=>gt,loadCliStatus:()=>ae,loadFallbackOrder:()=>bn,loadMcpServers:()=>ut,loadSettings:()=>mt,onCliChange:()=>Se,openPromptModal:()=>ht,openTemplateModal:()=>xt,saveActiveCliSettings:()=>U,saveFallbackOrder:()=>vt,savePerCli:()=>W,savePromptFromModal:()=>bt,saveTelegramSettings:()=>Ie,saveTemplateFromModal:()=>Mt,setForwardAll:()=>we,setPerm:()=>vn,setTelegram:()=>ke,syncMcpServers:()=>pt,templateGoBack:()=>St,toggleDevMode:()=>Lt,updateSettings:()=>rt});function ct(e){return e.charAt(0).toUpperCase()+e.slice(1)}function ie(e){return document.getElementById("model"+ct(e))}function fn(e){return document.getElementById("customModel"+ct(e))}function dt(e){return document.getElementById("effort"+ct(e))}function yn(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__">${d("model.customOption")}</option>`:"",l=(t||[]).map(m=>`<option value="${p(m)}">${p(m)}</option>`).join("");e.innerHTML=a+l+s,i&&Array.from(e.options).some(m=>m.value===i)&&(e.value=i)}function oe(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 go(e=null){let t=P(),n=document.getElementById("selCli");if(n){let i=e?.cli||n.value||t[0]||"claude";n.innerHTML=t.map(a=>{let s=ye(a)?.label||a;return`<option value="${p(a)}">${p(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="${p(a)}">${p(a)}</option>`).join(""),Array.from(o.options).some(a=>a.value===i)&&(o.value=i)}}function fo(e=null){for(let t of P()){let n=ie(t);if(n){let i=e?.perCli?.[t]?.model||n.value||"";yn(n,O[t]||[],{includeCustom:!0,selected:i}),i&&!Array.from(n.options).some(a=>a.value===i)&&(oe(n,i),n.value=i)}let o=dt(t);if(o){let i=ye(t),a=[""].concat(i?.efforts||[]),s=e?.perCli?.[t]?.effort||o.value||"",l=[...new Set(a)],m=i?.efforts?.length===0&&i?.effortNote?i.effortNote:"\u2014 none";o.innerHTML=l.map(r=>r?`<option value="${p(r)}">${p(r)}</option>`:`<option value="">${p(m)}</option>`).join(""),i?.effortNote&&(o.title=i.effortNote),o.disabled=i?.efforts?.length===0&&!!i?.effortNote,Array.from(o.options).some(r=>r.value===s)&&(o.value=s)}}}function lt(e,t=""){let n=document.getElementById("selEffort");if(!n)return;let o=ye(e);if(o?.effortNote){n.innerHTML=`<option value="">${p(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="${p(s)}">${p(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 mt(){await fe();let e=await v("/api/settings");if(!e)return;mn(e.locale??""),go(e),fo(e);let t=document.getElementById("selCli");t&&Array.from(t.options).some(r=>r.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),vn(e.permissions,!1),e.perCli)for(let[r,u]of Object.entries(e.perCli)){let g=ie(r),f=dt(r);g&&u.model&&(oe(g,u.model),g.value=u.model),f&&(f.value=u.effort||""),r==="codex"&&u.fastMode!==void 0&&(document.getElementById("codexFastOn")?.classList.toggle("active",u.fastMode),document.getElementById("codexFastOff")?.classList.toggle("active",!u.fastMode))}Se(!1);let i=e.activeOverrides?.[e.cli]||{},a=e.perCli?.[e.cli]||{},s=i.model||a.model,l=i.effort||a.effort||"",m=document.getElementById("selModel");s&&m&&(m.value=s),lt(e.cli,l),vo(e),bn(e),ut(),yo(e.stt||{})}function yo(e){let t=document.getElementById("sttEngine"),n=document.getElementById("sttGeminiKey"),o=document.getElementById("sttGeminiModel"),i=document.getElementById("sttGeminiModelCustom"),a=document.getElementById("sttWhisperModel"),s=document.getElementById("sttOpenaiBaseUrl"),l=document.getElementById("sttOpenaiKey"),m=document.getElementById("sttOpenaiModel"),r=document.getElementById("sttVertexJson");if(t&&(t.value=e.engine||"auto"),n&&(n.placeholder=e.geminiKeySet?`\u2705 \uC785\uB825\uB428 \xB7\xB7\xB7\xB7${e.geminiKeyLast4||""}`:"AIza..."),o){let f=e.geminiModel||"gemini-2.5-flash-lite";Array.from(o.options).some(E=>E.value===f)?o.value=f:(o.value="__custom__",i&&(i.value=f,i.style.display=""))}a&&(a.value=e.whisperModel||"mlx-community/whisper-large-v3-turbo"),s&&(s.value=e.openaiBaseUrl||""),l&&(l.placeholder=e.openaiKeySet?`\u2705 \uC785\uB825\uB428 \xB7\xB7\xB7\xB7${e.openaiKeyLast4||""}`:"sk-..."),m&&(m.value=e.openaiModel||""),r&&(r.value=e.vertexConfig||"");function u(){let f=t?.value||"auto",h=f==="auto"||f==="gemini",E=f==="openai",I=f==="vertex",X=f==="auto"||f==="whisper";document.querySelectorAll(".stt-gemini").forEach(L=>L.style.display=h?"":"none"),document.querySelectorAll(".stt-openai").forEach(L=>L.style.display=E?"":"none"),document.querySelectorAll(".stt-vertex").forEach(L=>L.style.display=I?"":"none"),document.querySelectorAll(".stt-whisper").forEach(L=>L.style.display=X?"":"none")}u();async function g(){let f={stt:{engine:t?.value||"auto",geminiModel:(o?.value==="__custom__"?i?.value:o?.value)||"gemini-2.5-flash-lite",whisperModel:a?.value||"",openaiBaseUrl:s?.value||"",openaiModel:m?.value||"",vertexConfig:r?.value||""}};n?.value&&(f.stt.geminiApiKey=n.value),l?.value&&(f.stt.openaiApiKey=l.value),console.log("[stt] saving:",{engine:f.stt.engine,hasGeminiKey:!!f.stt.geminiApiKey,hasOpenaiKey:!!f.stt.openaiApiKey});try{if(await y("/api/settings","PUT",f),n?.value){let h=n.value.slice(-4);n.value="",n.placeholder=`\u2705 \uC785\uB825\uB428 \xB7\xB7\xB7\xB7${h}`}if(l?.value){let h=l.value.slice(-4);l.value="",l.placeholder=`\u2705 \uC785\uB825\uB428 \xB7\xB7\xB7\xB7${h}`}}catch(h){console.error("[stt] save failed:",h)}}t?.addEventListener("change",()=>{u(),g()}),o?.addEventListener("change",()=>{i&&(i.style.display=o.value==="__custom__"?"":"none"),o.value!=="__custom__"&&g()}),i?.addEventListener("blur",g),n?.addEventListener("blur",()=>{n.value&&g()}),l?.addEventListener("blur",()=>{l.value&&g()}),s?.addEventListener("blur",g),m?.addEventListener("blur",g),a?.addEventListener("blur",g),r?.addEventListener("blur",g)}async function ut(){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 pt(){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(" ")}catch(t){e.textContent="\u274C "+t.message}}}async function gt(){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>"),ut()}catch(t){e.textContent="\u274C "+t.message}}}async function rt(){let e={cli:document.getElementById("selCli")?.value||"claude"},t=document.getElementById("headerCli");t&&(t.textContent=e.cli),await y("/api/settings","PUT",e)}function vn(e,t=!0){t&&A("/api/settings","PUT",{permissions:"auto"})}function hn(e){let t=ie(e);return t?t.value==="__custom__"?fn(e)?.value?.trim()||t.options[0]?.value||"default":t.value:"default"}function ft(e,t){let n=fn(e);n&&(t.value==="__custom__"?(n.style.display="block",n.focus()):(n.style.display="none",W()))}function yt(e,t){let n=t.value.trim();if(!n)return;let o=ie(e);o&&(oe(o,n),o.value=n,t.style.display="none",W())}async function W(){let e={};for(let t of P()){if(!ie(t))continue;let o=dt(t),i={model:hn(t),effort:o?o.value:""};if(t==="codex"){let a=document.getElementById("codexFastOn");i.fastMode=a?.classList.contains("active")??!1}e[t]=i}await y("/api/settings","PUT",{perCli:e})}function Se(e=!0){let t=document.getElementById("selCli")?.value||"claude",n=O[t]||[],o=document.getElementById("selModel");yn(o,n,{includeCustom:!0,includeDefault:!0});let i=document.getElementById("headerCli");i&&(i.textContent=t),lt(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=d("model.placeholder"),s.style.display="none",s.onchange=function(){let l=this.value.trim();!l||!o||(oe(o,l),o.value=l,this.style.display="none",U())},!o){e&&rt();return}o.parentElement?.appendChild(s),o.onchange=function(){this.value==="__custom__"?(s.style.display="block",s.focus()):(s.style.display="none",U())},v("/api/settings").then(l=>{if(!l)return;let m=l.activeOverrides?.[t]||{},r=l.perCli?.[t]||{},u=m.model||r.model,g=m.effort||r.effort||"";u&&o&&(oe(o,u),o.value=u),lt(t,g)}),e&&rt()}async function U(){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 Ie(){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 ke(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 we(e){document.getElementById("tgForwardOn")?.classList.toggle("active",e),document.getElementById("tgForwardOff")?.classList.toggle("active",!e),await y("/api/settings","PUT",{telegram:{forwardAll:e}})}function vo(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 bn(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 l=o[s]||"",m=n.map(r=>`<option value="${r}" ${r===l?"selected":""}>${r}</option>`).join("");a+=`
|
|
61
|
+
</div>`}).join(""),un(),t.setAttribute("aria-activedescendant",I>=0?`cmd-item-${I}`:"");let n=e.querySelector(".selected");n&&n.scrollIntoView({block:"nearest"})}function tt(e){let t=C[I],n=W();if(!t||!n){$();return}if($(),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 nt(){try{let e=Ee(),t=`/api/commands?interface=web&locale=${encodeURIComponent(e)}`;et=await h(t,{headers:{"Accept-Language":e}})||[]}catch(e){console.warn("[slash-commands] loadCommands failed:",e.message),et=[]}}function $(){let e=Le();j&&(clearTimeout(j),j=null),e&&(e.classList.remove("visible"),j=setTimeout(()=>{e.classList.contains("visible")||(e.style.display="none",e.innerHTML="")},150)),U=!1,I=-1,C=[];let t=W();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
|
+
`)||pn(t)){$();return}C=po(t),I=C.length?0:-1,xe()}function ot(e){return U?C.length?e.key==="ArrowDown"?(e.preventDefault(),I=Math.min(C.length-1,I+1),xe(),!0):e.key==="ArrowUp"?(e.preventDefault(),I=Math.max(0,I-1),xe(),!0):e.key==="Tab"?(e.preventDefault(),tt(!1),!0):e.key==="Enter"&&!e.shiftKey&&!e.isComposing?(e.preventDefault(),tt(!0),!0):e.key==="Escape"?(e.preventDefault(),$(),!0):!1:e.key==="Escape"?(e.preventDefault(),$(),!0):!1:(e.key==="ArrowDown"||e.key==="ArrowUp")&&!e.isComposing?(Me(W()?.value||""),U?(I=e.key==="ArrowUp"?C.length-1:0,xe(),e.preventDefault(),!0):!1):!1}function it(e){let n=e.target.closest(".cmd-item");if(!n)return;let o=parseInt(n.dataset.index||"-1",10);Number.isNaN(o)||o<0||(I=Math.min(o,C.length-1),tt(!0))}function at(e){if(!U)return;let t=Le(),n=W();if(!t||!n)return;let o=e.target;!t.contains(o)&&o!==n&&$()}function go(){return U}var et,C,I,U,j,Le,W,Te=L(()=>{"use strict";be();T();k();et=[],C=[],I=-1,U=!1,j=null;Le=()=>document.getElementById("cmdDropdown"),W=()=>document.getElementById("chatInput")});var se={};K(se,{applyCustomModel:()=>yt,closePromptModal:()=>G,closeTemplateModal:()=>Be,getModelValue:()=>hn,handleModelSelect:()=>ft,installMcpGlobal:()=>gt,loadCliStatus:()=>ae,loadFallbackOrder:()=>En,loadMcpServers:()=>ut,loadSettings:()=>mt,onCliChange:()=>Ie,openPromptModal:()=>ht,openTemplateModal:()=>xt,saveActiveCliSettings:()=>V,saveFallbackOrder:()=>vt,savePerCli:()=>A,savePromptFromModal:()=>Et,saveTelegramSettings:()=>Se,saveTemplateFromModal:()=>Mt,setForwardAll:()=>we,setPerm:()=>vn,setTelegram:()=>ke,syncMcpServers:()=>pt,templateGoBack:()=>It,toggleDevMode:()=>Lt,updateSettings:()=>rt});function ct(e){return e.charAt(0).toUpperCase()+e.slice(1)}function ie(e){return document.getElementById("model"+ct(e))}function fn(e){return document.getElementById("customModel"+ct(e))}function dt(e){return document.getElementById("effort"+ct(e))}function yn(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__">${m("model.customOption")}</option>`:"",l=(t||[]).map(c=>`<option value="${p(c)}">${p(c)}</option>`).join("");e.innerHTML=a+l+s,i&&Array.from(e.options).some(c=>c.value===i)&&(e.value=i)}function oe(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 fo(e=null){let t=O(),n=document.getElementById("selCli");if(n){let i=e?.cli||n.value||t[0]||"claude";n.innerHTML=t.map(a=>{let s=ye(a)?.label||a;return`<option value="${p(a)}">${p(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="${p(a)}">${p(a)}</option>`).join(""),Array.from(o.options).some(a=>a.value===i)&&(o.value=i)}}function yo(e=null){for(let t of O()){let n=ie(t);if(n){let i=e?.perCli?.[t]?.model||n.value||"";yn(n,F[t]||[],{includeCustom:!0,selected:i}),i&&!Array.from(n.options).some(a=>a.value===i)&&(oe(n,i),n.value=i)}let o=dt(t);if(o){let i=ye(t),a=[""].concat(i?.efforts||[]),s=e?.perCli?.[t]?.effort||o.value||"",l=[...new Set(a)],c=i?.efforts?.length===0&&i?.effortNote?i.effortNote:"\u2014 none";o.innerHTML=l.map(r=>r?`<option value="${p(r)}">${p(r)}</option>`:`<option value="">${p(c)}</option>`).join(""),i?.effortNote&&(o.title=i.effortNote),o.disabled=i?.efforts?.length===0&&!!i?.effortNote,Array.from(o.options).some(r=>r.value===s)&&(o.value=s)}}}function lt(e,t=""){let n=document.getElementById("selEffort");if(!n)return;let o=ye(e);if(o?.effortNote){n.innerHTML=`<option value="">${p(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="${p(s)}">${p(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 mt(){await fe();let e=await h("/api/settings");if(!e)return;mn(e.locale??""),fo(e),yo(e);let t=document.getElementById("selCli");t&&Array.from(t.options).some(r=>r.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),vn(e.permissions,!1),e.perCli)for(let[r,u]of Object.entries(e.perCli)){let g=ie(r),f=dt(r);if(g&&u.model&&(oe(g,u.model),g.value=u.model),f&&(f.value=u.effort||""),r==="codex"&&u.fastMode!==void 0&&(document.getElementById("codexFastOn")?.classList.toggle("active",u.fastMode),document.getElementById("codexFastOff")?.classList.toggle("active",!u.fastMode)),r==="codex"){let y=!!u.contextWindow;document.getElementById("codexCtxOn")?.classList.toggle("active",y),document.getElementById("codexCtxOff")?.classList.toggle("active",!y);let E=document.getElementById("codexCtxValues");E&&(E.style.display=y?"":"none");let x=document.getElementById("codexCtxWindow"),P=document.getElementById("codexCtxCompact");x&&u.contextWindowSize&&(x.value=String(u.contextWindowSize)),P&&u.contextCompactLimit&&(P.value=String(u.contextCompactLimit))}}Ie(!1);let i=e.activeOverrides?.[e.cli]||{},a=e.perCli?.[e.cli]||{},s=i.model||a.model,l=i.effort||a.effort||"",c=document.getElementById("selModel");s&&c&&(c.value=s),lt(e.cli,l),ho(e),En(e),ut(),vo(e.stt||{})}function vo(e){let t=document.getElementById("sttEngine"),n=document.getElementById("sttGeminiKey"),o=document.getElementById("sttGeminiModel"),i=document.getElementById("sttGeminiModelCustom"),a=document.getElementById("sttWhisperModel"),s=document.getElementById("sttOpenaiBaseUrl"),l=document.getElementById("sttOpenaiKey"),c=document.getElementById("sttOpenaiModel"),r=document.getElementById("sttVertexJson");if(t&&(t.value=e.engine||"auto"),n&&(n.placeholder=e.geminiKeySet?`\u2705 \uC785\uB825\uB428 \xB7\xB7\xB7\xB7${e.geminiKeyLast4||""}`:"AIza..."),o){let f=e.geminiModel||"gemini-2.5-flash-lite";Array.from(o.options).some(E=>E.value===f)?o.value=f:(o.value="__custom__",i&&(i.value=f,i.style.display=""))}a&&(a.value=e.whisperModel||"mlx-community/whisper-large-v3-turbo"),s&&(s.value=e.openaiBaseUrl||""),l&&(l.placeholder=e.openaiKeySet?`\u2705 \uC785\uB825\uB428 \xB7\xB7\xB7\xB7${e.openaiKeyLast4||""}`:"sk-..."),c&&(c.value=e.openaiModel||""),r&&(r.value=e.vertexConfig||"");function u(){let f=t?.value||"auto",y=f==="auto"||f==="gemini",E=f==="openai",x=f==="vertex",P=f==="auto"||f==="whisper";document.querySelectorAll(".stt-gemini").forEach(M=>M.style.display=y?"":"none"),document.querySelectorAll(".stt-openai").forEach(M=>M.style.display=E?"":"none"),document.querySelectorAll(".stt-vertex").forEach(M=>M.style.display=x?"":"none"),document.querySelectorAll(".stt-whisper").forEach(M=>M.style.display=P?"":"none")}u();async function g(){let f={stt:{engine:t?.value||"auto",geminiModel:(o?.value==="__custom__"?i?.value:o?.value)||"gemini-2.5-flash-lite",whisperModel:a?.value||"",openaiBaseUrl:s?.value||"",openaiModel:c?.value||"",vertexConfig:r?.value||""}};n?.value&&(f.stt.geminiApiKey=n.value),l?.value&&(f.stt.openaiApiKey=l.value),console.log("[stt] saving:",{engine:f.stt.engine,hasGeminiKey:!!f.stt.geminiApiKey,hasOpenaiKey:!!f.stt.openaiApiKey});try{if(await v("/api/settings","PUT",f),n?.value){let y=n.value.slice(-4);n.value="",n.placeholder=`\u2705 \uC785\uB825\uB428 \xB7\xB7\xB7\xB7${y}`}if(l?.value){let y=l.value.slice(-4);l.value="",l.placeholder=`\u2705 \uC785\uB825\uB428 \xB7\xB7\xB7\xB7${y}`}}catch(y){console.error("[stt] save failed:",y)}}t?.addEventListener("change",()=>{u(),g()}),o?.addEventListener("change",()=>{i&&(i.style.display=o.value==="__custom__"?"":"none"),o.value!=="__custom__"&&g()}),i?.addEventListener("blur",g),n?.addEventListener("blur",()=>{n.value&&g()}),l?.addEventListener("blur",()=>{l.value&&g()}),s?.addEventListener("blur",g),c?.addEventListener("blur",g),a?.addEventListener("blur",g),r?.addEventListener("blur",g)}async function ut(){try{let e=await h("/api/mcp");if(!e)return;let t=document.getElementById("mcpServerList");if(!t)return;let n=Object.entries(e.servers||{});if(!n.length){t.textContent=m("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 pt(){let e=document.getElementById("mcpSyncResult");if(e){e.style.display="block",e.textContent=m("mcp.syncing");try{let t=await v("/api/mcp/sync","POST",{});if(!t){e.textContent="\u274C sync failed";return}let n=t.results||{};e.innerHTML=Object.entries(n).map(([o,i])=>`${i?"\u2705":"\u23ED\uFE0F"} ${o}`).join(" ")}catch(t){e.textContent="\u274C "+t.message}}}async function gt(){let e=document.getElementById("mcpSyncResult");if(e){e.style.display="block",e.textContent=m("mcp.installing");try{let t=await v("/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>"),ut()}catch(t){e.textContent="\u274C "+t.message}}}async function rt(){let e={cli:document.getElementById("selCli")?.value||"claude"},t=document.getElementById("headerCli");t&&(t.textContent=e.cli),await v("/api/settings","PUT",e)}function vn(e,t=!0){t&&R("/api/settings","PUT",{permissions:"auto"})}function hn(e){let t=ie(e);return t?t.value==="__custom__"?fn(e)?.value?.trim()||t.options[0]?.value||"default":t.value:"default"}function ft(e,t){let n=fn(e);n&&(t.value==="__custom__"?(n.style.display="block",n.focus()):(n.style.display="none",A()))}function yt(e,t){let n=t.value.trim();if(!n)return;let o=ie(e);o&&(oe(o,n),o.value=n,t.style.display="none",A())}async function A(){let e={};for(let t of O()){if(!ie(t))continue;let o=dt(t),i={model:hn(t),effort:o?o.value:""};if(t==="codex"){let a=document.getElementById("codexFastOn");i.fastMode=a?.classList.contains("active")??!1;let s=document.getElementById("codexCtxOn");i.contextWindow=s?.classList.contains("active")??!1;let l=document.getElementById("codexCtxWindow"),c=document.getElementById("codexCtxCompact");i.contextWindowSize=parseInt(l?.value||"1000000",10),i.contextCompactLimit=parseInt(c?.value||"900000",10)}e[t]=i}await v("/api/settings","PUT",{perCli:e})}function Ie(e=!0){let t=document.getElementById("selCli")?.value||"claude",n=F[t]||[],o=document.getElementById("selModel");yn(o,n,{includeCustom:!0,includeDefault:!0});let i=document.getElementById("headerCli");i&&(i.textContent=t),lt(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=m("model.placeholder"),s.style.display="none",s.onchange=function(){let l=this.value.trim();!l||!o||(oe(o,l),o.value=l,this.style.display="none",V())},!o){e&&rt();return}o.parentElement?.appendChild(s),o.onchange=function(){this.value==="__custom__"?(s.style.display="block",s.focus()):(s.style.display="none",V())},h("/api/settings").then(l=>{if(!l)return;let c=l.activeOverrides?.[t]||{},r=l.perCli?.[t]||{},u=c.model||r.model,g=c.effort||r.effort||"";u&&o&&(oe(o,u),o.value=u),lt(t,g)}),e&&rt()}async function V(){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 v("/api/settings","PUT",{activeOverrides:i})}async function Se(){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 v("/api/settings","PUT",{telegram:{token:e,allowedChatIds:n}})}async function ke(e){document.getElementById("tgOn")?.classList.toggle("active",e),document.getElementById("tgOff")?.classList.toggle("active",!e),await v("/api/settings","PUT",{telegram:{enabled:e}})}async function we(e){document.getElementById("tgForwardOn")?.classList.toggle("active",e),document.getElementById("tgForwardOff")?.classList.toggle("active",!e),await v("/api/settings","PUT",{telegram:{forwardAll:e}})}function ho(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 En(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 l=o[s]||"",c=n.map(r=>`<option value="${r}" ${r===l?"selected":""}>${r}</option>`).join("");a+=`
|
|
63
63
|
<div class="settings-row sub-row">
|
|
64
64
|
<label style="min-width:60px">Fallback ${s+1}</label>
|
|
65
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="">${
|
|
68
|
-
${
|
|
67
|
+
<option value="">${m("settings.none")}</option>
|
|
68
|
+
${c}
|
|
69
69
|
</select>
|
|
70
|
-
</div>`}t.innerHTML=a}async function vt(){let t=[...document.querySelectorAll("#fallbackOrderList select")].map(n=>n.value).filter(Boolean);await
|
|
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 ${
|
|
72
|
-
<div style="color:${
|
|
73
|
-
${
|
|
74
|
-
<div style="color:var(--text-dim)${
|
|
70
|
+
</div>`}t.innerHTML=a}async function vt(){let t=[...document.querySelectorAll("#fallbackOrderList select")].map(n=>n.value).filter(Boolean);await v("/api/settings","PUT",{fallbackOrder:t})}async function ae(e=!1){let t=Number(localStorage.getItem("cliStatusInterval")||300);if(!e&&d.cliStatusCache&&t>0&&Date.now()-d.cliStatusTs<t*1e3){gn({cliStatus:d.cliStatusCache?.cliStatus,quota:d.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([h("/api/cli-status"),h("/api/quota")]);d.cliStatusCache={cliStatus:o,quota:i},d.cliStatusTs=Date.now(),gn({cliStatus:o,quota:i})}function gn(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 (${m("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 r=n?.[l],u;c.available?!r||r.error?u="ok":r.authenticated===!1?u="warn":u="ok":u="missing";let g="";if(r?.account){let E=[];r.account.email&&E.push(r.account.email),r.account.type&&E.push(r.account.type),r.account.plan&&E.push(r.account.plan),r.account.tier&&E.push(r.account.tier),E.length&&(g=`<div style="font-size:10px;color:var(--text-dim);margin:2px 0 4px 16px">${p(E.join(" \xB7 "))}</div>`)}let f="";if(!c.available||u==="warn"){let E=i[l];if(E){let x=!c.available,P=x?m("cli.authRequired"):m("cli.notAuthenticated"),M=x?"#ef4444":"#fbbf24";f=`
|
|
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 ${M}">
|
|
72
|
+
<div style="color:${M};margin-bottom:3px">${P}</div>
|
|
73
|
+
${x?`<div style="color:var(--text-dim)"><code style="font-size:10px;background:var(--border);padding:1px 4px;border-radius:2px">${p(E.install)}</code></div>`:""}
|
|
74
|
+
<div style="color:var(--text-dim)${x?";margin-top:2px":""}"><code style="font-size:10px;background:var(--border);padding:1px 4px;border-radius:2px">${p(E.auth)}</code></div>
|
|
75
75
|
</div>
|
|
76
|
-
`}}let
|
|
76
|
+
`}}let y="";r?.windows?.length?y=r.windows.map(E=>{let x=Math.round(E.percent),P=x>80?"#ef4444":x>50?"#fbbf24":"#38bdf8",M=E.label.replace("-hour","h").replace("-day","d").replace(" Sonnet","").replace(" Opus",""),ge="";if(E.resetsAt){let Z=new Date(typeof E.resetsAt=="number"?E.resetsAt*1e3:E.resetsAt),lo=new Date;Z.toDateString()===lo.toDateString()?ge=`${Z.getHours()}:${String(Z.getMinutes()).padStart(2,"0")}`:ge=`${Z.getMonth()+1}/${Z.getDate()}`}return`
|
|
77
77
|
<div style="display:flex;align-items:center;gap:4px;margin-left:16px;font-size:10px;color:var(--text-dim)">
|
|
78
|
-
<span style="width:18px">${
|
|
78
|
+
<span style="width:18px">${M}</span>
|
|
79
79
|
<div style="flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden">
|
|
80
|
-
<div style="width:${
|
|
80
|
+
<div style="width:${x}%;height:100%;background:${P};border-radius:2px"></div>
|
|
81
81
|
</div>
|
|
82
|
-
<span style="width:24px;text-align:right">${
|
|
82
|
+
<span style="width:24px;text-align:right">${x}%</span>
|
|
83
83
|
${ge?`<span style="width:30px;text-align:right;opacity:0.6">${ge}</span>`:""}
|
|
84
84
|
</div>
|
|
85
|
-
`}).join(""):r?.error&&
|
|
85
|
+
`}).join(""):r?.error&&c.available&&(y=`<div style="font-size:10px;color:var(--text-dim);margin:2px 0 0 16px;opacity:0.7">\u26A0 ${r.reason==="rate_limited"?"Rate limited \u2014 retry in a moment":"Usage data unavailable"}</div>`),a+=`
|
|
86
86
|
<div class="settings-group" style="margin-bottom:6px;padding:8px 10px">
|
|
87
87
|
<div class="cli-status-row">
|
|
88
88
|
<span class="cli-dot ${u}"></span>
|
|
89
|
-
<span class="cli-name" style="font-weight:600">${l}</span>${l==="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="${
|
|
89
|
+
<span class="cli-name" style="font-weight:600">${l}</span>${l==="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="${m("copilot.keychainHint")}">\u{1F511}</button>`:""}
|
|
90
90
|
</div>
|
|
91
91
|
${g}
|
|
92
92
|
${f}
|
|
93
|
-
${
|
|
93
|
+
${y}
|
|
94
94
|
</div>
|
|
95
|
-
`}o&&(o.innerHTML=a);let s=document.getElementById("copilotKeychainBtn");s&&s.addEventListener("click",async()=>{let l=s;l.disabled=!0,l.textContent="\u23F3";try{let
|
|
96
|
-
\uACC4\uC18D\uD558\uC2DC\uACA0\uC2B5\uB2C8\uAE4C?`))return;H=!H;let e=document.getElementById("templateEditor");e.readOnly=!H;let t=document.getElementById("templateSaveBtn");t&&(t.style.display=H?"":"none");let n=document.getElementById("templateDevToggle");n&&(n.style.color=H?"var(--stop-btn)":"var(--text-dim)",n.style.borderColor=H?"var(--stop-btn)":"var(--border)",n.textContent=H?"\u{1F513} \uAC1C\uBC1C\uC790 \uBAA8\uB4DC ON":"\u{1F527} \uAC1C\uBC1C\uC790 \uBAA8\uB4DC")}async function Mt(){let e=document.getElementById("templateEditor"),t=e.dataset.templateId;if(!t)return;await
|
|
95
|
+
`}o&&(o.innerHTML=a);let s=document.getElementById("copilotKeychainBtn");s&&s.addEventListener("click",async()=>{let l=s;l.disabled=!0,l.textContent="\u23F3";try{let c=await h("/api/copilot/refresh",{method:"POST"});l.textContent=c?.ok?"\u2705":"\u274C",c?.ok&&await ae(!0)}catch{l.textContent="\u274C"}setTimeout(()=>{l.textContent="\u{1F511}",l.disabled=!1},2e3)})}function ht(){h("/api/prompt").then(e=>{if(!e)return;let t=document.getElementById("modalPromptEditor");t&&(t.value=e.content||""),document.getElementById("promptModal")?.classList.add("open")})}function G(e){e&&e.target!==e.currentTarget||document.getElementById("promptModal")?.classList.remove("open")}async function Et(){let t=document.getElementById("modalPromptEditor")?.value||"";await v("/api/prompt","PUT",{content:t}),document.getElementById("promptModal")?.classList.remove("open")}async function xt(){let e=await h("/api/prompt-templates");e&&(bt=e.templates,H=!1,Eo(e.tree),Tt("tree"),document.getElementById("templateModal")?.classList.add("open"))}function Eo(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=bt.find(l=>l.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",()=>{bo(a)}),t.appendChild(s)}}}}function bo(e){let t=document.getElementById("templateEditor");t.value=e.content,t.dataset.templateId=e.id,t.readOnly=!0,H=!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 l=document.getElementById("templateModalTitle");l&&(l.textContent=`\u{1F4C4} ${e.filename}`),Tt("editor")}function Lt(){if(!H&&!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.
|
|
96
|
+
\uACC4\uC18D\uD558\uC2DC\uACA0\uC2B5\uB2C8\uAE4C?`))return;H=!H;let e=document.getElementById("templateEditor");e.readOnly=!H;let t=document.getElementById("templateSaveBtn");t&&(t.style.display=H?"":"none");let n=document.getElementById("templateDevToggle");n&&(n.style.color=H?"var(--stop-btn)":"var(--text-dim)",n.style.borderColor=H?"var(--stop-btn)":"var(--border)",n.textContent=H?"\u{1F513} \uAC1C\uBC1C\uC790 \uBAA8\uB4DC ON":"\u{1F527} \uAC1C\uBC1C\uC790 \uBAA8\uB4DC")}async function Mt(){let e=document.getElementById("templateEditor"),t=e.dataset.templateId;if(!t)return;await v(`/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=bt.find(i=>i.id===t);o&&(o.content=e.value)}function Tt(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 It(){Tt("tree")}function Be(e){e&&e.target!==e.currentTarget||document.getElementById("templateModal")?.classList.remove("open")}var bt,H,Q=L(()=>{"use strict";ve();_();be();T();k();B();bt=[],H=!1});async function bn(){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"}Ce=await St("ko"),e==="ko"?re=Ce:re=await St(e),le=e,xn()}async function St(e){try{let{api:t}=await Promise.resolve().then(()=>(k(),Zt));return await t(`/api/i18n/${e}`)||{}}catch{return{}}}function m(e,t={}){let n=re[e]??Ce[e]??e;for(let[o,i]of Object.entries(t))n=n.replaceAll(`{${o}}`,String(i));return n}function xn(){document.querySelectorAll("[data-i18n]").forEach(e=>{let t=e.getAttribute("data-i18n");t&&(e.textContent=m(t))}),document.querySelectorAll("[data-i18n-placeholder]").forEach(e=>{let t=e.getAttribute("data-i18n-placeholder");t&&(e.placeholder=m(t))}),document.querySelectorAll("[data-i18n-title]").forEach(e=>{let t=e.getAttribute("data-i18n-title");t&&(e.title=m(t))}),document.querySelectorAll("[data-i18n-aria]").forEach(e=>{let t=e.getAttribute("data-i18n-aria");t&&e.setAttribute("aria-label",m(t))})}async function Ln(e){if(e!==le){e==="ko"?re=Ce:re=await St(e),le=e;try{localStorage.setItem("claw_locale",e)}catch{}xn();try{let{loadEmployees:t}=await Promise.resolve().then(()=>(J(),ne));t()}catch{}try{let{loadSkills:t}=await Promise.resolve().then(()=>(he(),Xe));t()}catch{}try{let{loadCommands:t}=await Promise.resolve().then(()=>(Te(),st));t()}catch{}try{let{loadSettings:t}=await Promise.resolve().then(()=>(Q(),se));t()}catch{}}}function ce(){return le}function cn(e,t={}){let n=new URL(e,location.origin);return n.searchParams.has("locale")||n.searchParams.set("locale",le),fetch(n.toString(),t)}var le,re,Ce,T=L(()=>{"use strict";le="ko",re={},Ce={}});function Mn(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=L(()=>{"use strict"});function p(e){return e.replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,""").replace(/'/g,"'")}function kn(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 $e(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 xo(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 Lo(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>${p(i.tex)}</code></pre>`:`<code>${p(i.tex)}</code>`;try{return katex.renderToString(i.tex,{displayMode:i.displayMode,throwOnError:!1})}catch{return i.displayMode?`<pre><code>${p(i.tex)}</code></pre>`:`<code>${p(i.tex)}</code>`}})}function To(){typeof mermaid>"u"||document.querySelectorAll(".mermaid-pending").forEach(async e=>{e.classList.remove("mermaid-pending");let t=e.textContent||"",n=`mermaid-${++Mo}`;try{let{svg:o}=await mermaid.render(n,t);e.innerHTML=kn(o),e.classList.add("mermaid-rendered")}catch(o){let i=o?.message||o?.str||"Unknown error";e.innerHTML=`
|
|
97
97
|
<div style="border:1px solid #ef4444;border-radius:6px;padding:8px;margin:4px 0">
|
|
98
|
-
<div style="color:#ef4444;font-size:11px;margin-bottom:4px">\u26A0\uFE0F ${p(
|
|
98
|
+
<div style="color:#ef4444;font-size:11px;margin-bottom:4px">\u26A0\uFE0F ${p(m("mermaid.renderFail")||"Mermaid render failed")}</div>
|
|
99
99
|
<div style="color:#fbbf24;font-size:10px;margin-bottom:6px">${p(i.slice(0,200))}</div>
|
|
100
100
|
<pre style="margin:0;font-size:11px;overflow-x:auto"><code>${p(t)}</code></pre>
|
|
101
|
-
</div>`}})}function
|
|
102
|
-
`);i=`<details class="tool-summary"><summary>${s}</summary><div class="tool-log">${l}</div></details>`}o&&(o.innerHTML=i+kt(e)),o&&o.setAttribute("data-raw",$e(e))}
|
|
103
|
-
`);o&&(u+=
|
|
101
|
+
</div>`}})}function Io(){if(In)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">${p(t)}</div>`;let o=p(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?p(n):m("code.copy");return`<div class="code-block-wrapper">${`<span class="code-lang-label" data-lang="${n?p(n):""}">${i}</span>`}<pre><code class="hljs${n?` language-${p(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"}),In=!0,!0}function So(e){return p(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 wn(){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 ko(){Sn||(Sn=!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=m("code.copied"),t.classList.add("copied"),setTimeout(()=>{t.textContent=i,t.classList.remove("copied")},1500)}).catch(()=>{})}))}function kt(e){let t=$e(e);if(!t)return`<em style="color:var(--text-dim)">${p(m("orchestrator.dispatching"))}</em>`;let{text:n,blocks:o}=xo(t),i;if(Io()){let a=Mn(n);i=marked.parse(a),i=i.replace(/<table/g,'<div class="table-wrapper"><table').replace(/<\/table>/g,"</table></div>")}else i=So(n);return i=Lo(i,o),i=kn(i),requestAnimationFrame(()=>{To(),wn()}),ko(),i}var Mo,In,Sn,_=L(()=>{"use strict";T();Tn();Mo=0;In=!1;(function e(){if(typeof hljs<"u"){wn();return}setTimeout(e,200)})();Sn=!1});function $n(){return Y}function Bn(e){Y=(e||"").trim()||wt,localStorage.setItem(Cn,Y);let t=document.getElementById("appNameInput");t&&(t.value=Y)}function Hn(){Y=localStorage.getItem(Cn)||wt;let e=document.getElementById("appNameInput");e&&(e.value=Y),document.getElementById("appNameSave")?.addEventListener("click",()=>{let t=document.getElementById("appNameInput");t&&Bn(t.value)}),document.getElementById("appNameInput")?.addEventListener("keydown",t=>{let n=t;n.key==="Enter"&&(n.preventDefault(),Bn(n.target.value),n.target.blur())})}var Cn,wt,Y,Bt=L(()=>{"use strict";Cn="agentName",wt="CLI-JAW",Y=wt});var Ot={};K(Ot,{addMessage:()=>w,addSystemMsg:()=>b,appendAgentText:()=>Ct,finalizeAgent:()=>Ae,handleSave:()=>At,initMsgCopy:()=>Rt,loadMemory:()=>Pt,loadMessages:()=>wo,loadStats:()=>Pn,scrollToBottom:()=>$t,setStatus:()=>X,switchTab:()=>Ht,updateQueueBadge:()=>He});function X(e){let t=document.getElementById("statusBadge"),n=document.getElementById("btnSend");d.agentBusy=e==="running",document.getElementById("typingIndicator")?.classList.toggle("active",d.agentBusy),e==="running"?(t&&(t.className="status-badge status-running",t.textContent="\u23F3 running"),n&&(n.textContent="\u25A0",n.title=m("btn.stop"),n.classList.add("stop-mode"))):(t&&(t.className="status-badge status-idle",t.textContent="\u26A1 idle"),n&&(n.textContent="\u27A4",n.title="Send",n.classList.remove("stop-mode")),He(0))}function He(e){let t=document.getElementById("queueBadge");if(!t){t=document.createElement("span"),t.id="queueBadge",t.style.cssText="position:absolute;top:-6px;right:-6px;background:#f80;color:#fff;border-radius:50%;font-size:11px;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-weight:bold";let n=document.getElementById("btnSend");n?.parentElement&&(n.parentElement.style.position="relative"),n&&(n.style.position="relative",n.appendChild(t))}t.textContent=e>0?String(e):"",t.style.display=e>0?"flex":"none"}function 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 Ct(e){if(!e)return;d.currentAgentDiv||(d.currentAgentDiv=w("agent",""));let t=d.currentAgentDiv?.querySelector(".msg-content");t&&(t.textContent+=e),$t()}function Ae(e,t){let n=Date.now();if(!(!d.currentAgentDiv&&n-An<500)){if(document.querySelectorAll(".msg-system.tool-activity").forEach(o=>o.remove()),e){d.currentAgentDiv||(d.currentAgentDiv=w("agent",""));let o=d.currentAgentDiv?.querySelector(".msg-content"),i="";if(t&&t.length>0){let a={};t.forEach(c=>{a[c.icon]=(a[c.icon]||0)+1});let s=Object.entries(a).map(([c,r])=>`${c}\xD7${r}`).join(" "),l=t.map(c=>`${c.icon} ${p(c.label)}`).join(`
|
|
102
|
+
`);i=`<details class="tool-summary"><summary>${s}</summary><div class="tool-log">${l}</div></details>`}o&&(o.innerHTML=i+kt(e)),o&&o.setAttribute("data-raw",$e(e))}d.currentAgentDiv=null,An=Date.now(),X("idle"),Pn()}}function w(e,t){let n=document.getElementById("chatMessages"),o=document.createElement("div");o.className=`msg msg-${e}`;let i=kt(t);o.innerHTML=`<div class="msg-label">${e==="user"?m("msg.you"):$n()}</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",$e(t)),n?.appendChild(o),$t(),o}function $t(){let e=document.getElementById("chatMessages");e&&(e.scrollTop=e.scrollHeight)}function Ht(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(),se)).then(o=>o.loadSettings()),e==="agents"&&Promise.resolve().then(()=>(J(),ne)).then(o=>o.loadEmployees()),e==="skills"&&Promise.resolve().then(()=>(he(),Xe)).then(o=>o.loadSkills())}function At(){document.getElementById("tabSettings")?.classList.contains("active")?Promise.resolve().then(()=>(Q(),se)).then(t=>t.savePerCli()):Promise.resolve().then(()=>(Q(),se)).then(t=>t.updateSettings())}async function Pn(){let e=await h("/api/messages");if(!e)return;let t=document.getElementById("statMsgs");t&&(t.textContent=m("stat.messages",{count:e.length}))}async function wo(){let e=await h("/api/messages");e&&e.forEach(t=>w(t.role==="assistant"?"agent":t.role,t.content))}async function Pt(){try{let e=await h("/api/memory"),t=document.getElementById("memoryList");if(!t||!e)return;if(e.length===0){t.innerHTML=`<li style="color:var(--text-dim)">${m("mem.empty")}</li>`;return}t.innerHTML=e.map(n=>`<li><span class="memory-key">${p(n.key)}</span>: ${p(n.value)}</li>`).join("")}catch{}}function Rt(){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 An,N=L(()=>{"use strict";B();_();Bt();T();k();An=0});function Dt(e,t,n){let o=de.indexOf(n);if(o<0)return;let i=e.getBoundingClientRect(),a=t.offsetWidth||36,s=document.getElementById(`dot-${n}`);if(!s)return;let l=de[o+1],c=l?document.getElementById(`dot-${l}`):null;if(c){let r=s.getBoundingClientRect(),u=c.getBoundingClientRect(),g=(r.right+u.left)/2;t.style.left=g-i.left-a/2+"px"}else{let r=s.getBoundingClientRect();t.style.left=r.left-i.left+r.width/2-a/2+"px"}}function Ft(){d.ws=new WebSocket(`ws://${location.host}?lang=${ce()}`),d.ws.onmessage=e=>{let t=JSON.parse(e.data);if(t.type==="agent_status")t.running!==void 0?X(t.running?"running":"idle"):X(t.status||"idle"),t.agentId&&t.phase&&(Rn[t.agentId]={phase:t.phase,phaseLabel:t.phaseLabel||""},Promise.resolve().then(()=>(J(),ne)).then(n=>n.loadEmployees()));else if(t.type==="queue_update")He(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(m("ws.roundStart",{round:t.round||0,count:n.length,names:o}))}else if(t.type==="round_done")t.action==="complete"?b(m("ws.roundDone",{round:t.round||0})):t.action==="next"?b(m("ws.roundNext",{round:t.round||0})):b(m("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")Ct(t.text||"");else if(t.type==="agent_retry")b(m("ws.retry",{cli:t.cli||"",delay:t.delay||10}),"tool-activity");else if(t.type==="agent_fallback")b(m("ws.fallback",{from:t.from||"",to:t.to||""}),"tool-activity");else if(t.type==="agent_done")Ae(t.text||"",t.toolLog);else if(t.type==="orchestrate_done")Ae(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(()=>(J(),ne)).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(d.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 r=`--orc-glow-${i}`,u=getComputedStyle(document.documentElement).getPropertyValue(r).trim();document.body.style.setProperty("--orc-glow",u)}document.body.classList.add("orc-pulse"),setTimeout(()=>document.body.classList.remove("orc-pulse"),700);let a=document.getElementById("orcStateBadge");if(a){let r={IDLE:"",P:"PLAN",A:"AUDIT",B:"BUILD",C:"CHECK",D:"DONE"};a.textContent=r[i],a.style.display=i==="IDLE"?"none":"inline-block"}let s=document.getElementById("pabcRoadmap"),l=document.getElementById("sharkRunner"),c=document.getElementById("pabcBrand");if(s&&l){if(!s.dataset.resizeObserved){s.dataset.resizeObserved="1",new ResizeObserver(()=>{q&&l.classList.contains("running")&&Dt(s,l,q)}).observe(s);let r=0;window.addEventListener("resize",()=>{cancelAnimationFrame(r),r=requestAnimationFrame(()=>{q&&l.classList.contains("running")&&Dt(s,l,q)})})}if(i==="IDLE")s.classList.remove("visible","shimmer-out"),l.classList.remove("running"),q=null;else if(i==="D"){de.forEach(r=>{let u=document.getElementById(`dot-${r}`);u&&(u.className="pabc-dot done",u.setAttribute("data-phase",r))});for(let r=0;r<4;r++){let u=document.getElementById(`pabc-conn-${r}`);u&&(u.className="pabc-connector done")}l.classList.remove("running"),q=null,s.classList.add("shimmer-out"),setTimeout(()=>s.classList.remove("visible","shimmer-out"),1e3)}else{s.classList.remove("shimmer-out"),s.classList.add("visible"),l.classList.add("running");let r=de.indexOf(i);de.forEach((u,g)=>{let f=document.getElementById(`dot-${u}`);f&&(f.className=`pabc-dot ${g<r?"done":g===r?"active":"future"}`,f.setAttribute("data-phase",u))});for(let u=0;u<4;u++){let g=document.getElementById(`pabc-conn-${u}`);g&&(g.className=`pabc-connector ${u<r?"done":""}`)}q=i,requestAnimationFrame(()=>Dt(s,l,i))}c&&t.title&&(c.textContent=t.title)}}else t.type==="new_message"&&t.source==="telegram"&&w(t.role==="assistant"?"agent":t.role||"user",t.content||"")},d.ws.onopen=()=>{console.log("[ws] connected"),Promise.resolve().then(()=>(N(),Ot)).then(e=>{let t=document.getElementById("chatMessages");t&&(t.innerHTML=""),e.loadMessages(),e.setStatus("idle")})},d.ws.onclose=()=>{console.log("[ws] disconnected, reconnecting in 2s..."),X("idle"),setTimeout(Ft,2e3)}}function ln(e){return Rn[e]||null}var de,q,Rn,Ve=L(()=>{"use strict";B();N();T();de=["P","A","B","C"],q=null;Rn={}});Ve();N();B();N();be();T();Te();k();async function Re(){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()&&!d.attachedFiles.length){R("/api/stop","POST");return}let o=e.value.trim();if(!o&&!d.attachedFiles.length)return;let a=o.slice(1).trim().split(/\s+/)[0]||"",s=a.includes("/")||a.includes("\\");if(o.startsWith("/")&&!d.attachedFiles.length&&!s){e.value="",Pe(),$();try{let l,c;if(typeof AbortSignal?.timeout=="function")l=AbortSignal.timeout(1e4);else{let f=new AbortController;l=f.signal,c=setTimeout(()=>f.abort(),1e4)}let r=Ee(),u=await fetch("/api/command",{method:"POST",headers:{"Content-Type":"application/json","Accept-Language":r},body:JSON.stringify({text:o,locale:r}),signal:l});c&&clearTimeout(c);let g=await u.json().catch(()=>({}));if(g?.code==="not_command"){w("user",o),await v("/api/message","POST",{prompt:o});return}if(!u.ok&&!g?.text)throw new Error(`HTTP ${u.status}`);if(g?.code==="clear_screen"){let f=document.getElementById("chatMessages");f&&(f.innerHTML="")}g?.text&&b(g.text,"",g.type)}catch(l){b(m("chat.cmd.fail",{msg:l.message}),"","error")}return}if(d.attachedFiles.length){let c=`[\u{1F4CE} ${d.attachedFiles.map(r=>r.name).join(", ")}] ${o}`;w("user",c),e.value="",Pe();try{let u=(await Promise.all(d.attachedFiles.map(g=>Dn(g)))).map(g=>m("chat.file.sent",{path:g})).join(`
|
|
103
|
+
`);o&&(u+=m("chat.file.sentWithMsg",{text:o})),me(),await v("/api/message","POST",{prompt:u})}catch(r){b(m("chat.file.uploadFail",{msg:r.message})),me()}}else{w("user",o),e.value="",Pe();let l=await fetch("/api/message",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({prompt:o})}),c=await l.json().catch(()=>({}));if(!l.ok){b(`\u274C ${c.error||m("chat.requestFail",{status:l.status})}`,"","error");return}if(c.queued){let{updateQueueBadge:r}=await Promise.resolve().then(()=>(N(),Ot));r(c.pending||1)}else c.continued&&b(m("chat.continue"))}}function On(e){e.key==="Enter"&&!e.shiftKey&&!e.isComposing&&(e.preventDefault(),Re())}async function Dn(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 _t(e){for(let t of e)d.attachedFiles.some(n=>n.name===t.name)||d.attachedFiles.push(t);jt(),document.getElementById("chatInput")?.focus()}function Fn(e){d.attachedFiles.splice(e,1),jt()}function me(){d.attachedFiles=[],jt();let e=document.getElementById("fileInput");e&&(e.value="")}function jt(){let e=document.getElementById("filePreview"),t=document.getElementById("filePreviewList");if(e){if(!d.attachedFiles.length){e.classList.remove("visible"),t&&(t.innerHTML="");return}e.classList.add("visible"),t&&(t.innerHTML=d.attachedFiles.map((n,o)=>{let i=(n.size/1024).toFixed(1);return`<div class="file-chip">
|
|
104
104
|
${n.type.startsWith("image/")?`<img src="${URL.createObjectURL(n)}" class="file-chip-thumb" alt="">`:""}
|
|
105
105
|
<span class="file-chip-name">\u{1F4CE} ${n.name} (${i}KB)</span>
|
|
106
106
|
<button class="file-chip-remove" data-file-idx="${o}" title="Remove">\u2715</button>
|
|
107
|
-
</div>`}).join(""))}}async function _n(){
|
|
108
|
-
`)})}catch(l){b(
|
|
107
|
+
</div>`}).join(""))}}async function _n(){R("/api/clear","POST");let e=document.getElementById("chatMessages");e&&(e.innerHTML="")}function Bo(e){e.style.height="auto",e.style.height=e.scrollHeight+"px"}function jn(){let e=document.getElementById("chatInput");e&&e.addEventListener("input",()=>Bo(e))}function Pe(){let e=document.getElementById("chatInput");e&&(e.style.height="auto")}function Nn(){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&&_t(a)}),document.getElementById("fileInput")?.addEventListener("change",o=>{let i=o.target,a=[...i.files||[]];a.length&&_t(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 l=s.getAsFile();if(l)if(!l.name||l.name==="image.png"){let c=new Date().toISOString().replace(/[:.]/g,"-"),r=l.type.split("/")[1]||"png",u=new File([l],`pasted-${c}.${r}`,{type:l.type});a.push(u)}else a.push(l)}a.length&&(o.preventDefault(),_t(a))})}async function qn(e,t,n){let o=document.getElementById("chatInput"),i=o?.value.trim()||"",a=[...d.attachedFiles],s=["\u{1F3A4} [\uC74C\uC131 \uBA54\uC2DC\uC9C0]"];a.length&&s.push(`[\u{1F4CE} ${a.map(l=>l.name).join(", ")}]`),i&&s.push(i),w("user",s.join(" ")),o&&i&&(o.value="",Pe()),a.length&&me();try{let l=await fetch("/api/voice",{method:"POST",headers:{"Content-Type":n,"X-Voice-Ext":t,"X-STT-Only":"true"},body:e});if(!l.ok){let g=await l.json().catch(()=>({}));throw new Error(g.error||`HTTP ${l.status}`)}let c=await l.json().catch(()=>null);if(!c?.text)throw new Error("Empty STT result");b(`\u{1F3A4} STT (${c.engine}, ${c.elapsed?.toFixed(1)}s): "${c.text.slice(0,100)}"`,"","info");let r=[];a.length&&(r=await Promise.all(a.map(g=>Dn(g))));let u=[];for(let g of r)u.push(m("chat.file.sent",{path:g}));u.push(`\u{1F3A4} ${c.text}`),i&&u.push(i),await v("/api/message","POST",{prompt:u.join(`
|
|
108
|
+
`)})}catch(l){b(m("voice.sttFail",{msg:l.message}),"","error")}}Te();he();Q();J();B();T();k();_();async function zn(){let e=await h("/api/heartbeat");d.heartbeatJobs=e?.jobs||[],Oe(),document.getElementById("heartbeatModal")?.classList.add("open")}function Nt(e){e&&e.target!==e.currentTarget||document.getElementById("heartbeatModal")?.classList.remove("open")}function Oe(){let e=document.getElementById("hbJobsList");if(!e)return;let t=d.heartbeatJobs;t.length===0?e.innerHTML=`<p style="color:var(--text-dim);font-size:12px;text-align:center">${m("hb.empty")}</p>`:e.innerHTML=t.map((i,a)=>`
|
|
109
109
|
<div class="hb-job-card">
|
|
110
110
|
<div class="hb-job-header">
|
|
111
|
-
<input type="text" value="${p(String(i.name||""))}" placeholder="${
|
|
111
|
+
<input type="text" value="${p(String(i.name||""))}" placeholder="${m("hb.name")}"
|
|
112
112
|
data-hb-name="${a}">
|
|
113
113
|
<span style="font-size:11px;color:var(--text-dim)">every</span>
|
|
114
114
|
<input type="number" value="${i.schedule?.minutes||5}" min="1"
|
|
@@ -118,10 +118,10 @@ var lo=Object.defineProperty;var x=(e,t)=>()=>(e&&(t=e(e=0)),t);var q=(e,t)=>{fo
|
|
|
118
118
|
data-hb-toggle="${a}"></button>
|
|
119
119
|
<button class="hb-del" data-hb-remove="${a}">\u2715</button>
|
|
120
120
|
</div>
|
|
121
|
-
<textarea class="hb-prompt" rows="2" placeholder="${
|
|
121
|
+
<textarea class="hb-prompt" rows="2" placeholder="${m("hb.prompt")}"
|
|
122
122
|
data-hb-prompt="${a}">${p(String(i.prompt||""))}</textarea>
|
|
123
123
|
</div>
|
|
124
|
-
`).join("");let n=t.filter(i=>i.enabled).length,o=document.getElementById("hbSidebarBtn");o&&(o.textContent=`\u{1F493} Heartbeat (${n})`)}function
|
|
124
|
+
`).join("");let n=t.filter(i=>i.enabled).length,o=document.getElementById("hbSidebarBtn");o&&(o.textContent=`\u{1F493} Heartbeat (${n})`)}function Kn(){d.heartbeatJobs.push({id:"hb_"+Date.now(),name:"",enabled:!0,schedule:{kind:"every",minutes:5},prompt:""}),Oe(),z()}function Jn(e){d.heartbeatJobs.splice(e,1),Oe(),z()}function Un(e){let t=d.heartbeatJobs;t[e].enabled=!t[e].enabled,Oe(),z()}async function z(){await v("/api/heartbeat","PUT",{jobs:d.heartbeatJobs})}async function Wn(){try{let t=((await h("/api/heartbeat"))?.jobs||[]).filter(o=>o.enabled).length,n=document.getElementById("hbSidebarBtn");n&&(n.textContent=`\u{1F493} Heartbeat (${t})`)}catch{}}_();k();async function De(){let e=await h("/api/memory-files");if(!e)return;let t=u=>document.getElementById(u);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 l=t("memCounter");l&&(l.textContent=String(e.counter));let c=t("memThreshold");c&&(c.textContent=String(e.flushEvery)),Co(e.files);let r=t("memorySidebarBtn");r&&(r.textContent=`\u{1F9E0} Memory (${e.files.length})`),t("memoryModal")?.classList.add("open")}function qt(e){e&&e.target!==e.currentTarget||document.getElementById("memoryModal")?.classList.remove("open")}function zt(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 v("/api/memory-files/settings","PUT",{enabled:e})}async function ue(){let e=document.getElementById("memFlushEvery"),t=document.getElementById("memCli"),n=document.getElementById("memModel"),o=document.getElementById("memRetention");await v("/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 Co(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=>`
|
|
125
125
|
<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"
|
|
126
126
|
data-mem-view="${p(n.name)}">
|
|
127
127
|
<div>
|
|
@@ -130,11 +130,11 @@ var lo=Object.defineProperty;var x=(e,t)=>()=>(e&&(t=e(e=0)),t);var q=(e,t)=>{fo
|
|
|
130
130
|
</div>
|
|
131
131
|
<button data-mem-delete="${p(n.name)}" style="background:none;border:none;color:#f55;cursor:pointer;font-size:14px">\u{1F5D1}\uFE0F</button>
|
|
132
132
|
</div>
|
|
133
|
-
`).join("")}}async function
|
|
133
|
+
`).join("")}}async function Vn(e){confirm("Delete "+e+"?")&&(await v("/api/memory-files/"+e,"DELETE",{}),De())}async function Gn(e){let t=await h("/api/memory-files/"+e);if(!t)return;let n=document.getElementById("memFilesList");n&&(n.innerHTML=`
|
|
134
134
|
<div style="margin-bottom:8px;display:flex;justify-content:space-between;align-items:center">
|
|
135
135
|
<span style="font-size:12px;font-weight:600">${t.name}</span>
|
|
136
136
|
<button data-mem-back style="background:none;border:none;color:var(--accent);cursor:pointer;font-size:11px">\u2190 back</button>
|
|
137
137
|
</div>
|
|
138
138
|
<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)">${p(t.content)}</pre>
|
|
139
|
-
`)}B();ve();Bt();var Jt="sidebarState";function Qn(){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",Ut),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(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");Fe()}),window.innerWidth<=900&&document.body.classList.remove("left-collapsed","right-collapsed"),Fe()}function _e(){return window.innerWidth<=900}function Ut(){_e()?document.body.classList.toggle("left-expanded"):document.body.classList.toggle("left-collapsed"),Yn(),Fe()}function Wt(){_e()?document.body.classList.toggle("right-expanded"):document.body.classList.toggle("right-collapsed"),Yn(),Fe()}function Co(){return _e()?document.body.classList.contains("left-expanded"):!document.body.classList.contains("left-collapsed")}function $o(){return _e()?document.body.classList.contains("right-expanded"):!document.body.classList.contains("right-collapsed")}function Fe(){let e=document.getElementById("toggleLeft"),t=document.getElementById("toggleRight");e&&(e.textContent=Co()?"\u25C0":"\u25B6"),t&&(t.textContent=$o()?"\u25B6":"\u25C0")}function Yn(){localStorage.setItem(Jt,JSON.stringify({left:document.body.classList.contains("left-collapsed"),right:document.body.classList.contains("right-collapsed")}))}var Xn="theme",Ho="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.11.1/styles/github-dark.min.css",Ao="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.11.1/styles/github.min.css";function Zn(){let e=localStorage.getItem(Xn),t=window.matchMedia("(prefers-color-scheme: light)").matches?"light":"dark";eo(e||t),document.getElementById("toggleTheme")?.addEventListener("click",Po)}function Po(){let t=(document.documentElement.getAttribute("data-theme")||"dark")==="dark"?"light":"dark";eo(t),localStorage.setItem(Xn,t)}function eo(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"?Ho:Ao)}M();B();_();M();var Gt=!1,S=null,pe=[],Ne=null,je=null,no=0;function Ro(){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 Oo(e){let t=e;switch(t.name){case"NotAllowedError":return d("voice.micDenied");case"NotFoundError":return d("voice.micNotFound");case"NotReadableError":case"AbortError":return d("voice.micBusy");default:return t instanceof TypeError||!navigator.mediaDevices?d("voice.httpsRequired"):d("voice.micDenied")}}async function Do(){if(c.isRecording)return;if(typeof MediaRecorder>"u"||!navigator.mediaDevices?.getUserMedia){b(d("voice.unsupported"),"","error");return}try{Ne=await navigator.mediaDevices.getUserMedia({audio:!0})}catch(n){b(Oo(n),"","error");return}let e=Ro(),t=e?{mimeType:e}:{};S=new MediaRecorder(Ne,t),pe=[],S.ondataavailable=n=>{n.data.size>0&&pe.push(n.data)},S.onerror=()=>{oo(),b(d("voice.interrupted"),"","error")},S.onstop=async()=>{if(Gt){pe=[],to(),Gt=!1;return}let n=S?.mimeType||e||"audio/webm",o=n.includes("mp4")?".m4a":n.includes("ogg")?".ogg":".webm",i=new Blob(pe,{type:n});if(pe=[],to(),i.size>20*1024*1024){b(d("voice.tooLarge"),"","error");return}if(i.size<1e3){b(d("voice.tooShort"),"","error");return}await qn(i,o,n)},S.start(),c.isRecording=!0,no=Date.now(),Yt(!0),Fo()}function oo(){!c.isRecording||!S||(S.state==="recording"&&S.stop(),c.isRecording=!1,io(),Yt(!1))}function Vt(){!c.isRecording||!S||(Gt=!0,S.state==="recording"&&S.stop(),c.isRecording=!1,io(),Yt(!1))}function Qt(){c.isRecording?oo():Do()}function to(){Ne?.getTracks().forEach(e=>e.stop()),Ne=null}function Fo(){let e=document.getElementById("voiceTimer");e&&(e.style.display="inline",je=setInterval(()=>{let t=Math.floor((Date.now()-no)/1e3),n=String(Math.floor(t/60)).padStart(2,"0"),o=String(t%60).padStart(2,"0");e.textContent=`${n}:${o}`},500))}function io(){je&&(clearInterval(je),je=null);let e=document.getElementById("voiceTimer");e&&(e.style.display="none",e.textContent="00:00")}function Yt(e){let t=document.getElementById("btnVoice"),n=document.getElementById("btnVoiceCancel");t&&(t.classList.toggle("recording",e),t.textContent=e?"\u23F9":"\u{1F3A4}",t.title=e?d("voice.stop"):d("voice.start")),n&&(n.style.display=e?"inline-block":"none")}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",Re);var Xt=document.getElementById("chatInput");Xt?.addEventListener("keydown",e=>{ot(e)||On(e)});var qe=0;Xt?.addEventListener("input",e=>{e.isComposing||(qe&&cancelAnimationFrame(qe),qe=requestAnimationFrame(()=>{Me(e.target?.value||""),qe=0}))});Xt?.addEventListener("cmd-execute",()=>{Re()});document.getElementById("cmdDropdown")?.addEventListener("click",it);document.addEventListener("click",at);document.getElementById("filePreviewClear")?.addEventListener("click",me);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("btnVoice")?.addEventListener("click",()=>Qt());document.getElementById("btnVoiceCancel")?.addEventListener("click",()=>Vt());document.getElementById("memorySidebarBtn")?.addEventListener("click",De);document.getElementById("btnClearChat")?.addEventListener("click",_n);document.getElementById("hbSidebarBtn")?.addEventListener("click",Kn);document.getElementById("langToggle")?.addEventListener("click",async()=>{let e=ce()==="ko"?"en":"ko";await Ln(e);let t=document.getElementById("langToggle");t&&(t.textContent=`\u{1F310} ${d("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]&&Ht(i[o],t)});document.querySelector(".sidebar-save-bar .btn-save")?.addEventListener("click",At);document.getElementById("selCli")?.addEventListener("change",()=>Se());document.getElementById("selModel")?.addEventListener("change",()=>U());document.getElementById("selEffort")?.addEventListener("change",()=>U());document.querySelector('[data-action="addEmployee"]')?.addEventListener("click",ze);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){R(n.dataset.empName||"",{name:t.value});return}let o=t.closest("[data-emp-cli]");if(o){Ue(o.dataset.empCli||"",t.value);return}let i=t.closest("[data-emp-model]");if(i){if(t.value==="__custom__"){let l=prompt(d("model.promptInput"));if(l?.trim()){let m=document.createElement("option");m.value=l.trim(),m.textContent=l.trim();let r=t.querySelector('option[value="__custom__"]');r&&t.insertBefore(m,r),t.value=l.trim(),R(i.dataset.empModel||"",{model:l.trim()})}else t.value="default"}else R(i.dataset.empModel||"",{model:t.value});return}let a=t.closest("[data-emp-role]");if(a){We(a.dataset.empRole||"",t.value);return}let s=t.closest("[data-emp-custom]");if(s){R(s.dataset.empCustom||"",{role:t.value});return}});document.getElementById("skillsList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-skill-id]");t&&Qe(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";Ye(n,t)}});document.querySelector('[data-action="openPrompt"]')?.addEventListener("click",ht);document.getElementById("tgOff")?.addEventListener("click",()=>ke(!1));document.getElementById("tgOn")?.addEventListener("click",()=>ke(!0));document.getElementById("tgForwardOff")?.addEventListener("click",()=>we(!1));document.getElementById("tgForwardOn")?.addEventListener("click",()=>we(!0));document.getElementById("tgToken")?.addEventListener("change",Ie);document.getElementById("tgChatIds")?.addEventListener("change",Ie);document.getElementById("fallbackOrderList")?.addEventListener("change",vt);function ao(e){let t=document.getElementById("codexFastOn"),n=document.getElementById("codexFastOff");t&&n&&(t.classList.toggle("active",e),n.classList.toggle("active",!e)),W()}document.getElementById("codexFastOn")?.addEventListener("click",()=>ao(!0));document.getElementById("codexFastOff")?.addEventListener("click",()=>ao(!1));function _o(){for(let e of P()){let t=e.charAt(0).toUpperCase()+e.slice(1),n=document.getElementById("model"+t);n&&n.addEventListener("change",function(){ft(e,this)});let o=document.getElementById("customModel"+t);o&&o.addEventListener("change",function(){yt(e,this)});let i=document.getElementById("effort"+t);i&&i.addEventListener("change",W)}}document.querySelector('[data-action="syncMcp"]')?.addEventListener("click",pt);document.querySelector('[data-action="installMcp"]')?.addEventListener("click",gt);document.querySelector('[data-action="refreshCli"]')?.addEventListener("click",()=>ae(!0));document.getElementById("cliStatusInterval")?.addEventListener("change",function(){localStorage.setItem("cliStatusInterval",this.value)});document.getElementById("promptModal")?.addEventListener("click",e=>G(e));document.querySelector("#promptModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.querySelector('[data-action="closePrompt"]')?.addEventListener("click",()=>G());document.querySelector('[data-action="cancelPrompt"]')?.addEventListener("click",()=>G());document.querySelector('[data-action="savePrompt"]')?.addEventListener("click",bt);document.addEventListener("keydown",e=>{e.key==="Escape"&&!c.isRecording&&G()});document.querySelector('[data-action="openTemplates"]')?.addEventListener("click",xt);document.querySelector('[data-action="saveTemplate"]')?.addEventListener("click",Mt);document.querySelector('[data-action="closeTemplate"]')?.addEventListener("click",()=>Be());document.getElementById("templateModal")?.addEventListener("click",e=>Be(e));document.querySelector("#templateModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.getElementById("templateBack")?.addEventListener("click",St);document.getElementById("templateDevToggle")?.addEventListener("click",Lt);document.getElementById("heartbeatModal")?.addEventListener("click",e=>Nt(e));document.querySelector("#heartbeatModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.querySelector('[data-action="closeHeartbeat"]')?.addEventListener("click",()=>Nt());document.querySelector('[data-action="addHeartbeat"]')?.addEventListener("click",zn);document.getElementById("hbJobsList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-hb-toggle]");if(t){Un(+(t.dataset.hbToggle||"0"));return}let n=e.target?.closest("[data-hb-remove]");if(n){Jn(+(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,N();return}let o=t.closest("[data-hb-minutes]");if(o){c.heartbeatJobs[+(o.dataset.hbMinutes||"0")].schedule={kind:"every",minutes:+t.value},N();return}let i=t.closest("[data-hb-prompt]");if(i){c.heartbeatJobs[+(i.dataset.hbPrompt||"0")].prompt=t.value,N();return}});document.getElementById("memoryModal")?.addEventListener("click",e=>qt(e));document.querySelector("#memoryModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.querySelector('[data-action="closeMemory"]')?.addEventListener("click",()=>qt());document.getElementById("memTabBtnSettings")?.addEventListener("click",()=>Kt("settings"));document.getElementById("memTabBtnFiles")?.addEventListener("click",()=>Kt("files"));document.getElementById("memOn")?.addEventListener("click",()=>zt(!0));document.getElementById("memOff")?.addEventListener("click",()=>zt(!1));document.getElementById("memFlushEvery")?.addEventListener("change",ue);document.getElementById("memCli")?.addEventListener("change",ue);document.getElementById("memModel")?.addEventListener("change",ue);document.getElementById("memRetention")?.addEventListener("change",ue);document.getElementById("memFilesList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-mem-delete]");if(t){e.stopPropagation(),Gn(t.dataset.memDelete||"");return}let n=e.target?.closest("[data-mem-view]");if(n){Vn(n.dataset.memView||"");return}if(e.target?.closest("[data-mem-back]")){De();return}});async function jo(){await En();let e=document.getElementById("langToggle");e&&(e.textContent=`\u{1F310} ${d("lang."+ce())}`),await fe(),_o(),Ft(),Nn(),jn(),await nt(),await mt(),ae(),Pt(),Ke(),Wn(),Hn(),Qn(),Zn(),Rt()}jo().catch(e=>{console.error("[bootstrap]",e)});document.addEventListener("keydown",e=>{if(e.key==="Escape"){if(c.isRecording){e.preventDefault(),Vt();return}document.querySelectorAll(".modal-overlay.open").forEach(t=>{t.classList.remove("open")})}(e.ctrlKey||e.metaKey)&&e.shiftKey&&e.code==="Space"&&(e.preventDefault(),Qt())});document.getElementById("mobileMenuLeft")?.addEventListener("click",Ut);document.getElementById("mobileMenuRight")?.addEventListener("click",Wt);
|
|
139
|
+
`)}B();ve();Bt();var Jt="sidebarState";function Qn(){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",Ut),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(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");Fe()}),window.innerWidth<=900&&document.body.classList.remove("left-collapsed","right-collapsed"),Fe()}function _e(){return window.innerWidth<=900}function Ut(){_e()?document.body.classList.toggle("left-expanded"):document.body.classList.toggle("left-collapsed"),Yn(),Fe()}function Wt(){_e()?document.body.classList.toggle("right-expanded"):document.body.classList.toggle("right-collapsed"),Yn(),Fe()}function $o(){return _e()?document.body.classList.contains("left-expanded"):!document.body.classList.contains("left-collapsed")}function Ho(){return _e()?document.body.classList.contains("right-expanded"):!document.body.classList.contains("right-collapsed")}function Fe(){let e=document.getElementById("toggleLeft"),t=document.getElementById("toggleRight");e&&(e.textContent=$o()?"\u25C0":"\u25B6"),t&&(t.textContent=Ho()?"\u25B6":"\u25C0")}function Yn(){localStorage.setItem(Jt,JSON.stringify({left:document.body.classList.contains("left-collapsed"),right:document.body.classList.contains("right-collapsed")}))}var Xn="theme",Ao="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.11.1/styles/github-dark.min.css",Po="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.11.1/styles/github.min.css";function Zn(){let e=localStorage.getItem(Xn),t=window.matchMedia("(prefers-color-scheme: light)").matches?"light":"dark";eo(e||t),document.getElementById("toggleTheme")?.addEventListener("click",Ro)}function Ro(){let t=(document.documentElement.getAttribute("data-theme")||"dark")==="dark"?"light":"dark";eo(t),localStorage.setItem(Xn,t)}function eo(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"?Ao:Po)}T();B();N();T();var Vt=!1,S=null,pe=[],Ne=null,je=null,no=0;function Oo(){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 Do(e){let t=e;switch(t.name){case"NotAllowedError":return m("voice.micDenied");case"NotFoundError":return m("voice.micNotFound");case"NotReadableError":case"AbortError":return m("voice.micBusy");default:return t instanceof TypeError||!navigator.mediaDevices?m("voice.httpsRequired"):m("voice.micDenied")}}async function Fo(){if(d.isRecording)return;if(typeof MediaRecorder>"u"||!navigator.mediaDevices?.getUserMedia){b(m("voice.unsupported"),"","error");return}try{Ne=await navigator.mediaDevices.getUserMedia({audio:!0})}catch(n){b(Do(n),"","error");return}let e=Oo(),t=e?{mimeType:e}:{};S=new MediaRecorder(Ne,t),pe=[],S.ondataavailable=n=>{n.data.size>0&&pe.push(n.data)},S.onerror=()=>{oo(),b(m("voice.interrupted"),"","error")},S.onstop=async()=>{if(Vt){pe=[],to(),Vt=!1;return}let n=S?.mimeType||e||"audio/webm",o=n.includes("mp4")?".m4a":n.includes("ogg")?".ogg":".webm",i=new Blob(pe,{type:n});if(pe=[],to(),i.size>20*1024*1024){b(m("voice.tooLarge"),"","error");return}if(i.size<1e3){b(m("voice.tooShort"),"","error");return}await qn(i,o,n)},S.start(),d.isRecording=!0,no=Date.now(),Yt(!0),_o()}function oo(){!d.isRecording||!S||(S.state==="recording"&&S.stop(),d.isRecording=!1,io(),Yt(!1))}function Gt(){!d.isRecording||!S||(Vt=!0,S.state==="recording"&&S.stop(),d.isRecording=!1,io(),Yt(!1))}function Qt(){d.isRecording?oo():Fo()}function to(){Ne?.getTracks().forEach(e=>e.stop()),Ne=null}function _o(){let e=document.getElementById("voiceTimer");e&&(e.style.display="inline",je=setInterval(()=>{let t=Math.floor((Date.now()-no)/1e3),n=String(Math.floor(t/60)).padStart(2,"0"),o=String(t%60).padStart(2,"0");e.textContent=`${n}:${o}`},500))}function io(){je&&(clearInterval(je),je=null);let e=document.getElementById("voiceTimer");e&&(e.style.display="none",e.textContent="00:00")}function Yt(e){let t=document.getElementById("btnVoice"),n=document.getElementById("btnVoiceCancel");t&&(t.classList.toggle("recording",e),t.textContent=e?"\u23F9":"\u{1F3A4}",t.title=e?m("voice.stop"):m("voice.start")),n&&(n.style.display=e?"inline-block":"none")}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",Re);var Xt=document.getElementById("chatInput");Xt?.addEventListener("keydown",e=>{ot(e)||On(e)});var qe=0;Xt?.addEventListener("input",e=>{e.isComposing||(qe&&cancelAnimationFrame(qe),qe=requestAnimationFrame(()=>{Me(e.target?.value||""),qe=0}))});Xt?.addEventListener("cmd-execute",()=>{Re()});document.getElementById("cmdDropdown")?.addEventListener("click",it);document.addEventListener("click",at);document.getElementById("filePreviewClear")?.addEventListener("click",me);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("btnVoice")?.addEventListener("click",()=>Qt());document.getElementById("btnVoiceCancel")?.addEventListener("click",()=>Gt());document.getElementById("memorySidebarBtn")?.addEventListener("click",De);document.getElementById("btnClearChat")?.addEventListener("click",_n);document.getElementById("hbSidebarBtn")?.addEventListener("click",zn);document.getElementById("langToggle")?.addEventListener("click",async()=>{let e=ce()==="ko"?"en":"ko";await Ln(e);let t=document.getElementById("langToggle");t&&(t.textContent=`\u{1F310} ${m("lang."+e)}`),d.ws&&d.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]&&Ht(i[o],t)});document.querySelector(".sidebar-save-bar .btn-save")?.addEventListener("click",At);document.getElementById("selCli")?.addEventListener("change",()=>Ie());document.getElementById("selModel")?.addEventListener("change",()=>V());document.getElementById("selEffort")?.addEventListener("change",()=>V());document.querySelector('[data-action="addEmployee"]')?.addEventListener("click",Ke);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){D(n.dataset.empName||"",{name:t.value});return}let o=t.closest("[data-emp-cli]");if(o){Ue(o.dataset.empCli||"",t.value);return}let i=t.closest("[data-emp-model]");if(i){if(t.value==="__custom__"){let l=prompt(m("model.promptInput"));if(l?.trim()){let c=document.createElement("option");c.value=l.trim(),c.textContent=l.trim();let r=t.querySelector('option[value="__custom__"]');r&&t.insertBefore(c,r),t.value=l.trim(),D(i.dataset.empModel||"",{model:l.trim()})}else t.value="default"}else D(i.dataset.empModel||"",{model:t.value});return}let a=t.closest("[data-emp-role]");if(a){We(a.dataset.empRole||"",t.value);return}let s=t.closest("[data-emp-custom]");if(s){D(s.dataset.empCustom||"",{role:t.value});return}});document.getElementById("skillsList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-skill-id]");t&&Qe(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";Ye(n,t)}});document.querySelector('[data-action="openPrompt"]')?.addEventListener("click",ht);document.getElementById("tgOff")?.addEventListener("click",()=>ke(!1));document.getElementById("tgOn")?.addEventListener("click",()=>ke(!0));document.getElementById("tgForwardOff")?.addEventListener("click",()=>we(!1));document.getElementById("tgForwardOn")?.addEventListener("click",()=>we(!0));document.getElementById("tgToken")?.addEventListener("change",Se);document.getElementById("tgChatIds")?.addEventListener("change",Se);document.getElementById("fallbackOrderList")?.addEventListener("change",vt);function ao(e){let t=document.getElementById("codexFastOn"),n=document.getElementById("codexFastOff");t&&n&&(t.classList.toggle("active",e),n.classList.toggle("active",!e)),A()}document.getElementById("codexFastOn")?.addEventListener("click",()=>ao(!0));document.getElementById("codexFastOff")?.addEventListener("click",()=>ao(!1));function so(e){let t=document.getElementById("codexCtxOn"),n=document.getElementById("codexCtxOff"),o=document.getElementById("codexCtxValues");t&&n&&(t.classList.toggle("active",e),n.classList.toggle("active",!e)),o&&(o.style.display=e?"":"none"),A()}document.getElementById("codexCtxOn")?.addEventListener("click",()=>so(!0));document.getElementById("codexCtxOff")?.addEventListener("click",()=>so(!1));document.getElementById("codexCtxWindow")?.addEventListener("change",A);document.getElementById("codexCtxCompact")?.addEventListener("change",A);function jo(){for(let e of O()){let t=e.charAt(0).toUpperCase()+e.slice(1),n=document.getElementById("model"+t);n&&n.addEventListener("change",function(){ft(e,this)});let o=document.getElementById("customModel"+t);o&&o.addEventListener("change",function(){yt(e,this)});let i=document.getElementById("effort"+t);i&&i.addEventListener("change",A)}}document.querySelector('[data-action="syncMcp"]')?.addEventListener("click",pt);document.querySelector('[data-action="installMcp"]')?.addEventListener("click",gt);document.querySelector('[data-action="refreshCli"]')?.addEventListener("click",()=>ae(!0));document.getElementById("cliStatusInterval")?.addEventListener("change",function(){localStorage.setItem("cliStatusInterval",this.value)});document.getElementById("promptModal")?.addEventListener("click",e=>G(e));document.querySelector("#promptModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.querySelector('[data-action="closePrompt"]')?.addEventListener("click",()=>G());document.querySelector('[data-action="cancelPrompt"]')?.addEventListener("click",()=>G());document.querySelector('[data-action="savePrompt"]')?.addEventListener("click",Et);document.addEventListener("keydown",e=>{e.key==="Escape"&&!d.isRecording&&G()});document.querySelector('[data-action="openTemplates"]')?.addEventListener("click",xt);document.querySelector('[data-action="saveTemplate"]')?.addEventListener("click",Mt);document.querySelector('[data-action="closeTemplate"]')?.addEventListener("click",()=>Be());document.getElementById("templateModal")?.addEventListener("click",e=>Be(e));document.querySelector("#templateModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.getElementById("templateBack")?.addEventListener("click",It);document.getElementById("templateDevToggle")?.addEventListener("click",Lt);document.getElementById("heartbeatModal")?.addEventListener("click",e=>Nt(e));document.querySelector("#heartbeatModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.querySelector('[data-action="closeHeartbeat"]')?.addEventListener("click",()=>Nt());document.querySelector('[data-action="addHeartbeat"]')?.addEventListener("click",Kn);document.getElementById("hbJobsList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-hb-toggle]");if(t){Un(+(t.dataset.hbToggle||"0"));return}let n=e.target?.closest("[data-hb-remove]");if(n){Jn(+(n.dataset.hbRemove||"0"));return}});document.getElementById("hbJobsList")?.addEventListener("change",e=>{let t=e.target,n=t.closest("[data-hb-name]");if(n){d.heartbeatJobs[+(n.dataset.hbName||"0")].name=t.value,z();return}let o=t.closest("[data-hb-minutes]");if(o){d.heartbeatJobs[+(o.dataset.hbMinutes||"0")].schedule={kind:"every",minutes:+t.value},z();return}let i=t.closest("[data-hb-prompt]");if(i){d.heartbeatJobs[+(i.dataset.hbPrompt||"0")].prompt=t.value,z();return}});document.getElementById("memoryModal")?.addEventListener("click",e=>qt(e));document.querySelector("#memoryModal .modal-box")?.addEventListener("click",e=>e.stopPropagation());document.querySelector('[data-action="closeMemory"]')?.addEventListener("click",()=>qt());document.getElementById("memTabBtnSettings")?.addEventListener("click",()=>zt("settings"));document.getElementById("memTabBtnFiles")?.addEventListener("click",()=>zt("files"));document.getElementById("memOn")?.addEventListener("click",()=>Kt(!0));document.getElementById("memOff")?.addEventListener("click",()=>Kt(!1));document.getElementById("memFlushEvery")?.addEventListener("change",ue);document.getElementById("memCli")?.addEventListener("change",ue);document.getElementById("memModel")?.addEventListener("change",ue);document.getElementById("memRetention")?.addEventListener("change",ue);document.getElementById("memFilesList")?.addEventListener("click",e=>{let t=e.target?.closest("[data-mem-delete]");if(t){e.stopPropagation(),Vn(t.dataset.memDelete||"");return}let n=e.target?.closest("[data-mem-view]");if(n){Gn(n.dataset.memView||"");return}if(e.target?.closest("[data-mem-back]")){De();return}});async function No(){await bn();let e=document.getElementById("langToggle");e&&(e.textContent=`\u{1F310} ${m("lang."+ce())}`),await fe(),jo(),Ft(),Nn(),jn(),await nt(),await mt(),ae(),Pt(),ze(),Wn(),Hn(),Qn(),Zn(),Rt()}No().catch(e=>{console.error("[bootstrap]",e)});document.addEventListener("keydown",e=>{if(e.key==="Escape"){if(d.isRecording){e.preventDefault(),Gt();return}document.querySelectorAll(".modal-overlay.open").forEach(t=>{t.classList.remove("open")})}(e.ctrlKey||e.metaKey)&&e.shiftKey&&e.code==="Space"&&(e.preventDefault(),Qt())});document.getElementById("mobileMenuLeft")?.addEventListener("click",Ut);document.getElementById("mobileMenuRight")?.addEventListener("click",Wt);
|
|
140
140
|
//# sourceMappingURL=bundle.js.map
|