cli-jaw 1.6.6 → 1.6.8

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "cli-jaw",
3
- "version": "1.6.6",
3
+ "version": "1.6.8",
4
4
  "description": "Personal AI assistant powered by 5 engines (Claude, Codex, Gemini, OpenCode, Copilot) — Web, Terminal, Telegram, and Discord interfaces with 107 built-in skills",
5
5
  "type": "module",
6
6
  "keywords": [
@@ -1,4 +1,4 @@
1
- import{t as e}from"./state-O6NVkWcL.js";import{m as t,n,o as r}from"./render-C5gpc065.js";import{n as i,r as a,t as o}from"./api-Ci-lgwRp.js";import{n as s}from"./ws-CDrAtY9-.js";import{n as c,r as l,t as u}from"./constants-C8_0OtK2.js";var d={"React/Vue 기반 UI 컴포넌트 개발, 스타일링":`frontend`,"API 서버, DB 스키마, 비즈니스 로직 구현":`backend`,"프론트엔드와 백엔드 모두 담당":`frontend`,"CI/CD, Docker, 인프라 자동화":`backend`,"테스트 작성, 버그 재현, 품질 관리":`custom`,"데이터 파이프라인, ETL, 분석 쿼리":`data`,"API 문서화, README, 가이드 작성":`docs`,"UI/UX 구현, CSS, 컴포넌트 개발":`frontend`,"API, DB, 서버 로직 구현":`backend`,"데이터 파이프라인, 분석, ML":`data`,"문서화, README, API docs":`docs`,"UI/UX, CSS, components":`frontend`,"API, DB, server logic":`backend`,"Search, codebase exploration, uncertainty reduction, read-only reports":`research`,"Search, codebase exploration, uncertainty reduction, read-only":`research`,"Data pipeline, analysis, ML":`data`,"Documentation, README, API docs":`docs`},f={1:`#60a5fa`,2:`#a78bfa`,3:`#34d399`,4:`#fbbf24`,5:`#f472b6`};async function p(){e.employees=await o(`/api/employees`)||[],m()}function m(){let i=document.getElementById(`employeesList`);if(!i)return;let a=e.employees;if(a.length===0){i.innerHTML=`<div style="color:var(--text-dim);font-size:11px;padding:4px 0">${t(`emp.addPrompt`)}</div>`;return}let o=l();i.innerHTML=a.map(e=>{let i=u[e.cli]||[],a=d[e.role||``],l=a?c.find(e=>e.value===a):c.find(t=>t.prompt===e.role),p=l?l.value:e.role?`custom`:`frontend`,m=p===`custom`,h=s(e.id),g=h?.phase||e.phase,_=h?.phaseLabel||e.phaseLabel,v=g?`<span style="background:${f[g]||`#888`};color:#000;padding:1px 6px;border-radius:9px;font-size:9px">${n(_||`P`+g)}</span>`:``;return`
1
+ import{t as e}from"./state-O6NVkWcL.js";import{m as t,n,o as r}from"./render-DIojC86t.js";import{n as i,r as a,t as o}from"./api-Ci-lgwRp.js";import{n as s}from"./ws-CWswsLQB.js";import{n as c,r as l,t as u}from"./constants-C8_0OtK2.js";var d={"React/Vue 기반 UI 컴포넌트 개발, 스타일링":`frontend`,"API 서버, DB 스키마, 비즈니스 로직 구현":`backend`,"프론트엔드와 백엔드 모두 담당":`frontend`,"CI/CD, Docker, 인프라 자동화":`backend`,"테스트 작성, 버그 재현, 품질 관리":`custom`,"데이터 파이프라인, ETL, 분석 쿼리":`data`,"API 문서화, README, 가이드 작성":`docs`,"UI/UX 구현, CSS, 컴포넌트 개발":`frontend`,"API, DB, 서버 로직 구현":`backend`,"데이터 파이프라인, 분석, ML":`data`,"문서화, README, API docs":`docs`,"UI/UX, CSS, components":`frontend`,"API, DB, server logic":`backend`,"Search, codebase exploration, uncertainty reduction, read-only reports":`research`,"Search, codebase exploration, uncertainty reduction, read-only":`research`,"Data pipeline, analysis, ML":`data`,"Documentation, README, API docs":`docs`},f={1:`#60a5fa`,2:`#a78bfa`,3:`#34d399`,4:`#fbbf24`,5:`#f472b6`};async function p(){e.employees=await o(`/api/employees`)||[],m()}function m(){let i=document.getElementById(`employeesList`);if(!i)return;let a=e.employees;if(a.length===0){i.innerHTML=`<div style="color:var(--text-dim);font-size:11px;padding:4px 0">${t(`emp.addPrompt`)}</div>`;return}let o=l();i.innerHTML=a.map(e=>{let i=u[e.cli]||[],a=d[e.role||``],l=a?c.find(e=>e.value===a):c.find(t=>t.prompt===e.role),p=l?l.value:e.role?`custom`:`frontend`,m=p===`custom`,h=s(e.id),g=h?.phase||e.phase,_=h?.phaseLabel||e.phaseLabel,v=g?`<span style="background:${f[g]||`#888`};color:#000;padding:1px 6px;border-radius:9px;font-size:9px">${n(_||`P`+g)}</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>
@@ -1,10 +1,10 @@
1
1
  const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/vendor-render-Bjnw0wQ6.css"])))=>i.map(i=>d[i]);
2
- import{n as e,t}from"./vendor-render-D2YP6GiF.js";import{t as n}from"./state-O6NVkWcL.js";import{Z as r}from"./vendor-mermaid-lvHqQdfg.js";import{d as i,f as a,i as o,l as s,m as c,n as l,o as u,p as d,t as f}from"./render-C5gpc065.js";import{_ as ee,g as te,h as ne,n as p,o as re,p as ie,s as ae,t as m,v as oe}from"./ui-ORW7tzea.js";import{n as se,r as h,t as g}from"./api-Ci-lgwRp.js";import{t as ce}from"./ws-CDrAtY9-.js";import{t as le}from"./locale-DIXc-_34.js";import{a as ue,i as de,n as fe,o as pe,r as me,t as he}from"./slash-commands-D_tV86er.js";import{i as ge,t as _e}from"./skills-DL7wTirZ.js";import{a as ve,r as ye}from"./constants-C8_0OtK2.js";import{A as be,D as xe,E as Se,M as Ce,N as we,O as Te,S as Ee,T as De,a as Oe,b as ke,c as Ae,f as je,g as _,h as Me,i as Ne,j as Pe,k as Fe,l as Ie,m as Le,n as Re,o as ze,p as Be,r as Ve,s as He,t as v,u as Ue,w as We,y as Ge}from"./settings-BbG1hQmA.js";var y=[];function Ke(e){return/^\/compact(?:\s|$)/i.test(String(e||``).trim())?300*1e3:1e4}async function b(){let e=document.getElementById(`chatInput`),t=document.getElementById(`btnSend`);if(!e||!t)return;let i=document.activeElement===t;if(t.classList.contains(`stop-mode`)&&i&&!e.value.trim()&&!n.attachedFiles.length){se(`/api/stop`,`POST`);return}let a=e.value.trim();if(!a&&!n.attachedFiles.length)return;let o=a.slice(1).trim().split(/\s+/)[0]||``,s=o.includes(`/`)||o.includes(`\\`);if(a.startsWith(`/`)&&!n.attachedFiles.length&&!s){e.value=``,w(),he();try{let e,t,n=Ke(a);if(typeof AbortSignal?.timeout==`function`)e=AbortSignal.timeout(n);else{let r=new AbortController;e=r.signal,t=setTimeout(()=>r.abort(),n)}let r=le(),i=await fetch(`/api/command`,{method:`POST`,headers:{"Content-Type":`application/json`,"Accept-Language":r},body:JSON.stringify({text:a,locale:r}),signal:e});t&&clearTimeout(t);let o=await i.json().catch(()=>({}));if(o?.code===`not_command`){m(`user`,a),await h(`/api/message`,`POST`,{prompt:a});return}if(!i.ok&&!o?.text)throw Error(`HTTP ${i.status}`);if(o?.code===`clear_screen`){f(),te().clear();let e=document.getElementById(`chatMessages`);e&&(e.innerHTML=``)}o?.text&&p(l(o.text),``,o.type)}catch(e){p(c(`chat.cmd.fail`,{msg:e.message}),``,`error`)}return}if(n.attachedFiles.length){m(`user`,`📎 [${n.attachedFiles.map(e=>e.name).join(`, `)}] ${a}`),e.value=``,w();try{let e=(await Promise.all(n.attachedFiles.map(e=>Je(e)))).map(e=>c(`chat.file.sent`,{path:e})).join(`
3
- `);a&&(e+=c(`chat.file.sentWithMsg`,{text:a})),S(),await h(`/api/message`,`POST`,{prompt:e})}catch(e){p(c(`chat.file.uploadFail`,{msg:e.message})),S()}}else{m(`user`,a),e.value=``,w();let t=await fetch(`/api/message`,{method:`POST`,headers:{"Content-Type":`application/json`},body:JSON.stringify({prompt:a})}),n=await t.json().catch(()=>({}));if(!t.ok){p(`${u.error} ${l(n.error||c(`chat.requestFail`,{status:t.status}))}`,``,`error`);return}if(n.queued){let{updateQueueBadge:e}=await r(async()=>{let{updateQueueBadge:e}=await import(`./ui-ByJAyywC.js`);return{updateQueueBadge:e}},__vite__mapDeps([0]));e(n.pending||1)}else n.continued&&p(c(`chat.continue`))}}function qe(e){e.key===`Enter`&&!e.shiftKey&&!e.isComposing&&(e.preventDefault(),b())}async function Je(e){let t=await fetch(`/api/upload`,{method:`POST`,headers:{"X-Filename":encodeURIComponent(e.name)},body:e});if(!t.ok)throw Error(`upload failed`);return(await t.json()).path}function x(e){for(let t of e)n.attachedFiles.some(e=>e.name===t.name)||n.attachedFiles.push(t);C(),document.getElementById(`chatInput`)?.focus()}function Ye(e){n.attachedFiles.splice(e,1),C()}function S(){y.forEach(e=>URL.revokeObjectURL(e)),y=[],n.attachedFiles=[],C();let e=document.getElementById(`fileInput`);e&&(e.value=``)}function C(){let e=document.getElementById(`filePreview`),t=document.getElementById(`filePreviewList`);if(e){if(y.forEach(e=>URL.revokeObjectURL(e)),y=[],!n.attachedFiles.length){e.classList.remove(`visible`),t&&(t.innerHTML=``);return}e.classList.add(`visible`),t&&(t.innerHTML=n.attachedFiles.map((e,t)=>{let n=(e.size/1024).toFixed(1),r=e.type.startsWith(`image/`),i=``;if(r){let t=URL.createObjectURL(e);y.push(t),i=`<img src="${t}" class="file-chip-thumb" alt="">`}return`<div class="file-chip">
2
+ import{n as e,t}from"./vendor-render-D2YP6GiF.js";import{t as n}from"./state-O6NVkWcL.js";import{Z as r}from"./vendor-mermaid-lvHqQdfg.js";import{d as i,f as a,i as o,l as s,m as c,n as l,o as u,p as d,t as f}from"./render-DIojC86t.js";import{_ as ee,g as te,h as ne,n as p,o as re,p as ie,s as ae,t as m,v as oe}from"./ui-Drug8_7N.js";import{n as se,r as h,t as g}from"./api-Ci-lgwRp.js";import{t as ce}from"./ws-CWswsLQB.js";import{t as le}from"./locale-DIXc-_34.js";import{a as ue,i as de,n as fe,o as pe,r as me,t as he}from"./slash-commands-cmcn-EJn.js";import{i as ge,t as _e}from"./skills-74SoDe9K.js";import{a as ve,r as ye}from"./constants-C8_0OtK2.js";import{A as be,D as xe,E as Se,M as Ce,N as we,O as Te,S as Ee,T as De,a as Oe,b as ke,c as Ae,f as je,g as _,h as Me,i as Ne,j as Pe,k as Fe,l as Ie,m as Le,n as Re,o as ze,p as Be,r as Ve,s as He,t as v,u as Ue,w as We,y as Ge}from"./settings-B5D4wxWj.js";var y=[];function Ke(e){return/^\/compact(?:\s|$)/i.test(String(e||``).trim())?300*1e3:1e4}async function b(){let e=document.getElementById(`chatInput`),t=document.getElementById(`btnSend`);if(!e||!t)return;let i=document.activeElement===t;if(t.classList.contains(`stop-mode`)&&i&&!e.value.trim()&&!n.attachedFiles.length){se(`/api/stop`,`POST`);return}let a=e.value.trim();if(!a&&!n.attachedFiles.length)return;let o=a.slice(1).trim().split(/\s+/)[0]||``,s=o.includes(`/`)||o.includes(`\\`);if(a.startsWith(`/`)&&!n.attachedFiles.length&&!s){e.value=``,w(),he();try{let e,t,n=Ke(a);if(typeof AbortSignal?.timeout==`function`)e=AbortSignal.timeout(n);else{let r=new AbortController;e=r.signal,t=setTimeout(()=>r.abort(),n)}let r=le(),i=await fetch(`/api/command`,{method:`POST`,headers:{"Content-Type":`application/json`,"Accept-Language":r},body:JSON.stringify({text:a,locale:r}),signal:e});t&&clearTimeout(t);let o=await i.json().catch(()=>({}));if(o?.code===`not_command`){m(`user`,a),await h(`/api/message`,`POST`,{prompt:a});return}if(!i.ok&&!o?.text)throw Error(`HTTP ${i.status}`);if(o?.code===`clear_screen`){f(),te().clear();let e=document.getElementById(`chatMessages`);e&&(e.innerHTML=``)}o?.text&&p(l(o.text),``,o.type)}catch(e){p(c(`chat.cmd.fail`,{msg:e.message}),``,`error`)}return}if(n.attachedFiles.length){m(`user`,`📎 [${n.attachedFiles.map(e=>e.name).join(`, `)}] ${a}`),e.value=``,w();try{let e=(await Promise.all(n.attachedFiles.map(e=>Je(e)))).map(e=>c(`chat.file.sent`,{path:e})).join(`
3
+ `);a&&(e+=c(`chat.file.sentWithMsg`,{text:a})),S(),await h(`/api/message`,`POST`,{prompt:e})}catch(e){p(c(`chat.file.uploadFail`,{msg:e.message})),S()}}else{m(`user`,a),e.value=``,w();let t=await fetch(`/api/message`,{method:`POST`,headers:{"Content-Type":`application/json`},body:JSON.stringify({prompt:a})}),n=await t.json().catch(()=>({}));if(!t.ok){p(`${u.error} ${l(n.error||c(`chat.requestFail`,{status:t.status}))}`,``,`error`);return}if(n.queued){let{updateQueueBadge:e}=await r(async()=>{let{updateQueueBadge:e}=await import(`./ui-DWkhzfMp.js`);return{updateQueueBadge:e}},__vite__mapDeps([0]));e(n.pending||1)}else n.continued&&p(c(`chat.continue`))}}function qe(e){e.key===`Enter`&&!e.shiftKey&&!e.isComposing&&(e.preventDefault(),b())}async function Je(e){let t=await fetch(`/api/upload`,{method:`POST`,headers:{"X-Filename":encodeURIComponent(e.name)},body:e});if(!t.ok)throw Error(`upload failed`);return(await t.json()).path}function x(e){for(let t of e)n.attachedFiles.some(e=>e.name===t.name)||n.attachedFiles.push(t);C(),document.getElementById(`chatInput`)?.focus()}function Ye(e){n.attachedFiles.splice(e,1),C()}function S(){y.forEach(e=>URL.revokeObjectURL(e)),y=[],n.attachedFiles=[],C();let e=document.getElementById(`fileInput`);e&&(e.value=``)}function C(){let e=document.getElementById(`filePreview`),t=document.getElementById(`filePreviewList`);if(e){if(y.forEach(e=>URL.revokeObjectURL(e)),y=[],!n.attachedFiles.length){e.classList.remove(`visible`),t&&(t.innerHTML=``);return}e.classList.add(`visible`),t&&(t.innerHTML=n.attachedFiles.map((e,t)=>{let n=(e.size/1024).toFixed(1),r=e.type.startsWith(`image/`),i=``;if(r){let t=URL.createObjectURL(e);y.push(t),i=`<img src="${t}" class="file-chip-thumb" alt="">`}return`<div class="file-chip">
4
4
  ${i}
5
5
  <span class="file-chip-name">${u.paperclip} ${l(e.name)} (${n}KB)</span>
6
6
  <button class="file-chip-remove" data-file-idx="${t}" title="Remove">${u.close}</button>
7
- </div>`}).join(``))}}async function Xe(){se(`/api/clear`,`POST`),f(),te().clear();let e=document.getElementById(`chatMessages`);e&&(e.innerHTML=``);let{cleanupToolActivity:t}=await r(async()=>{let{cleanupToolActivity:e}=await import(`./ui-ByJAyywC.js`);return{cleanupToolActivity:e}},__vite__mapDeps([0]));t(),ee().catch(()=>{})}var Ze=0;function Qe(e){Ze||=requestAnimationFrame(()=>{Ze=0,e.style.height=`auto`,e.style.height=e.scrollHeight+`px`})}function $e(){let e=document.getElementById(`chatInput`);e&&e.addEventListener(`input`,()=>Qe(e))}function w(){let e=document.getElementById(`chatInput`);e&&(e.style.height=`auto`)}function et(){let e=document.querySelector(`.chat-area`),t=document.getElementById(`dragOverlay`);if(!e||!t)return;let n=0;e.addEventListener(`dragenter`,e=>{e.preventDefault(),n++,t.classList.add(`visible`)}),e.addEventListener(`dragleave`,e=>{e.preventDefault(),n--,n<=0&&(n=0,t.classList.remove(`visible`))}),e.addEventListener(`dragover`,e=>e.preventDefault()),e.addEventListener(`drop`,e=>{e.preventDefault(),n=0,t.classList.remove(`visible`);let r=[...e.dataTransfer?.files||[]];r.length&&x(r)}),document.getElementById(`fileInput`)?.addEventListener(`change`,e=>{let t=e.target,n=[...t.files||[]];n.length&&x(n),t.value=``}),document.addEventListener(`paste`,e=>{let t=e.clipboardData?.items;if(!t)return;let n=[];for(let e of t){if(e.kind!==`file`)continue;let t=e.getAsFile();if(t)if(!t.name||t.name===`image.png`){let e=new Date().toISOString().replace(/[:.]/g,`-`),r=t.type.split(`/`)[1]||`png`,i=new File([t],`pasted-${e}.${r}`,{type:t.type});n.push(i)}else n.push(t)}n.length&&(e.preventDefault(),x(n))})}async function tt(e,t,r){let i=document.getElementById(`chatInput`),a=i?.value.trim()||``,o=[...n.attachedFiles],s=[`🎤 [음성 메시지]`];o.length&&s.push(`📎 [${o.map(e=>e.name).join(`, `)}]`),a&&s.push(a),m(`user`,s.join(` `)),i&&a&&(i.value=``,w()),o.length&&S();try{let n=await fetch(`/api/voice`,{method:`POST`,headers:{"Content-Type":r,"X-Voice-Ext":t,"X-STT-Only":`true`},body:e});if(!n.ok){let e=await n.json().catch(()=>({}));throw Error(e.error||`HTTP ${n.status}`)}let i=await n.json().catch(()=>null);if(!i?.text)throw Error(`Empty STT result`);p(`${u.mic} STT (${l(i.engine||``)}, ${i.elapsed?.toFixed(1)}s): "${l(i.text.slice(0,100))}"`,``,`info`);let s=[];o.length&&(s=await Promise.all(o.map(e=>Je(e))));let d=[];for(let e of s)d.push(c(`chat.file.sent`,{path:e}));d.push(`🎤 ${i.text}`),a&&d.push(a),await h(`/api/message`,`POST`,{prompt:d.join(`
7
+ </div>`}).join(``))}}async function Xe(){se(`/api/clear`,`POST`),f(),te().clear();let e=document.getElementById(`chatMessages`);e&&(e.innerHTML=``);let{cleanupToolActivity:t}=await r(async()=>{let{cleanupToolActivity:e}=await import(`./ui-DWkhzfMp.js`);return{cleanupToolActivity:e}},__vite__mapDeps([0]));t(),ee().catch(()=>{})}var Ze=0;function Qe(e){Ze||=requestAnimationFrame(()=>{Ze=0,e.style.height=`auto`,e.style.height=e.scrollHeight+`px`})}function $e(){let e=document.getElementById(`chatInput`);e&&e.addEventListener(`input`,()=>Qe(e))}function w(){let e=document.getElementById(`chatInput`);e&&(e.style.height=`auto`)}function et(){let e=document.querySelector(`.chat-area`),t=document.getElementById(`dragOverlay`);if(!e||!t)return;let n=0;e.addEventListener(`dragenter`,e=>{e.preventDefault(),n++,t.classList.add(`visible`)}),e.addEventListener(`dragleave`,e=>{e.preventDefault(),n--,n<=0&&(n=0,t.classList.remove(`visible`))}),e.addEventListener(`dragover`,e=>e.preventDefault()),e.addEventListener(`drop`,e=>{e.preventDefault(),n=0,t.classList.remove(`visible`);let r=[...e.dataTransfer?.files||[]];r.length&&x(r)}),document.getElementById(`fileInput`)?.addEventListener(`change`,e=>{let t=e.target,n=[...t.files||[]];n.length&&x(n),t.value=``}),document.addEventListener(`paste`,e=>{let t=e.clipboardData?.items;if(!t)return;let n=[];for(let e of t){if(e.kind!==`file`)continue;let t=e.getAsFile();if(t)if(!t.name||t.name===`image.png`){let e=new Date().toISOString().replace(/[:.]/g,`-`),r=t.type.split(`/`)[1]||`png`,i=new File([t],`pasted-${e}.${r}`,{type:t.type});n.push(i)}else n.push(t)}n.length&&(e.preventDefault(),x(n))})}async function tt(e,t,r){let i=document.getElementById(`chatInput`),a=i?.value.trim()||``,o=[...n.attachedFiles],s=[`🎤 [음성 메시지]`];o.length&&s.push(`📎 [${o.map(e=>e.name).join(`, `)}]`),a&&s.push(a),m(`user`,s.join(` `)),i&&a&&(i.value=``,w()),o.length&&S();try{let n=await fetch(`/api/voice`,{method:`POST`,headers:{"Content-Type":r,"X-Voice-Ext":t,"X-STT-Only":`true`},body:e});if(!n.ok){let e=await n.json().catch(()=>({}));throw Error(e.error||`HTTP ${n.status}`)}let i=await n.json().catch(()=>null);if(!i?.text)throw Error(`Empty STT result`);p(`${u.mic} STT (${l(i.engine||``)}, ${i.elapsed?.toFixed(1)}s): "${l(i.text.slice(0,100))}"`,``,`info`);let s=[];o.length&&(s=await Promise.all(o.map(e=>Je(e))));let d=[];for(let e of s)d.push(c(`chat.file.sent`,{path:e}));d.push(`🎤 ${i.text}`),a&&d.push(a),await h(`/api/message`,`POST`,{prompt:d.join(`
8
8
  `)})}catch(e){p(c(`voice.sttFail`,{msg:e.message}),``,`error`)}}var nt={sun:0,mon:1,tue:2,wed:3,thu:4,fri:5,sat:6},rt={jan:1,feb:2,mar:3,apr:4,may:5,jun:6,jul:7,aug:8,sep:9,oct:10,nov:11,dec:12};function it(e){let t=typeof e==`string`?e.trim():``;if(t)try{return new Intl.DateTimeFormat(`en-US`,{timeZone:t}).format(new Date),t}catch{return}}function at(e){let t=e&&typeof e==`object`?e:{},n=t.kind,r=typeof t.timeZone==`string`?t.timeZone.trim():``,i=it(t.timeZone);if(r&&!i)return{ok:!1,code:`invalid_timezone`,error:`invalid timeZone "${r}"`};if(n===`cron`){let e=typeof t.cron==`string`?t.cron.trim().replace(/\s+/g,` `):``;if(!e)return{ok:!1,code:`invalid_cron`,error:`cron expression required`};let n=ot(e);return n?{ok:!1,code:`invalid_cron`,error:n}:{ok:!0,schedule:i?{kind:`cron`,cron:e,timeZone:i}:{kind:`cron`,cron:e}}}if(n==null||n===`every`){let e=typeof t.minutes==`number`?t.minutes:Number(t.minutes);if(!Number.isInteger(e)||e<1)return{ok:!1,code:`invalid_minutes`,error:`minutes must be an integer >= 1`};let n=Math.max(1,Math.floor(e));return{ok:!0,schedule:i?{kind:`every`,minutes:n,timeZone:i}:{kind:`every`,minutes:n}}}return{ok:!1,code:`invalid_kind`,error:`invalid heartbeat schedule kind "${String(n)}"`}}function ot(e){try{let[t,n,r,i,a]=st(e);return T(t,{min:0,max:59}),T(n,{min:0,max:23}),T(r,{min:1,max:31}),T(i,{min:1,max:12,aliases:rt}),T(a,{min:0,max:7,aliases:nt,normalize:ut}),null}catch(e){return e.message}}function st(e){let t=String(e||``).trim().replace(/\s+/g,` `).split(` `);if(t.length!==5)throw Error(`cron must have 5 fields, got ${t.length}`);return t}function T(e,t){for(let n of e.split(`,`))ct(n.trim(),t)}function ct(e,t){if(!e)throw Error(`empty cron segment`);let n=e;if(e.includes(`/`)){let[t,r,...i]=e.split(`/`);if(!t||!r||i.length>0)throw Error(`invalid cron step segment "${e}"`);n=t,lt(r,`invalid cron step "${r}"`)}if(n!==`*`){if(n.includes(`-`)){let[e,r,...i]=n.split(`-`);if(!e||!r||i.length>0||E(e,t)>E(r,t))throw Error(`invalid cron range "${n}"`);return}E(n,t)}}function E(e,t){let n=e.trim().toLowerCase(),r=t.aliases?.[n]??Number(n);if(!Number.isInteger(r))throw Error(`invalid cron value "${e}"`);let i=t.normalize?t.normalize(r):r;if(!dt(i,t.min,t.max))throw Error(`cron value "${e}" out of range ${t.min}-${t.max}`);return i}function lt(e,t){let n=Number(e);if(!Number.isInteger(n)||n<=0)throw Error(t);return n}function ut(e){return e===7?0:e}function dt(e,t,n){return e>=t&&e<=n}async function ft(){n.heartbeatJobs=((await g(`/api/heartbeat`))?.jobs||[]).map(k),n.heartbeatErrors=j(n.heartbeatJobs),D(),document.getElementById(`heartbeatModal`)?.classList.add(`open`)}function pt(e){e&&e.target!==e.currentTarget||document.getElementById(`heartbeatModal`)?.classList.remove(`open`)}function D(){let e=document.getElementById(`hbJobsList`);if(!e)return;let t=n.heartbeatJobs.map(k);n.heartbeatJobs=t,n.heartbeatErrors=j(t),t.length===0?e.innerHTML=`<p style="color:var(--text-dim);font-size:12px;text-align:center">${c(`hb.empty`)}</p>`:e.innerHTML=t.map((e,t)=>{let r=vt(e.schedule),i=r.kind===`cron`,a=n.heartbeatErrors[e.id],o=a||wt(r),s=a?`hb-schedule-meta hb-error`:`hb-schedule-meta hb-help`,d=i?`<input type="text" value="${l(r.cron)}" placeholder="${l(c(`hb.cronPlaceholder`))}"
9
9
  data-hb-cron="${t}">`:`<input type="number" value="${r.minutes}" min="1" data-hb-minutes="${t}">`,f=i?`<span class="hb-chip">${l(c(`hb.cronLabel`))}</span>`:`<span class="hb-chip">${l(c(`hb.minutesLabel`))}</span>`;return`
10
10
  <div class="hb-job-card">
@@ -46,4 +46,4 @@ import{n as e,t}from"./vendor-render-D2YP6GiF.js";import{t as n}from"./state-O6N
46
46
  <button data-mem-back style="background:none;border:none;color:var(--accent);cursor:pointer;font-size:11px">${u.arrowLeft} back</button>
47
47
  </div>
48
48
  <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)">${l(t.content)}</pre>
49
- `)}var B=`sidebarState`,V=900,Ht=768;function H(){return window.innerWidth<=Ht}function U(){document.body.classList.remove(`left-expanded`,`right-expanded`)}function Ut(e){let t=`${e}-expanded`,n=e===`left`?`right-expanded`:`left-expanded`,r=!document.body.classList.contains(t);document.body.classList.remove(n),document.body.classList.toggle(t,r)}function Wt(){let e={};try{e=JSON.parse(localStorage.getItem(B)||`{}`)}catch{}e.left&&document.body.classList.add(`left-collapsed`),e.right&&document.body.classList.add(`right-collapsed`);let t=H();document.getElementById(`toggleLeft`)?.addEventListener(`click`,Gt),document.getElementById(`toggleRight`)?.addEventListener(`click`,Kt),window.addEventListener(`resize`,()=>{let e=H();if(window.innerWidth>V){U();let e={};try{e=JSON.parse(localStorage.getItem(B)||`{}`)}catch{}document.body.classList.toggle(`left-collapsed`,!!e.left),document.body.classList.toggle(`right-collapsed`,!!e.right)}else document.body.classList.remove(`left-collapsed`,`right-collapsed`),e!==t&&U();t=e,G()}),window.innerWidth<=V&&(document.body.classList.remove(`left-collapsed`,`right-collapsed`),H()&&U()),G()}function W(){return window.innerWidth<=V}function Gt(){W()?Ut(`left`):document.body.classList.toggle(`left-collapsed`),Yt(),G()}function Kt(){W()?Ut(`right`):document.body.classList.toggle(`right-collapsed`),Yt(),G()}function qt(){return W()?document.body.classList.contains(`left-expanded`):!document.body.classList.contains(`left-collapsed`)}function Jt(){return W()?document.body.classList.contains(`right-expanded`):!document.body.classList.contains(`right-collapsed`)}function G(){let e=document.getElementById(`toggleLeft`),t=document.getElementById(`toggleRight`);e&&(e.innerHTML=qt()?u.chevronLeft:u.chevronRight),t&&(t.innerHTML=Jt()?u.chevronRight:u.chevronLeft)}function Yt(){localStorage.setItem(B,JSON.stringify({left:document.body.classList.contains(`left-collapsed`),right:document.body.classList.contains(`right-collapsed`)}))}var Xt=`theme`,K=null;function Zt(n){let r=n===`light`?t:e;K||(K=document.createElement(`style`),K.id=`hljsTheme`,document.head.appendChild(K)),K.textContent=r}function Qt(){let e=localStorage.getItem(Xt),t=window.matchMedia(`(prefers-color-scheme: light)`).matches?`light`:`dark`;en(e||t),document.getElementById(`toggleTheme`)?.addEventListener(`click`,$t)}function $t(){let e=(document.documentElement.getAttribute(`data-theme`)||`dark`)===`dark`?`light`:`dark`;en(e),localStorage.setItem(Xt,e)}function en(e){document.documentElement.setAttribute(`data-theme`,e);let t=document.getElementById(`toggleTheme`);t&&t.classList.toggle(`is-light`,e===`light`),Zt(e),ne(),o()}var tn=50,nn=30,rn=80,an=500,q=null,on=!1;function sn(){if(on||!(`ontouchstart`in window))return;on=!0;let e=document.querySelector(`.chat-area`);e&&(e.addEventListener(`touchstart`,cn,{passive:!0}),e.addEventListener(`touchend`,ln,{passive:!0}))}function cn(e){let t=e.touches[0],n=window.innerWidth,r=null;t.clientX<nn?r=`left`:t.clientX>n-nn&&(r=`right`),q={startX:t.clientX,startY:t.clientY,startTime:Date.now(),isEdge:r}}function ln(e){if(!q)return;let t=e.changedTouches[0],n=t.clientX-q.startX,r=Math.abs(t.clientY-q.startY),i=Date.now()-q.startTime,a=q;q=null,!(r>rn||i>an||Math.abs(n)<tn)&&(n>0&&a.isEdge===`left`&&Gt(),n<0&&a.isEdge===`right`&&Kt())}var un=!1,J=null,Y=[],X=null,dn=null,fn=0;function pn(){if(typeof MediaRecorder>`u`)return``;for(let e of[`audio/webm;codecs=opus`,`audio/mp4`,`audio/ogg;codecs=opus`])if(MediaRecorder.isTypeSupported(e))return e;return``}function mn(e){let t=e;switch(t.name){case`NotAllowedError`:return c(`voice.micDenied`);case`NotFoundError`:return c(`voice.micNotFound`);case`NotReadableError`:case`AbortError`:return c(`voice.micBusy`);default:return t instanceof TypeError||!navigator.mediaDevices?c(`voice.httpsRequired`):c(`voice.micDenied`)}}async function hn(){if(n.isRecording)return;if(typeof MediaRecorder>`u`||!navigator.mediaDevices?.getUserMedia){p(c(`voice.unsupported`),``,`error`);return}try{X=await navigator.mediaDevices.getUserMedia({audio:!0})}catch(e){p(mn(e),``,`error`);return}let e=pn();J=new MediaRecorder(X,e?{mimeType:e}:{}),Y=[],J.ondataavailable=e=>{e.data.size>0&&Y.push(e.data)},J.onerror=()=>{gn(),p(c(`voice.interrupted`),``,`error`)},J.onstop=async()=>{if(un){Y=[],yn(),un=!1;return}let t=J?.mimeType||e||`audio/webm`,n=t.includes(`mp4`)?`.m4a`:t.includes(`ogg`)?`.ogg`:`.webm`,r=new Blob(Y,{type:t});if(Y=[],yn(),r.size>20*1024*1024){p(c(`voice.tooLarge`),``,`error`);return}if(r.size<1e3){p(c(`voice.tooShort`),``,`error`);return}await tt(r,n,t)},J.start(),n.isRecording=!0,fn=Date.now(),Sn(!0),bn()}function gn(){!n.isRecording||!J||(J.state===`recording`&&J.stop(),n.isRecording=!1,xn(),Sn(!1))}function _n(){!n.isRecording||!J||(un=!0,J.state===`recording`&&J.stop(),n.isRecording=!1,xn(),Sn(!1))}function vn(){n.isRecording?gn():hn()}function yn(){X?.getTracks().forEach(e=>e.stop()),X=null}function bn(){let e=document.getElementById(`voiceTimer`);e&&(e.style.display=`inline`,dn=setInterval(()=>{let t=Math.floor((Date.now()-fn)/1e3);e.textContent=`${String(Math.floor(t/60)).padStart(2,`0`)}:${String(t%60).padStart(2,`0`)}`},500))}function xn(){dn&&=(clearInterval(dn),null);let e=document.getElementById(`voiceTimer`);e&&(e.style.display=`none`,e.textContent=`00:00`)}function Sn(e){let t=document.getElementById(`btnVoice`),n=document.getElementById(`btnVoiceCancel`);t&&(t.classList.toggle(`recording`,e),t.innerHTML=e?u.stop:u.mic,t.title=c(e?`voice.stop`:`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)});var{loadEmployees:Cn,addEmployee:wn,deleteEmployee:Tn,updateEmployee:Z,onEmpCliChange:En,onEmpRoleChange:Dn}=await r(async()=>{let{loadEmployees:e,addEmployee:t,deleteEmployee:n,updateEmployee:r,onEmpCliChange:i,onEmpRoleChange:a}=await import(`./employees-B11suLXa.js`);return{loadEmployees:e,addEmployee:t,deleteEmployee:n,updateEmployee:r,onEmpCliChange:i,onEmpRoleChange:a}},__vite__mapDeps([0]));document.getElementById(`btnSend`)?.addEventListener(`click`,b);var Q=document.getElementById(`chatInput`);Q?.addEventListener(`keydown`,e=>{me(e)||qe(e)});var $=0;Q?.addEventListener(`input`,e=>{e.isComposing||($&&cancelAnimationFrame($),$=requestAnimationFrame(()=>{pe(e.target?.value||``),$=0}))}),Q?.addEventListener(`cmd-execute`,()=>{b()}),document.getElementById(`cmdDropdown`)?.addEventListener(`click`,fe),document.addEventListener(`click`,de),document.getElementById(`filePreviewClear`)?.addEventListener(`click`,S),document.getElementById(`filePreviewList`)?.addEventListener(`click`,e=>{let t=e.target?.closest(`[data-file-idx]`);t&&Ye(+(t.dataset.fileIdx||`0`))}),document.querySelector(`.btn-attach`)?.addEventListener(`click`,()=>{document.getElementById(`fileInput`)?.click()}),document.getElementById(`btnVoice`)?.addEventListener(`click`,()=>vn()),document.getElementById(`btnVoiceCancel`)?.addEventListener(`click`,()=>_n()),document.getElementById(`memorySidebarBtn`)?.addEventListener(`click`,L),document.getElementById(`btnClearChat`)?.addEventListener(`click`,Xe),document.getElementById(`hbSidebarBtn`)?.addEventListener(`click`,ft),document.getElementById(`langToggle`)?.addEventListener(`click`,async()=>{let e=i()===`ko`?`en`:`ko`;await d(e);let t=document.getElementById(`langToggle`);t&&(t.innerHTML=`${u.web} ${c(`lang.`+e)}`),n.ws&&n.ws.close()}),document.querySelector(`.tab-bar`)?.addEventListener(`click`,e=>{let t=e.target?.closest(`.tab-btn`);if(!t)return;let n=[...t.parentElement?.children||[]].filter(e=>e.classList.contains(`tab-btn`)).indexOf(t),r=[`agents`,`skills`,`settings`];r[n]&&ie(r[n],t)}),document.querySelector(`.sidebar-save-bar .btn-save`)?.addEventListener(`click`,re),document.getElementById(`selCli`)?.addEventListener(`change`,()=>Le()),document.getElementById(`selModel`)?.addEventListener(`change`,()=>Me()),document.getElementById(`selEffort`)?.addEventListener(`change`,()=>Me()),document.querySelector(`[data-action="addEmployee"]`)?.addEventListener(`click`,wn),document.getElementById(`employeesList`)?.addEventListener(`click`,e=>{let t=e.target?.closest(`[data-emp-delete]`);if(t){Tn(t.dataset.empDelete||``);return}}),document.getElementById(`employeesList`)?.addEventListener(`change`,e=>{let t=e.target,n=t.closest(`[data-emp-name]`);if(n){Z(n.dataset.empName||``,{name:t.value});return}let r=t.closest(`[data-emp-cli]`);if(r){En(r.dataset.empCli||``,t.value);return}let i=t.closest(`[data-emp-model]`);if(i){if(t.value===`__custom__`){let e=prompt(c(`model.promptInput`));if(e?.trim()){let n=document.createElement(`option`);n.value=e.trim(),n.textContent=e.trim();let r=t.querySelector(`option[value="__custom__"]`);r&&t.insertBefore(n,r),t.value=e.trim(),Z(i.dataset.empModel||``,{model:e.trim()})}else t.value=`default`}else Z(i.dataset.empModel||``,{model:t.value});return}let a=t.closest(`[data-emp-role]`);if(a){Dn(a.dataset.empRole||``,t.value);return}let o=t.closest(`[data-emp-custom]`);if(o){Z(o.dataset.empCustom||``,{role:t.value});return}}),document.getElementById(`skillsList`)?.addEventListener(`click`,e=>{let t=e.target?.closest(`[data-skill-id]`);t&&ge(t.dataset.skillId||``,t.dataset.skillEnabled===`true`)}),document.querySelector(`#tabSkills`)?.addEventListener(`click`,e=>{let t=e.target?.closest(`.skill-filter`);t&&_e(t.dataset.filter||`all`,t)}),document.querySelector(`[data-action="openPrompt"]`)?.addEventListener(`click`,Ve),document.getElementById(`tgOff`)?.addEventListener(`click`,()=>we(!1)),document.getElementById(`tgOn`)?.addEventListener(`click`,()=>we(!0)),document.getElementById(`tgForwardOff`)?.addEventListener(`click`,()=>Ce(!1)),document.getElementById(`tgForwardOn`)?.addEventListener(`click`,()=>Ce(!0)),document.getElementById(`tgToken`)?.addEventListener(`change`,Pe),document.getElementById(`tgChatIds`)?.addEventListener(`change`,Pe),document.getElementById(`chTelegram`)?.addEventListener(`click`,()=>De(`telegram`)),document.getElementById(`chDiscord`)?.addEventListener(`click`,()=>De(`discord`)),document.getElementById(`dcOff`)?.addEventListener(`click`,()=>xe(!1)),document.getElementById(`dcOn`)?.addEventListener(`click`,()=>xe(!0)),document.getElementById(`dcForwardOff`)?.addEventListener(`click`,()=>Fe(!1)),document.getElementById(`dcForwardOn`)?.addEventListener(`click`,()=>Fe(!0)),document.getElementById(`dcAllowBotsOff`)?.addEventListener(`click`,()=>Te(!1)),document.getElementById(`dcAllowBotsOn`)?.addEventListener(`click`,()=>Te(!0)),document.getElementById(`dcMentionOff`)?.addEventListener(`click`,()=>be(!1)),document.getElementById(`dcMentionOn`)?.addEventListener(`click`,()=>be(!0)),document.getElementById(`dcToken`)?.addEventListener(`change`,Se),document.getElementById(`dcGuildId`)?.addEventListener(`change`,Se),document.getElementById(`dcChannelIds`)?.addEventListener(`change`,Se),document.getElementById(`fallbackOrderList`)?.addEventListener(`change`,We);function On(e){let t=document.getElementById(`codexFastOn`),n=document.getElementById(`codexFastOff`);t&&n&&(t.classList.toggle(`active`,e),n.classList.toggle(`active`,!e)),_()}document.getElementById(`codexFastOn`)?.addEventListener(`click`,()=>On(!0)),document.getElementById(`codexFastOff`)?.addEventListener(`click`,()=>On(!1));function kn(e){let t=document.getElementById(`codexCtxOn`),n=document.getElementById(`codexCtxOff`),r=document.getElementById(`codexCtxValues`);t&&n&&(t.classList.toggle(`active`,e),n.classList.toggle(`active`,!e)),r&&(r.style.display=e?``:`none`),_()}document.getElementById(`codexCtxOn`)?.addEventListener(`click`,()=>kn(!0)),document.getElementById(`codexCtxOff`)?.addEventListener(`click`,()=>kn(!1)),document.getElementById(`codexCtxWindow`)?.addEventListener(`change`,_),document.getElementById(`codexCtxCompact`)?.addEventListener(`change`,_);function An(e){let t=document.getElementById(`claude1mOn`),n=document.getElementById(`claude1mOff`),r=document.getElementById(`modelClaude`),i=e;if(r){let t=r.value||``;if(e&&!t.endsWith(`[1m]`)){let e=t+`[1m]`;Array.from(r.options).some(t=>t.value===e)?r.value=e:i=!1}else if(!e&&t.endsWith(`[1m]`)){let e=t.replace(/\[1m\]$/,``);Array.from(r.options).some(t=>t.value===e)?r.value=e:i=!0}else i=t.endsWith(`[1m]`)}t&&n&&(t.classList.toggle(`active`,i),n.classList.toggle(`active`,!i)),_()}document.getElementById(`claude1mOn`)?.addEventListener(`click`,()=>An(!0)),document.getElementById(`claude1mOff`)?.addEventListener(`click`,()=>An(!1));function jn(){for(let e of ye()){let t=e.charAt(0).toUpperCase()+e.slice(1),n=document.getElementById(`model`+t);n&&n.addEventListener(`change`,function(){je(e,this)});let r=document.getElementById(`customModel`+t);r&&r.addEventListener(`change`,function(){Ue(e,this)});let i=document.getElementById(`effort`+t);i&&i.addEventListener(`change`,_)}}document.querySelector(`[data-action="syncMcp"]`)?.addEventListener(`click`,Ee),document.querySelector(`[data-action="installMcp"]`)?.addEventListener(`click`,ke),document.querySelector(`[data-action="refreshCli"]`)?.addEventListener(`click`,()=>Ie(!0)),document.getElementById(`cliStatusInterval`)?.addEventListener(`change`,function(){localStorage.setItem(`cliStatusInterval`,this.value)}),document.getElementById(`promptModal`)?.addEventListener(`click`,e=>v(e)),document.querySelector(`#promptModal .modal-box`)?.addEventListener(`click`,e=>e.stopPropagation()),document.querySelector(`[data-action="closePrompt"]`)?.addEventListener(`click`,()=>v()),document.querySelector(`[data-action="cancelPrompt"]`)?.addEventListener(`click`,()=>v()),document.querySelector(`[data-action="savePrompt"]`)?.addEventListener(`click`,Oe),document.addEventListener(`keydown`,e=>{e.key===`Escape`&&!n.isRecording&&v()}),document.querySelector(`[data-action="openTemplates"]`)?.addEventListener(`click`,Ne),document.querySelector(`[data-action="saveTemplate"]`)?.addEventListener(`click`,ze),document.querySelector(`[data-action="closeTemplate"]`)?.addEventListener(`click`,()=>Re()),document.getElementById(`templateModal`)?.addEventListener(`click`,e=>Re(e)),document.querySelector(`#templateModal .modal-box`)?.addEventListener(`click`,e=>e.stopPropagation()),document.getElementById(`templateBack`)?.addEventListener(`click`,He),document.getElementById(`templateDevToggle`)?.addEventListener(`click`,Ae),document.getElementById(`heartbeatModal`)?.addEventListener(`click`,e=>pt(e)),document.querySelector(`#heartbeatModal .modal-box`)?.addEventListener(`click`,e=>e.stopPropagation()),document.querySelector(`[data-action="closeHeartbeat"]`)?.addEventListener(`click`,()=>pt()),document.querySelector(`[data-action="addHeartbeat"]`)?.addEventListener(`click`,mt),document.getElementById(`hbJobsList`)?.addEventListener(`click`,e=>{let t=e.target?.closest(`[data-hb-toggle]`);if(t){gt(+(t.dataset.hbToggle||`0`));return}let n=e.target?.closest(`[data-hb-remove]`);if(n){ht(+(n.dataset.hbRemove||`0`));return}}),document.getElementById(`hbJobsList`)?.addEventListener(`change`,e=>{let t=e.target,r=t.closest(`[data-hb-name]`);if(r){n.heartbeatJobs[+(r.dataset.hbName||`0`)].name=t.value,O();return}let i=t.closest(`[data-hb-kind]`);if(i){let e=+(i.dataset.hbKind||`0`),r=n.heartbeatJobs[e]?.schedule,a=typeof r?.timeZone==`string`?r.timeZone:void 0;n.heartbeatJobs[e].schedule=t.value===`cron`?{kind:`cron`,cron:typeof r?.cron==`string`&&r.cron.trim()?r.cron:`0 9 * * *`,...a?{timeZone:a}:{}}:{kind:`every`,minutes:typeof r?.minutes==`number`&&r.minutes>0?Math.floor(r.minutes):5,...a?{timeZone:a}:{}},D(),O();return}let a=t.closest(`[data-hb-minutes]`);if(a){let e=+(a.dataset.hbMinutes||`0`),r=n.heartbeatJobs[e]?.schedule,i=Math.max(1,Math.floor(Number(t.value)||5)),o=typeof r?.timeZone==`string`?r.timeZone:void 0;n.heartbeatJobs[e].schedule={kind:`every`,minutes:i,...o?{timeZone:o}:{}},D(),O();return}let o=t.closest(`[data-hb-cron]`);if(o){let e=+(o.dataset.hbCron||`0`),r=n.heartbeatJobs[e]?.schedule,i=typeof r?.timeZone==`string`?r.timeZone:void 0,a=t.value.trim().replace(/\s+/g,` `);n.heartbeatJobs[e].schedule={kind:`cron`,cron:a,...i?{timeZone:i}:{}},D(),O();return}let s=t.closest(`[data-hb-timezone]`);if(s){let e=+(s.dataset.hbTimezone||`0`),r=n.heartbeatJobs[e]?.schedule;r?.kind===`cron`?n.heartbeatJobs[e].schedule={kind:`cron`,cron:typeof r.cron==`string`&&r.cron.trim()?r.cron:`0 9 * * *`,...t.value.trim()?{timeZone:t.value.trim()}:{}}:n.heartbeatJobs[e].schedule={kind:`every`,minutes:typeof r?.minutes==`number`&&r.minutes>0?Math.floor(r.minutes):5,...t.value.trim()?{timeZone:t.value.trim()}:{}},D(),O();return}let c=t.closest(`[data-hb-prompt]`);if(c){n.heartbeatJobs[+(c.dataset.hbPrompt||`0`)].prompt=t.value,O();return}}),document.getElementById(`memoryModal`)?.addEventListener(`click`,e=>Ft(e)),document.querySelector(`#memoryModal .modal-box`)?.addEventListener(`click`,e=>e.stopPropagation()),document.querySelector(`[data-action="closeMemory"]`)?.addEventListener(`click`,()=>Ft()),document.getElementById(`memTabBtnSettings`)?.addEventListener(`click`,()=>R(`settings`)),document.getElementById(`memTabBtnAdvOps`)?.addEventListener(`click`,()=>R(`status`)),document.getElementById(`memTabBtnFiles`)?.addEventListener(`click`,()=>R(`files`)),document.getElementById(`memOn`)?.addEventListener(`click`,()=>It(!0)),document.getElementById(`memOff`)?.addEventListener(`click`,()=>It(!1)),document.getElementById(`memFlushEvery`)?.addEventListener(`change`,z),document.getElementById(`memCli`)?.addEventListener(`change`,z),document.getElementById(`memModel`)?.addEventListener(`change`,z),document.getElementById(`memRetention`)?.addEventListener(`change`,z),document.getElementById(`advBootstrapBtn`)?.addEventListener(`click`,Lt),document.getElementById(`advReindexBtn`)?.addEventListener(`click`,Rt),document.getElementById(`advReimportBtn`)?.addEventListener(`click`,Lt),document.getElementById(`advOpenCorruptedBtn`)?.addEventListener(`click`,zt),document.getElementById(`basicMemoryFiles`)?.addEventListener(`click`,e=>{let t=e.target?.closest(`[data-mem-delete]`);if(t){e.stopPropagation(),Bt(t.dataset.memDelete||``);return}let n=e.target?.closest(`[data-mem-view]`);if(n){Vt(n.dataset.memView||``);return}if(e.target?.closest(`[data-mem-back]`)){L();return}});async function Mn(){s(),Ge(),await a();let e=document.getElementById(`langToggle`);e&&(e.innerHTML=`${u.web} ${c(`lang.`+i())}`),await ve(),jn(),ce(),et(),$e(),await ue(),await Be(),Ie(),Cn(),_t(),oe(),Wt(),Qt(),ae(),sn(),`serviceWorker`in navigator&&navigator.serviceWorker.register(`/sw.js`).catch(()=>{})}Mn().catch(e=>{console.error(`[bootstrap]`,e)}),document.addEventListener(`keydown`,e=>{if(e.key===`Escape`){if(n.isRecording){e.preventDefault(),_n();return}document.querySelectorAll(`.modal-overlay.open`).forEach(e=>{e.classList.remove(`open`)})}(e.ctrlKey||e.metaKey)&&e.shiftKey&&e.code===`Space`&&(e.preventDefault(),vn())}),document.getElementById(`mobileMenuLeft`)?.addEventListener(`click`,Gt),document.getElementById(`mobileMenuRight`)?.addEventListener(`click`,Kt);
49
+ `)}var B=`sidebarState`,V=900,Ht=768;function H(){return window.innerWidth<=Ht}function U(){document.body.classList.remove(`left-expanded`,`right-expanded`)}function Ut(e){let t=`${e}-expanded`,n=e===`left`?`right-expanded`:`left-expanded`,r=!document.body.classList.contains(t);document.body.classList.remove(n),document.body.classList.toggle(t,r)}function Wt(){let e={};try{e=JSON.parse(localStorage.getItem(B)||`{}`)}catch{}e.left&&document.body.classList.add(`left-collapsed`),e.right&&document.body.classList.add(`right-collapsed`);let t=H();document.getElementById(`toggleLeft`)?.addEventListener(`click`,Gt),document.getElementById(`toggleRight`)?.addEventListener(`click`,Kt),window.addEventListener(`resize`,()=>{let e=H();if(window.innerWidth>V){U();let e={};try{e=JSON.parse(localStorage.getItem(B)||`{}`)}catch{}document.body.classList.toggle(`left-collapsed`,!!e.left),document.body.classList.toggle(`right-collapsed`,!!e.right)}else document.body.classList.remove(`left-collapsed`,`right-collapsed`),e!==t&&U();t=e,G()}),window.innerWidth<=V&&(document.body.classList.remove(`left-collapsed`,`right-collapsed`),H()&&U()),G()}function W(){return window.innerWidth<=V}function Gt(){W()?Ut(`left`):document.body.classList.toggle(`left-collapsed`),Yt(),G()}function Kt(){W()?Ut(`right`):document.body.classList.toggle(`right-collapsed`),Yt(),G()}function qt(){return W()?document.body.classList.contains(`left-expanded`):!document.body.classList.contains(`left-collapsed`)}function Jt(){return W()?document.body.classList.contains(`right-expanded`):!document.body.classList.contains(`right-collapsed`)}function G(){let e=document.getElementById(`toggleLeft`),t=document.getElementById(`toggleRight`);e&&(e.innerHTML=qt()?u.chevronLeft:u.chevronRight),t&&(t.innerHTML=Jt()?u.chevronRight:u.chevronLeft)}function Yt(){localStorage.setItem(B,JSON.stringify({left:document.body.classList.contains(`left-collapsed`),right:document.body.classList.contains(`right-collapsed`)}))}var Xt=`theme`,K=null;function Zt(n){let r=n===`light`?t:e;K||(K=document.createElement(`style`),K.id=`hljsTheme`,document.head.appendChild(K)),K.textContent=r}function Qt(){let e=localStorage.getItem(Xt),t=window.matchMedia(`(prefers-color-scheme: light)`).matches?`light`:`dark`;en(e||t),document.getElementById(`toggleTheme`)?.addEventListener(`click`,$t)}function $t(){let e=(document.documentElement.getAttribute(`data-theme`)||`dark`)===`dark`?`light`:`dark`;en(e),localStorage.setItem(Xt,e)}function en(e){document.documentElement.setAttribute(`data-theme`,e);let t=document.getElementById(`toggleTheme`);t&&t.classList.toggle(`is-light`,e===`light`),Zt(e),ne(),o()}var tn=50,nn=30,rn=80,an=500,q=null,on=!1;function sn(){if(on||!(`ontouchstart`in window))return;on=!0;let e=document.querySelector(`.chat-area`);e&&(e.addEventListener(`touchstart`,cn,{passive:!0}),e.addEventListener(`touchend`,ln,{passive:!0}))}function cn(e){let t=e.touches[0],n=window.innerWidth,r=null;t.clientX<nn?r=`left`:t.clientX>n-nn&&(r=`right`),q={startX:t.clientX,startY:t.clientY,startTime:Date.now(),isEdge:r}}function ln(e){if(!q)return;let t=e.changedTouches[0],n=t.clientX-q.startX,r=Math.abs(t.clientY-q.startY),i=Date.now()-q.startTime,a=q;q=null,!(r>rn||i>an||Math.abs(n)<tn)&&(n>0&&a.isEdge===`left`&&Gt(),n<0&&a.isEdge===`right`&&Kt())}var un=!1,J=null,Y=[],X=null,dn=null,fn=0;function pn(){if(typeof MediaRecorder>`u`)return``;for(let e of[`audio/webm;codecs=opus`,`audio/mp4`,`audio/ogg;codecs=opus`])if(MediaRecorder.isTypeSupported(e))return e;return``}function mn(e){let t=e;switch(t.name){case`NotAllowedError`:return c(`voice.micDenied`);case`NotFoundError`:return c(`voice.micNotFound`);case`NotReadableError`:case`AbortError`:return c(`voice.micBusy`);default:return t instanceof TypeError||!navigator.mediaDevices?c(`voice.httpsRequired`):c(`voice.micDenied`)}}async function hn(){if(n.isRecording)return;if(typeof MediaRecorder>`u`||!navigator.mediaDevices?.getUserMedia){p(c(`voice.unsupported`),``,`error`);return}try{X=await navigator.mediaDevices.getUserMedia({audio:!0})}catch(e){p(mn(e),``,`error`);return}let e=pn();J=new MediaRecorder(X,e?{mimeType:e}:{}),Y=[],J.ondataavailable=e=>{e.data.size>0&&Y.push(e.data)},J.onerror=()=>{gn(),p(c(`voice.interrupted`),``,`error`)},J.onstop=async()=>{if(un){Y=[],yn(),un=!1;return}let t=J?.mimeType||e||`audio/webm`,n=t.includes(`mp4`)?`.m4a`:t.includes(`ogg`)?`.ogg`:`.webm`,r=new Blob(Y,{type:t});if(Y=[],yn(),r.size>20*1024*1024){p(c(`voice.tooLarge`),``,`error`);return}if(r.size<1e3){p(c(`voice.tooShort`),``,`error`);return}await tt(r,n,t)},J.start(),n.isRecording=!0,fn=Date.now(),Sn(!0),bn()}function gn(){!n.isRecording||!J||(J.state===`recording`&&J.stop(),n.isRecording=!1,xn(),Sn(!1))}function _n(){!n.isRecording||!J||(un=!0,J.state===`recording`&&J.stop(),n.isRecording=!1,xn(),Sn(!1))}function vn(){n.isRecording?gn():hn()}function yn(){X?.getTracks().forEach(e=>e.stop()),X=null}function bn(){let e=document.getElementById(`voiceTimer`);e&&(e.style.display=`inline`,dn=setInterval(()=>{let t=Math.floor((Date.now()-fn)/1e3);e.textContent=`${String(Math.floor(t/60)).padStart(2,`0`)}:${String(t%60).padStart(2,`0`)}`},500))}function xn(){dn&&=(clearInterval(dn),null);let e=document.getElementById(`voiceTimer`);e&&(e.style.display=`none`,e.textContent=`00:00`)}function Sn(e){let t=document.getElementById(`btnVoice`),n=document.getElementById(`btnVoiceCancel`);t&&(t.classList.toggle(`recording`,e),t.innerHTML=e?u.stop:u.mic,t.title=c(e?`voice.stop`:`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)});var{loadEmployees:Cn,addEmployee:wn,deleteEmployee:Tn,updateEmployee:Z,onEmpCliChange:En,onEmpRoleChange:Dn}=await r(async()=>{let{loadEmployees:e,addEmployee:t,deleteEmployee:n,updateEmployee:r,onEmpCliChange:i,onEmpRoleChange:a}=await import(`./employees-Epnu4Dr0.js`);return{loadEmployees:e,addEmployee:t,deleteEmployee:n,updateEmployee:r,onEmpCliChange:i,onEmpRoleChange:a}},__vite__mapDeps([0]));document.getElementById(`btnSend`)?.addEventListener(`click`,b);var Q=document.getElementById(`chatInput`);Q?.addEventListener(`keydown`,e=>{me(e)||qe(e)});var $=0;Q?.addEventListener(`input`,e=>{e.isComposing||($&&cancelAnimationFrame($),$=requestAnimationFrame(()=>{pe(e.target?.value||``),$=0}))}),Q?.addEventListener(`cmd-execute`,()=>{b()}),document.getElementById(`cmdDropdown`)?.addEventListener(`click`,fe),document.addEventListener(`click`,de),document.getElementById(`filePreviewClear`)?.addEventListener(`click`,S),document.getElementById(`filePreviewList`)?.addEventListener(`click`,e=>{let t=e.target?.closest(`[data-file-idx]`);t&&Ye(+(t.dataset.fileIdx||`0`))}),document.querySelector(`.btn-attach`)?.addEventListener(`click`,()=>{document.getElementById(`fileInput`)?.click()}),document.getElementById(`btnVoice`)?.addEventListener(`click`,()=>vn()),document.getElementById(`btnVoiceCancel`)?.addEventListener(`click`,()=>_n()),document.getElementById(`memorySidebarBtn`)?.addEventListener(`click`,L),document.getElementById(`btnClearChat`)?.addEventListener(`click`,Xe),document.getElementById(`hbSidebarBtn`)?.addEventListener(`click`,ft),document.getElementById(`langToggle`)?.addEventListener(`click`,async()=>{let e=i()===`ko`?`en`:`ko`;await d(e);let t=document.getElementById(`langToggle`);t&&(t.innerHTML=`${u.web} ${c(`lang.`+e)}`),n.ws&&n.ws.close()}),document.querySelector(`.tab-bar`)?.addEventListener(`click`,e=>{let t=e.target?.closest(`.tab-btn`);if(!t)return;let n=[...t.parentElement?.children||[]].filter(e=>e.classList.contains(`tab-btn`)).indexOf(t),r=[`agents`,`skills`,`settings`];r[n]&&ie(r[n],t)}),document.querySelector(`.sidebar-save-bar .btn-save`)?.addEventListener(`click`,re),document.getElementById(`selCli`)?.addEventListener(`change`,()=>Le()),document.getElementById(`selModel`)?.addEventListener(`change`,()=>Me()),document.getElementById(`selEffort`)?.addEventListener(`change`,()=>Me()),document.querySelector(`[data-action="addEmployee"]`)?.addEventListener(`click`,wn),document.getElementById(`employeesList`)?.addEventListener(`click`,e=>{let t=e.target?.closest(`[data-emp-delete]`);if(t){Tn(t.dataset.empDelete||``);return}}),document.getElementById(`employeesList`)?.addEventListener(`change`,e=>{let t=e.target,n=t.closest(`[data-emp-name]`);if(n){Z(n.dataset.empName||``,{name:t.value});return}let r=t.closest(`[data-emp-cli]`);if(r){En(r.dataset.empCli||``,t.value);return}let i=t.closest(`[data-emp-model]`);if(i){if(t.value===`__custom__`){let e=prompt(c(`model.promptInput`));if(e?.trim()){let n=document.createElement(`option`);n.value=e.trim(),n.textContent=e.trim();let r=t.querySelector(`option[value="__custom__"]`);r&&t.insertBefore(n,r),t.value=e.trim(),Z(i.dataset.empModel||``,{model:e.trim()})}else t.value=`default`}else Z(i.dataset.empModel||``,{model:t.value});return}let a=t.closest(`[data-emp-role]`);if(a){Dn(a.dataset.empRole||``,t.value);return}let o=t.closest(`[data-emp-custom]`);if(o){Z(o.dataset.empCustom||``,{role:t.value});return}}),document.getElementById(`skillsList`)?.addEventListener(`click`,e=>{let t=e.target?.closest(`[data-skill-id]`);t&&ge(t.dataset.skillId||``,t.dataset.skillEnabled===`true`)}),document.querySelector(`#tabSkills`)?.addEventListener(`click`,e=>{let t=e.target?.closest(`.skill-filter`);t&&_e(t.dataset.filter||`all`,t)}),document.querySelector(`[data-action="openPrompt"]`)?.addEventListener(`click`,Ve),document.getElementById(`tgOff`)?.addEventListener(`click`,()=>we(!1)),document.getElementById(`tgOn`)?.addEventListener(`click`,()=>we(!0)),document.getElementById(`tgForwardOff`)?.addEventListener(`click`,()=>Ce(!1)),document.getElementById(`tgForwardOn`)?.addEventListener(`click`,()=>Ce(!0)),document.getElementById(`tgToken`)?.addEventListener(`change`,Pe),document.getElementById(`tgChatIds`)?.addEventListener(`change`,Pe),document.getElementById(`chTelegram`)?.addEventListener(`click`,()=>De(`telegram`)),document.getElementById(`chDiscord`)?.addEventListener(`click`,()=>De(`discord`)),document.getElementById(`dcOff`)?.addEventListener(`click`,()=>xe(!1)),document.getElementById(`dcOn`)?.addEventListener(`click`,()=>xe(!0)),document.getElementById(`dcForwardOff`)?.addEventListener(`click`,()=>Fe(!1)),document.getElementById(`dcForwardOn`)?.addEventListener(`click`,()=>Fe(!0)),document.getElementById(`dcAllowBotsOff`)?.addEventListener(`click`,()=>Te(!1)),document.getElementById(`dcAllowBotsOn`)?.addEventListener(`click`,()=>Te(!0)),document.getElementById(`dcMentionOff`)?.addEventListener(`click`,()=>be(!1)),document.getElementById(`dcMentionOn`)?.addEventListener(`click`,()=>be(!0)),document.getElementById(`dcToken`)?.addEventListener(`change`,Se),document.getElementById(`dcGuildId`)?.addEventListener(`change`,Se),document.getElementById(`dcChannelIds`)?.addEventListener(`change`,Se),document.getElementById(`fallbackOrderList`)?.addEventListener(`change`,We);function On(e){let t=document.getElementById(`codexFastOn`),n=document.getElementById(`codexFastOff`);t&&n&&(t.classList.toggle(`active`,e),n.classList.toggle(`active`,!e)),_()}document.getElementById(`codexFastOn`)?.addEventListener(`click`,()=>On(!0)),document.getElementById(`codexFastOff`)?.addEventListener(`click`,()=>On(!1));function kn(e){let t=document.getElementById(`codexCtxOn`),n=document.getElementById(`codexCtxOff`),r=document.getElementById(`codexCtxValues`);t&&n&&(t.classList.toggle(`active`,e),n.classList.toggle(`active`,!e)),r&&(r.style.display=e?``:`none`),_()}document.getElementById(`codexCtxOn`)?.addEventListener(`click`,()=>kn(!0)),document.getElementById(`codexCtxOff`)?.addEventListener(`click`,()=>kn(!1)),document.getElementById(`codexCtxWindow`)?.addEventListener(`change`,_),document.getElementById(`codexCtxCompact`)?.addEventListener(`change`,_);function An(e){let t=document.getElementById(`claude1mOn`),n=document.getElementById(`claude1mOff`),r=document.getElementById(`modelClaude`),i=e;if(r){let t=r.value||``;if(e&&!t.endsWith(`[1m]`)){let e=t+`[1m]`;Array.from(r.options).some(t=>t.value===e)?r.value=e:i=!1}else if(!e&&t.endsWith(`[1m]`)){let e=t.replace(/\[1m\]$/,``);Array.from(r.options).some(t=>t.value===e)?r.value=e:i=!0}else i=t.endsWith(`[1m]`)}t&&n&&(t.classList.toggle(`active`,i),n.classList.toggle(`active`,!i)),_()}document.getElementById(`claude1mOn`)?.addEventListener(`click`,()=>An(!0)),document.getElementById(`claude1mOff`)?.addEventListener(`click`,()=>An(!1));function jn(){for(let e of ye()){let t=e.charAt(0).toUpperCase()+e.slice(1),n=document.getElementById(`model`+t);n&&n.addEventListener(`change`,function(){je(e,this)});let r=document.getElementById(`customModel`+t);r&&r.addEventListener(`change`,function(){Ue(e,this)});let i=document.getElementById(`effort`+t);i&&i.addEventListener(`change`,_)}}document.querySelector(`[data-action="syncMcp"]`)?.addEventListener(`click`,Ee),document.querySelector(`[data-action="installMcp"]`)?.addEventListener(`click`,ke),document.querySelector(`[data-action="refreshCli"]`)?.addEventListener(`click`,()=>Ie(!0)),document.getElementById(`cliStatusInterval`)?.addEventListener(`change`,function(){localStorage.setItem(`cliStatusInterval`,this.value)}),document.getElementById(`promptModal`)?.addEventListener(`click`,e=>v(e)),document.querySelector(`#promptModal .modal-box`)?.addEventListener(`click`,e=>e.stopPropagation()),document.querySelector(`[data-action="closePrompt"]`)?.addEventListener(`click`,()=>v()),document.querySelector(`[data-action="cancelPrompt"]`)?.addEventListener(`click`,()=>v()),document.querySelector(`[data-action="savePrompt"]`)?.addEventListener(`click`,Oe),document.addEventListener(`keydown`,e=>{e.key===`Escape`&&!n.isRecording&&v()}),document.querySelector(`[data-action="openTemplates"]`)?.addEventListener(`click`,Ne),document.querySelector(`[data-action="saveTemplate"]`)?.addEventListener(`click`,ze),document.querySelector(`[data-action="closeTemplate"]`)?.addEventListener(`click`,()=>Re()),document.getElementById(`templateModal`)?.addEventListener(`click`,e=>Re(e)),document.querySelector(`#templateModal .modal-box`)?.addEventListener(`click`,e=>e.stopPropagation()),document.getElementById(`templateBack`)?.addEventListener(`click`,He),document.getElementById(`templateDevToggle`)?.addEventListener(`click`,Ae),document.getElementById(`heartbeatModal`)?.addEventListener(`click`,e=>pt(e)),document.querySelector(`#heartbeatModal .modal-box`)?.addEventListener(`click`,e=>e.stopPropagation()),document.querySelector(`[data-action="closeHeartbeat"]`)?.addEventListener(`click`,()=>pt()),document.querySelector(`[data-action="addHeartbeat"]`)?.addEventListener(`click`,mt),document.getElementById(`hbJobsList`)?.addEventListener(`click`,e=>{let t=e.target?.closest(`[data-hb-toggle]`);if(t){gt(+(t.dataset.hbToggle||`0`));return}let n=e.target?.closest(`[data-hb-remove]`);if(n){ht(+(n.dataset.hbRemove||`0`));return}}),document.getElementById(`hbJobsList`)?.addEventListener(`change`,e=>{let t=e.target,r=t.closest(`[data-hb-name]`);if(r){n.heartbeatJobs[+(r.dataset.hbName||`0`)].name=t.value,O();return}let i=t.closest(`[data-hb-kind]`);if(i){let e=+(i.dataset.hbKind||`0`),r=n.heartbeatJobs[e]?.schedule,a=typeof r?.timeZone==`string`?r.timeZone:void 0;n.heartbeatJobs[e].schedule=t.value===`cron`?{kind:`cron`,cron:typeof r?.cron==`string`&&r.cron.trim()?r.cron:`0 9 * * *`,...a?{timeZone:a}:{}}:{kind:`every`,minutes:typeof r?.minutes==`number`&&r.minutes>0?Math.floor(r.minutes):5,...a?{timeZone:a}:{}},D(),O();return}let a=t.closest(`[data-hb-minutes]`);if(a){let e=+(a.dataset.hbMinutes||`0`),r=n.heartbeatJobs[e]?.schedule,i=Math.max(1,Math.floor(Number(t.value)||5)),o=typeof r?.timeZone==`string`?r.timeZone:void 0;n.heartbeatJobs[e].schedule={kind:`every`,minutes:i,...o?{timeZone:o}:{}},D(),O();return}let o=t.closest(`[data-hb-cron]`);if(o){let e=+(o.dataset.hbCron||`0`),r=n.heartbeatJobs[e]?.schedule,i=typeof r?.timeZone==`string`?r.timeZone:void 0,a=t.value.trim().replace(/\s+/g,` `);n.heartbeatJobs[e].schedule={kind:`cron`,cron:a,...i?{timeZone:i}:{}},D(),O();return}let s=t.closest(`[data-hb-timezone]`);if(s){let e=+(s.dataset.hbTimezone||`0`),r=n.heartbeatJobs[e]?.schedule;r?.kind===`cron`?n.heartbeatJobs[e].schedule={kind:`cron`,cron:typeof r.cron==`string`&&r.cron.trim()?r.cron:`0 9 * * *`,...t.value.trim()?{timeZone:t.value.trim()}:{}}:n.heartbeatJobs[e].schedule={kind:`every`,minutes:typeof r?.minutes==`number`&&r.minutes>0?Math.floor(r.minutes):5,...t.value.trim()?{timeZone:t.value.trim()}:{}},D(),O();return}let c=t.closest(`[data-hb-prompt]`);if(c){n.heartbeatJobs[+(c.dataset.hbPrompt||`0`)].prompt=t.value,O();return}}),document.getElementById(`memoryModal`)?.addEventListener(`click`,e=>Ft(e)),document.querySelector(`#memoryModal .modal-box`)?.addEventListener(`click`,e=>e.stopPropagation()),document.querySelector(`[data-action="closeMemory"]`)?.addEventListener(`click`,()=>Ft()),document.getElementById(`memTabBtnSettings`)?.addEventListener(`click`,()=>R(`settings`)),document.getElementById(`memTabBtnAdvOps`)?.addEventListener(`click`,()=>R(`status`)),document.getElementById(`memTabBtnFiles`)?.addEventListener(`click`,()=>R(`files`)),document.getElementById(`memOn`)?.addEventListener(`click`,()=>It(!0)),document.getElementById(`memOff`)?.addEventListener(`click`,()=>It(!1)),document.getElementById(`memFlushEvery`)?.addEventListener(`change`,z),document.getElementById(`memCli`)?.addEventListener(`change`,z),document.getElementById(`memModel`)?.addEventListener(`change`,z),document.getElementById(`memRetention`)?.addEventListener(`change`,z),document.getElementById(`advBootstrapBtn`)?.addEventListener(`click`,Lt),document.getElementById(`advReindexBtn`)?.addEventListener(`click`,Rt),document.getElementById(`advReimportBtn`)?.addEventListener(`click`,Lt),document.getElementById(`advOpenCorruptedBtn`)?.addEventListener(`click`,zt),document.getElementById(`basicMemoryFiles`)?.addEventListener(`click`,e=>{let t=e.target?.closest(`[data-mem-delete]`);if(t){e.stopPropagation(),Bt(t.dataset.memDelete||``);return}let n=e.target?.closest(`[data-mem-view]`);if(n){Vt(n.dataset.memView||``);return}if(e.target?.closest(`[data-mem-back]`)){L();return}});async function Mn(){s(),Ge(),await a();let e=document.getElementById(`langToggle`);e&&(e.innerHTML=`${u.web} ${c(`lang.`+i())}`),await ve(),jn(),ce(),et(),$e(),await ue(),await Be(),Ie(),Cn(),_t(),oe(),Wt(),Qt(),ae(),sn(),`serviceWorker`in navigator&&navigator.serviceWorker.register(`/sw.js`).catch(()=>{})}Mn().catch(e=>{console.error(`[bootstrap]`,e)}),document.addEventListener(`keydown`,e=>{if(e.key===`Escape`){if(n.isRecording){e.preventDefault(),_n();return}document.querySelectorAll(`.modal-overlay.open`).forEach(e=>{e.classList.remove(`open`)})}(e.ctrlKey||e.metaKey)&&e.shiftKey&&e.code===`Space`&&(e.preventDefault(),vn())}),document.getElementById(`mobileMenuLeft`)?.addEventListener(`click`,Gt),document.getElementById(`mobileMenuRight`)?.addEventListener(`click`,Kt);
@@ -1,4 +1,4 @@
1
- import{A as e,C as t,D as n,E as r,F as i,I as a,M as o,N as s,O as c,P as l,S as u,T as d,_ as f,b as ee,j as p,k as m,u as te,v as ne,w as h,x as re,y as g}from"./vendor-render-D2YP6GiF.js";import{Q as _,Z as v}from"./vendor-mermaid-lvHqQdfg.js";import{A as ie,B as ae,C as oe,D as se,E as ce,F as le,G as ue,H as de,I as fe,J as pe,K as me,L as he,M as ge,N as _e,O as ve,P as ye,R as be,S as xe,T as Se,U as Ce,V as we,W as Te,_ as Ee,a as De,b as Oe,c as y,d as b,f as x,g as S,h as C,i as w,j as T,k as ke,l as Ae,m as je,n as Me,o as Ne,p as Pe,q as Fe,r as Ie,s as Le,t as Re,u as ze,v as Be,w as Ve,x as He,y as Ue,z as We}from"./vendor-icons-1Ec7ZWcT.js";var E=`ko`,D={},O={};async function Ge(){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`}O=await k(`ko`),D=e===`ko`?O:await k(e),E=e,j()}async function k(e){try{let{api:t}=await v(async()=>{let{api:e}=await import(`./api-Bbmmo0o1.js`);return{api:e}},[]);return await t(`/api/i18n/${e}`)||{}}catch{return{}}}function A(e,t={}){let n=D[e]??O[e]??e;for(let[e,r]of Object.entries(t))n=n.replaceAll(`{${e}}`,String(r));return n}function j(){document.querySelectorAll(`[data-i18n]`).forEach(e=>{let t=e.getAttribute(`data-i18n`);t&&(e.textContent=A(t))}),document.querySelectorAll(`[data-i18n-placeholder]`).forEach(e=>{let t=e.getAttribute(`data-i18n-placeholder`);t&&(e.placeholder=A(t))}),document.querySelectorAll(`[data-i18n-title]`).forEach(e=>{let t=e.getAttribute(`data-i18n-title`);t&&(e.title=A(t))}),document.querySelectorAll(`[data-i18n-aria]`).forEach(e=>{let t=e.getAttribute(`data-i18n-aria`);t&&e.setAttribute(`aria-label`,A(t))})}async function Ke(e){if(e!==E){D=e===`ko`?O:await k(e),E=e;try{localStorage.setItem(`claw_locale`,e)}catch{}j();try{let{loadEmployees:e}=await v(async()=>{let{loadEmployees:e}=await import(`./employees-B11suLXa.js`);return{loadEmployees:e}},[]);e()}catch{}try{let{loadSkills:e}=await v(async()=>{let{loadSkills:e}=await import(`./skills-kOx6rq1X.js`);return{loadSkills:e}},[]);e()}catch{}try{let{loadCommands:e}=await v(async()=>{let{loadCommands:e}=await import(`./slash-commands-C5vUKzNP.js`);return{loadCommands:e}},[]);e()}catch{}try{let{loadSettings:e}=await v(async()=>{let{loadSettings:e}=await import(`./settings-tOEsbIIs.js`);return{loadSettings:e}},[]);e()}catch{}}}function qe(){return E}function Je(e,t={}){let n=new URL(e,location.origin);return n.searchParams.has(`locale`)||n.searchParams.set(`locale`,E),fetch(n.toString(),t)}var M=14,Ye=16;function N(e,t=Ye){return pe(e,{size:t})}var P={check:N(be),error:N(he),warning:N(w),skip:N(Le),tool:N(Ie),thinking:N(Oe),search:N(ze),web:N(ie),exec:N(Re),compacting:N(Ee),plan:N(Be),brain:N(Te),heartPulse:N(ve),lock:N(He),lockOpen:N(xe),key:N(Se),settings:N(y),file:N(_e),trash:N(De),lightbulb:N(Ve),refresh:N(x),mic:N(Ue),clipboard:N(fe),robot:N(ue),palette:N(S),link:N(oe),salute:N(ke),shark:`🦈`,paperclip:N(C),save:N(b),gamepad:N(T),house:N(ce),radio:N(Pe),folder:N(ge),pencil:N(je),chart:N(Ce),hourglass:N(se),stop:N(Ne),close:N(Me,M),send:N(Ae),copy:N(le,M),download:N(ye,M),checkSimple:N(de,M),chevronLeft:N(ae,M),chevronRight:N(We,M),chevronDown:N(we,M),arrowLeft:N(Fe,M),arrowRight:N(me,M)},Xe={"✅":`check`,"❌":`error`,"🔧":`tool`,"⏭":`skip`,"🧠":`brain`,"💓":`heartPulse`,"🔒":`lock`,"🔓":`lockOpen`,"🔑":`key`,"⚙":`settings`,"⚙️":`settings`,"📄":`file`,"🗑":`trash`,"🗑️":`trash`,"⚠":`warning`,"⚠️":`warning`,"💡":`lightbulb`,"🦈":`shark`,"💭":`thinking`,"🔍":`search`,"🌐":`web`,"⚡":`exec`,"🗜":`compacting`,"🗜️":`compacting`,"📝":`plan`,"📑":`clipboard`,"🤖":`robot`,"📋":`clipboard`,"🔄":`refresh`,"🎨":`palette`,"🎤":`mic`,"🔗":`link`,"🫡":`salute`,"📎":`paperclip`,"💾":`save`,"🎮":`gamepad`,"🏠":`house`,"📡":`radio`,"📂":`folder`,"✏️":`pencil`,"📊":`chart`,"🎙️":`mic`};function F(e){let t=Xe[e];return t?P[t]:e}function Ze(e){return e===`✅`?`done`:e===`❌`?`error`:null}function Qe(e=document.body){let t=e.querySelectorAll(`[data-icon]`);for(let e of t){let t=e.dataset.icon;t&&P[t]&&(e.innerHTML=P[t],e.classList.add(`icon-hydrated`))}}function $e(e){let t=[],n=e.replace(/```[\s\S]*?```/g,e=>(t.push(e),`\x00P${t.length-1}\x00`)).replace(/`[^`]+`/g,e=>(t.push(e),`\x00P${t.length-1}\x00`));return n=n.replace(/([\p{P}])\*\*(?=[^\s\p{P}])/gu,(e,t)=>t===`*`?e:t+`​**`),n=n.replace(/\x00P(\d+)\x00/g,(e,n)=>t[Number(n)]),n}var I=0;function et(e){let t=new Map;return{text:e.replace(/^ {0,3}(`{3,}|~{3,})[^\n]*\n[\s\S]*?\n {0,3}\1[ \t]*$/gm,e=>{let n=`\x00FENCE-${I++}\x00`;return t.set(n,e),n}),fences:t}}function tt(e,t){for(let[n,r]of t)e=e.replace(n,()=>r);return e}function nt(e,t=!1){let n=[],r=``,i=0;for(;i<e.length;){let a=e.indexOf(`<svg`,i);if(a===-1){r+=e.slice(i);break}let o=e[a+4];if(o&&!/[\s\/>]/.test(o)){r+=e.slice(i,a+4),i=a+4;continue}r+=e.slice(i,a);let s=0,c=a,l=!1;for(;c<e.length;){let t=e.indexOf(`<svg`,c+1),o=e.indexOf(`</svg>`,c+(c===a?0:1));if(o===-1)break;if(t!==-1&&t<o){let n=e[t+4];n&&/[\s\/>]/.test(n)&&s++,c=t+4}else if(s===0){let t=o+6,s=e.slice(a,t),c=I++,u=`\n\n<div data-jaw-svg="${c}"></div>\n\n`;n.push({id:c,index:a,length:s.length,svg:s,kind:`complete`,placeholder:u}),r+=u,i=t,l=!0;break}else s--,c=o+6}if(!l){let o=I++;if(t){let t=e.slice(a),s=`\n\n<div data-jaw-svg="${o}" data-jaw-kind="partial"></div>\n\n`;n.push({id:o,index:a,length:t.length,svg:``,kind:`partial`,placeholder:s}),r+=s,i=e.length}else{let t=`\n\n<div data-jaw-svg="${o}" data-jaw-kind="error"></div>\n\n`,s=e.slice(a),c=s.search(/\n\s*\n/),l=c===-1?s.length:c;n.push({id:o,index:a,length:l,svg:``,kind:`error`,placeholder:t}),r+=t,i=a+l}}}return{text:r,blocks:n}}l.registerLanguage(`javascript`,s),l.registerLanguage(`js`,s),l.registerLanguage(`typescript`,o),l.registerLanguage(`ts`,o),l.registerLanguage(`python`,p),l.registerLanguage(`py`,p),l.registerLanguage(`bash`,e),l.registerLanguage(`shell`,m),l.registerLanguage(`sh`,m),l.registerLanguage(`json`,c),l.registerLanguage(`css`,n),l.registerLanguage(`xml`,r),l.registerLanguage(`html`,r),l.registerLanguage(`markdown`,d),l.registerLanguage(`md`,d),l.registerLanguage(`yaml`,h),l.registerLanguage(`yml`,h),l.registerLanguage(`sql`,t),l.registerLanguage(`rust`,u),l.registerLanguage(`rs`,u),l.registerLanguage(`go`,re),l.registerLanguage(`java`,ee),l.registerLanguage(`cpp`,g),l.registerLanguage(`c`,g),l.registerLanguage(`diff`,ne),l.registerLanguage(`plaintext`,f),l.registerLanguage(`text`,f);var L=null,R=null;function rt(){return document.documentElement.getAttribute(`data-theme`)===`light`?{primaryColor:`#e2e8f0`,primaryTextColor:`#1a202c`,primaryBorderColor:`#a0aec0`,lineColor:`#718096`,secondaryColor:`#ebf8ff`,tertiaryColor:`#f7fafc`,background:`transparent`,mainBkg:`#e2e8f0`,nodeBorder:`#a0aec0`,clusterBkg:`#f7fafc`,clusterBorder:`#cbd5e0`,titleColor:`#1a202c`,edgeLabelBackground:`#f7fafc`}:{primaryColor:`#2d3748`,primaryTextColor:`#e2e8f0`,primaryBorderColor:`#4a5568`,lineColor:`#718096`,secondaryColor:`#1a365d`,tertiaryColor:`#1a202c`,background:`transparent`,mainBkg:`#2d3748`,nodeBorder:`#4a5568`,clusterBkg:`#1a202c`,clusterBorder:`#2d3748`,titleColor:`#e2e8f0`,edgeLabelBackground:`#1a202c`}}async function z(){let e=document.documentElement.getAttribute(`data-theme`)||`dark`;return L||(L=await v(()=>import(`./mermaid.core-BoxIvw7E.js`),[]),L.default.setParseErrorHandler(()=>{})),R!==e&&(R=e,L.default.initialize({startOnLoad:!1,theme:`base`,themeVariables:rt(),securityLevel:`strict`,suppressErrorRendering:!0})),L.default}function it(e){let t=_.sanitize(e,{USE_PROFILES:{svg:!0,svgFilters:!0},FORBID_TAGS:[`script`,`iframe`,`object`,`embed`,`form`,`input`,`foreignObject`,`animate`,`set`,`animateTransform`,`animateMotion`],FORBID_ATTR:[`onerror`,`onclick`,`onload`,`onmouseover`,`onfocus`,`onblur`,`background`]}),n=document.createElement(`div`);n.innerHTML=t;for(let e of n.querySelectorAll(`style`)){let t=e.textContent||``;t=t.replace(/@import\b[^;]*;?/gi,`/* stripped */`),t=t.replace(/@font-face\s*\{[^}]*\}/gi,`/* stripped */`),t=t.replace(/url\s*\(\s*(?!['"]?#)[^)]*\)/gi,`none`),e.textContent=t}return n.innerHTML}function B(e){return e.replace(/&/g,`&amp;`).replace(/</g,`&lt;`).replace(/>/g,`&gt;`).replace(/"/g,`&quot;`).replace(/'/g,`&#39;`)}function V(e){return _.sanitize(e,{USE_PROFILES:{html:!0,svg:!0,svgFilters:!0},FORBID_TAGS:[`script`,`style`,`iframe`,`object`,`embed`,`form`,`input`,`foreignObject`,`animate`,`set`,`animateTransform`,`animateMotion`],FORBID_ATTR:[`onerror`,`onclick`,`onload`,`onmouseover`,`onfocus`,`onblur`,`background`],ADD_TAGS:[`use`],ADD_ATTR:[`aria-hidden`,`xmlns`,`viewBox`,`role`,`aria-label`,`data-jaw-svg`,`data-jaw-kind`]})}var at=`http://www.w3.org/2000/svg`,ot=new Set([`a`,`area`,`link`]);_.addHook(`afterSanitizeAttributes`,e=>{let t=e.tagName.toLowerCase();if(e.namespaceURI===at||!ot.has(t)){let t=e.getAttribute(`href`)||``;t&&!t.startsWith(`#`)&&e.removeAttribute(`href`)}let n=e.getAttributeNS(`http://www.w3.org/1999/xlink`,`href`)||e.getAttribute(`xlink:href`)||``;if(n&&!n.startsWith(`#`)&&(e.removeAttributeNS(`http://www.w3.org/1999/xlink`,`href`),e.removeAttribute(`xlink:href`)),t===`image`||t===`feimage`){let t=e.getAttribute(`src`)||``;t&&!t.startsWith(`#`)&&e.removeAttribute(`src`)}let r=[`fill`,`stroke`,`filter`,`mask`,`clip-path`,`marker-start`,`marker-mid`,`marker-end`,`cursor`];if(e.hasAttribute(`style`)){let t=e.style?.cssText||``;if(/url\s*\(/i.test(t)){let n=t.replace(/url\s*\(\s*(?!['"]?#)[^)]*\)/gi,`none`);e.style.cssText=n}}for(let t of r)if(e.hasAttribute(t)){let n=e.getAttribute(t)||``;if(/url\s*\(/i.test(n)){let r=n.replace(/url\s*\(\s*(?!['"]?#)[^)]*\)/gi,`none`);e.setAttribute(t,r)}}});var st=/["'](?:subtasks|employee_config|agent_phases|orchestration_plan)["']\s*:/;function H(e){let t=e.replace(/```json\n([\s\S]*?)\n```/g,(e,t)=>st.test(t)?``:e);return t=t.replace(/\{[^{}]*"subtasks"\s*:\s*\[[\s\S]*?\]\s*\}/g,``).trim(),t}function ct(e){let t=[],n=[],r=e.replace(/```[\s\S]*?```/g,e=>(n.push(e),`\x00C${n.length-1}\x00`)).replace(/`[^`]+`/g,e=>(n.push(e),`\x00C${n.length-1}\x00`));return r=r.replace(/\$\$([\s\S]+?)\$\$/g,(e,n)=>(t.push({tex:n.trim(),displayMode:!0}),`\x00MATH-${t.length-1}\x00`)),r=r.replace(/\\\[([\s\S]+?)\\\]/g,(e,n)=>(t.push({tex:n.trim(),displayMode:!0}),`\x00MATH-${t.length-1}\x00`)),r=r.replace(/(?<!\$)\$(?!\$)([^\n$]+?)\$(?!\$)/g,(e,n)=>(t.push({tex:n.trim(),displayMode:!1}),`\x00MATH-${t.length-1}\x00`)),r=r.replace(/\\\((.+?)\\\)/g,(e,n)=>(t.push({tex:n.trim(),displayMode:!1}),`\x00MATH-${t.length-1}\x00`)),r=r.replace(/\x00C(\d+)\x00/g,(e,t)=>n[Number(t)]),{text:r,blocks:t}}function lt(e,t,n=!1){return e.replace(/\x00MATH-(\d+)\x00/g,(e,r)=>{let i=t[Number(r)];if(!i)return`<code title="math placeholder error">[math error]</code>`;if(n)return i.displayMode?`<div class="math-placeholder">${B(i.tex)}</div>`:`<code class="math-placeholder">${B(i.tex)}</code>`;try{return te.renderToString(i.tex,{displayMode:i.displayMode,throwOnError:!1})}catch{return i.displayMode?`<pre><code>${B(i.tex)}</code></pre>`:`<code>${B(i.tex)}</code>`}})}var U=0;async function ut(){R=null;let e=document.querySelectorAll(`.mermaid-rendered`);if(!e.length)return;let t=await z();for(let n of e){let e=n.dataset.mermaidCode;if(!e)continue;let r=`mermaid-${++U}`;try{let{svg:i}=await t.render(r,e);n.innerHTML=i,G(n)}catch{}}}var W=null;function dt(){W||=new IntersectionObserver(e=>{for(let t of e){if(!t.isIntersecting)continue;let e=t.target;e.classList.contains(`mermaid-pending`)&&(W.unobserve(e),ft(e))}},{rootMargin:`200px`})}function G(e){e.querySelector(`.mermaid-copy-btn`)?.remove(),e.querySelector(`.mermaid-save-btn`)?.remove();let t=document.createElement(`button`);t.className=`mermaid-save-btn`,t.type=`button`,t.ariaLabel=`Save as image`,t.title=`Save`,t.innerHTML=P.download,e.appendChild(t);let n=document.createElement(`button`);n.className=`mermaid-copy-btn`,n.type=`button`,n.ariaLabel=`Copy source`,n.title=`Copy`,n.innerHTML=P.copy,e.appendChild(n)}function K(e,t,n){e.classList.remove(`mermaid-rendered`),e.innerHTML=`
1
+ import{A as e,C as t,D as n,E as r,F as i,I as a,M as o,N as s,O as c,P as l,S as u,T as d,_ as f,b as ee,j as p,k as m,u as te,v as ne,w as h,x as re,y as g}from"./vendor-render-D2YP6GiF.js";import{Q as _,Z as v}from"./vendor-mermaid-lvHqQdfg.js";import{A as ie,B as ae,C as oe,D as se,E as ce,F as le,G as ue,H as de,I as fe,J as pe,K as me,L as he,M as ge,N as _e,O as ve,P as ye,R as be,S as xe,T as Se,U as Ce,V as we,W as Te,_ as Ee,a as De,b as Oe,c as y,d as b,f as x,g as S,h as C,i as w,j as T,k as ke,l as Ae,m as je,n as Me,o as Ne,p as Pe,q as Fe,r as Ie,s as Le,t as Re,u as ze,v as Be,w as Ve,x as He,y as Ue,z as We}from"./vendor-icons-1Ec7ZWcT.js";var E=`ko`,D={},O={};async function Ge(){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`}O=await k(`ko`),D=e===`ko`?O:await k(e),E=e,j()}async function k(e){try{let{api:t}=await v(async()=>{let{api:e}=await import(`./api-Bbmmo0o1.js`);return{api:e}},[]);return await t(`/api/i18n/${e}`)||{}}catch{return{}}}function A(e,t={}){let n=D[e]??O[e]??e;for(let[e,r]of Object.entries(t))n=n.replaceAll(`{${e}}`,String(r));return n}function j(){document.querySelectorAll(`[data-i18n]`).forEach(e=>{let t=e.getAttribute(`data-i18n`);t&&(e.textContent=A(t))}),document.querySelectorAll(`[data-i18n-placeholder]`).forEach(e=>{let t=e.getAttribute(`data-i18n-placeholder`);t&&(e.placeholder=A(t))}),document.querySelectorAll(`[data-i18n-title]`).forEach(e=>{let t=e.getAttribute(`data-i18n-title`);t&&(e.title=A(t))}),document.querySelectorAll(`[data-i18n-aria]`).forEach(e=>{let t=e.getAttribute(`data-i18n-aria`);t&&e.setAttribute(`aria-label`,A(t))})}async function Ke(e){if(e!==E){D=e===`ko`?O:await k(e),E=e;try{localStorage.setItem(`claw_locale`,e)}catch{}j();try{let{loadEmployees:e}=await v(async()=>{let{loadEmployees:e}=await import(`./employees-Epnu4Dr0.js`);return{loadEmployees:e}},[]);e()}catch{}try{let{loadSkills:e}=await v(async()=>{let{loadSkills:e}=await import(`./skills-BG6RWbOV.js`);return{loadSkills:e}},[]);e()}catch{}try{let{loadCommands:e}=await v(async()=>{let{loadCommands:e}=await import(`./slash-commands-DRdRDhAK.js`);return{loadCommands:e}},[]);e()}catch{}try{let{loadSettings:e}=await v(async()=>{let{loadSettings:e}=await import(`./settings-uJ9ftA50.js`);return{loadSettings:e}},[]);e()}catch{}}}function qe(){return E}function Je(e,t={}){let n=new URL(e,location.origin);return n.searchParams.has(`locale`)||n.searchParams.set(`locale`,E),fetch(n.toString(),t)}var M=14,Ye=16;function N(e,t=Ye){return pe(e,{size:t})}var P={check:N(be),error:N(he),warning:N(w),skip:N(Le),tool:N(Ie),thinking:N(Oe),search:N(ze),web:N(ie),exec:N(Re),compacting:N(Ee),plan:N(Be),brain:N(Te),heartPulse:N(ve),lock:N(He),lockOpen:N(xe),key:N(Se),settings:N(y),file:N(_e),trash:N(De),lightbulb:N(Ve),refresh:N(x),mic:N(Ue),clipboard:N(fe),robot:N(ue),palette:N(S),link:N(oe),salute:N(ke),shark:`🦈`,paperclip:N(C),save:N(b),gamepad:N(T),house:N(ce),radio:N(Pe),folder:N(ge),pencil:N(je),chart:N(Ce),hourglass:N(se),stop:N(Ne),close:N(Me,M),send:N(Ae),copy:N(le,M),download:N(ye,M),checkSimple:N(de,M),chevronLeft:N(ae,M),chevronRight:N(We,M),chevronDown:N(we,M),arrowLeft:N(Fe,M),arrowRight:N(me,M)},Xe={"✅":`check`,"❌":`error`,"🔧":`tool`,"⏭":`skip`,"🧠":`brain`,"💓":`heartPulse`,"🔒":`lock`,"🔓":`lockOpen`,"🔑":`key`,"⚙":`settings`,"⚙️":`settings`,"📄":`file`,"🗑":`trash`,"🗑️":`trash`,"⚠":`warning`,"⚠️":`warning`,"💡":`lightbulb`,"🦈":`shark`,"💭":`thinking`,"🔍":`search`,"🌐":`web`,"⚡":`exec`,"🗜":`compacting`,"🗜️":`compacting`,"📝":`plan`,"📑":`clipboard`,"🤖":`robot`,"📋":`clipboard`,"🔄":`refresh`,"🎨":`palette`,"🎤":`mic`,"🔗":`link`,"🫡":`salute`,"📎":`paperclip`,"💾":`save`,"🎮":`gamepad`,"🏠":`house`,"📡":`radio`,"📂":`folder`,"✏️":`pencil`,"📊":`chart`,"🎙️":`mic`};function F(e){let t=Xe[e];return t?P[t]:e}function Ze(e){return e===`✅`?`done`:e===`❌`?`error`:null}function Qe(e=document.body){let t=e.querySelectorAll(`[data-icon]`);for(let e of t){let t=e.dataset.icon;t&&P[t]&&(e.innerHTML=P[t],e.classList.add(`icon-hydrated`))}}function $e(e){let t=[],n=e.replace(/```[\s\S]*?```/g,e=>(t.push(e),`\x00P${t.length-1}\x00`)).replace(/`[^`]+`/g,e=>(t.push(e),`\x00P${t.length-1}\x00`));return n=n.replace(/([\p{P}])\*\*(?=[^\s\p{P}])/gu,(e,t)=>t===`*`?e:t+`​**`),n=n.replace(/\x00P(\d+)\x00/g,(e,n)=>t[Number(n)]),n}var I=0;function et(e){let t=new Map;return{text:e.replace(/^ {0,3}(`{3,}|~{3,})[^\n]*\n[\s\S]*?\n {0,3}\1[ \t]*$/gm,e=>{let n=`\x00FENCE-${I++}\x00`;return t.set(n,e),n}),fences:t}}function tt(e,t){for(let[n,r]of t)e=e.replace(n,()=>r);return e}function nt(e,t=!1){let n=[],r=``,i=0;for(;i<e.length;){let a=e.indexOf(`<svg`,i);if(a===-1){r+=e.slice(i);break}let o=e[a+4];if(o&&!/[\s\/>]/.test(o)){r+=e.slice(i,a+4),i=a+4;continue}r+=e.slice(i,a);let s=0,c=a,l=!1;for(;c<e.length;){let t=e.indexOf(`<svg`,c+1),o=e.indexOf(`</svg>`,c+(c===a?0:1));if(o===-1)break;if(t!==-1&&t<o){let n=e[t+4];n&&/[\s\/>]/.test(n)&&s++,c=t+4}else if(s===0){let t=o+6,s=e.slice(a,t),c=I++,u=`\n\n<div data-jaw-svg="${c}"></div>\n\n`;n.push({id:c,index:a,length:s.length,svg:s,kind:`complete`,placeholder:u}),r+=u,i=t,l=!0;break}else s--,c=o+6}if(!l){let o=I++;if(t){let t=e.slice(a),s=`\n\n<div data-jaw-svg="${o}" data-jaw-kind="partial"></div>\n\n`;n.push({id:o,index:a,length:t.length,svg:``,kind:`partial`,placeholder:s}),r+=s,i=e.length}else{let t=`\n\n<div data-jaw-svg="${o}" data-jaw-kind="error"></div>\n\n`,s=e.slice(a),c=s.search(/\n\s*\n/),l=c===-1?s.length:c;n.push({id:o,index:a,length:l,svg:``,kind:`error`,placeholder:t}),r+=t,i=a+l}}}return{text:r,blocks:n}}l.registerLanguage(`javascript`,s),l.registerLanguage(`js`,s),l.registerLanguage(`typescript`,o),l.registerLanguage(`ts`,o),l.registerLanguage(`python`,p),l.registerLanguage(`py`,p),l.registerLanguage(`bash`,e),l.registerLanguage(`shell`,m),l.registerLanguage(`sh`,m),l.registerLanguage(`json`,c),l.registerLanguage(`css`,n),l.registerLanguage(`xml`,r),l.registerLanguage(`html`,r),l.registerLanguage(`markdown`,d),l.registerLanguage(`md`,d),l.registerLanguage(`yaml`,h),l.registerLanguage(`yml`,h),l.registerLanguage(`sql`,t),l.registerLanguage(`rust`,u),l.registerLanguage(`rs`,u),l.registerLanguage(`go`,re),l.registerLanguage(`java`,ee),l.registerLanguage(`cpp`,g),l.registerLanguage(`c`,g),l.registerLanguage(`diff`,ne),l.registerLanguage(`plaintext`,f),l.registerLanguage(`text`,f);var L=null,R=null;function rt(){return document.documentElement.getAttribute(`data-theme`)===`light`?{primaryColor:`#e2e8f0`,primaryTextColor:`#1a202c`,primaryBorderColor:`#a0aec0`,lineColor:`#718096`,secondaryColor:`#ebf8ff`,tertiaryColor:`#f7fafc`,background:`transparent`,mainBkg:`#e2e8f0`,nodeBorder:`#a0aec0`,clusterBkg:`#f7fafc`,clusterBorder:`#cbd5e0`,titleColor:`#1a202c`,edgeLabelBackground:`#f7fafc`}:{primaryColor:`#2d3748`,primaryTextColor:`#e2e8f0`,primaryBorderColor:`#4a5568`,lineColor:`#718096`,secondaryColor:`#1a365d`,tertiaryColor:`#1a202c`,background:`transparent`,mainBkg:`#2d3748`,nodeBorder:`#4a5568`,clusterBkg:`#1a202c`,clusterBorder:`#2d3748`,titleColor:`#e2e8f0`,edgeLabelBackground:`#1a202c`}}async function z(){let e=document.documentElement.getAttribute(`data-theme`)||`dark`;return L||(L=await v(()=>import(`./mermaid.core-BoxIvw7E.js`),[]),L.default.setParseErrorHandler(()=>{})),R!==e&&(R=e,L.default.initialize({startOnLoad:!1,theme:`base`,themeVariables:rt(),securityLevel:`strict`,suppressErrorRendering:!0})),L.default}function it(e){let t=_.sanitize(e,{USE_PROFILES:{svg:!0,svgFilters:!0},FORBID_TAGS:[`script`,`iframe`,`object`,`embed`,`form`,`input`,`foreignObject`,`animate`,`set`,`animateTransform`,`animateMotion`],FORBID_ATTR:[`onerror`,`onclick`,`onload`,`onmouseover`,`onfocus`,`onblur`,`background`]}),n=document.createElement(`div`);n.innerHTML=t;for(let e of n.querySelectorAll(`style`)){let t=e.textContent||``;t=t.replace(/@import\b[^;]*;?/gi,`/* stripped */`),t=t.replace(/@font-face\s*\{[^}]*\}/gi,`/* stripped */`),t=t.replace(/url\s*\(\s*(?!['"]?#)[^)]*\)/gi,`none`),e.textContent=t}return n.innerHTML}function B(e){return e.replace(/&/g,`&amp;`).replace(/</g,`&lt;`).replace(/>/g,`&gt;`).replace(/"/g,`&quot;`).replace(/'/g,`&#39;`)}function V(e){return _.sanitize(e,{USE_PROFILES:{html:!0,svg:!0,svgFilters:!0},FORBID_TAGS:[`script`,`style`,`iframe`,`object`,`embed`,`form`,`input`,`foreignObject`,`animate`,`set`,`animateTransform`,`animateMotion`],FORBID_ATTR:[`onerror`,`onclick`,`onload`,`onmouseover`,`onfocus`,`onblur`,`background`],ADD_TAGS:[`use`],ADD_ATTR:[`aria-hidden`,`xmlns`,`viewBox`,`role`,`aria-label`,`data-jaw-svg`,`data-jaw-kind`]})}var at=`http://www.w3.org/2000/svg`,ot=new Set([`a`,`area`,`link`]);_.addHook(`afterSanitizeAttributes`,e=>{let t=e.tagName.toLowerCase();if(e.namespaceURI===at||!ot.has(t)){let t=e.getAttribute(`href`)||``;t&&!t.startsWith(`#`)&&e.removeAttribute(`href`)}let n=e.getAttributeNS(`http://www.w3.org/1999/xlink`,`href`)||e.getAttribute(`xlink:href`)||``;if(n&&!n.startsWith(`#`)&&(e.removeAttributeNS(`http://www.w3.org/1999/xlink`,`href`),e.removeAttribute(`xlink:href`)),t===`image`||t===`feimage`){let t=e.getAttribute(`src`)||``;t&&!t.startsWith(`#`)&&e.removeAttribute(`src`)}let r=[`fill`,`stroke`,`filter`,`mask`,`clip-path`,`marker-start`,`marker-mid`,`marker-end`,`cursor`];if(e.hasAttribute(`style`)){let t=e.style?.cssText||``;if(/url\s*\(/i.test(t)){let n=t.replace(/url\s*\(\s*(?!['"]?#)[^)]*\)/gi,`none`);e.style.cssText=n}}for(let t of r)if(e.hasAttribute(t)){let n=e.getAttribute(t)||``;if(/url\s*\(/i.test(n)){let r=n.replace(/url\s*\(\s*(?!['"]?#)[^)]*\)/gi,`none`);e.setAttribute(t,r)}}});var st=/["'](?:subtasks|employee_config|agent_phases|orchestration_plan)["']\s*:/;function H(e){let t=e.replace(/```json\n([\s\S]*?)\n```/g,(e,t)=>st.test(t)?``:e);return t=t.replace(/\{[^{}]*"subtasks"\s*:\s*\[[\s\S]*?\]\s*\}/g,``).trim(),t}function ct(e){let t=[],n=[],r=e.replace(/```[\s\S]*?```/g,e=>(n.push(e),`\x00C${n.length-1}\x00`)).replace(/`[^`]+`/g,e=>(n.push(e),`\x00C${n.length-1}\x00`));return r=r.replace(/\$\$([\s\S]+?)\$\$/g,(e,n)=>(t.push({tex:n.trim(),displayMode:!0}),`\x00MATH-${t.length-1}\x00`)),r=r.replace(/\\\[([\s\S]+?)\\\]/g,(e,n)=>(t.push({tex:n.trim(),displayMode:!0}),`\x00MATH-${t.length-1}\x00`)),r=r.replace(/(?<!\$)\$(?!\$)([^\n$]+?)\$(?!\$)/g,(e,n)=>(t.push({tex:n.trim(),displayMode:!1}),`\x00MATH-${t.length-1}\x00`)),r=r.replace(/\\\((.+?)\\\)/g,(e,n)=>(t.push({tex:n.trim(),displayMode:!1}),`\x00MATH-${t.length-1}\x00`)),r=r.replace(/\x00C(\d+)\x00/g,(e,t)=>n[Number(t)]),{text:r,blocks:t}}function lt(e,t,n=!1){return e.replace(/\x00MATH-(\d+)\x00/g,(e,r)=>{let i=t[Number(r)];if(!i)return`<code title="math placeholder error">[math error]</code>`;if(n)return i.displayMode?`<div class="math-placeholder">${B(i.tex)}</div>`:`<code class="math-placeholder">${B(i.tex)}</code>`;try{return te.renderToString(i.tex,{displayMode:i.displayMode,throwOnError:!1})}catch{return i.displayMode?`<pre><code>${B(i.tex)}</code></pre>`:`<code>${B(i.tex)}</code>`}})}var U=0;async function ut(){R=null;let e=document.querySelectorAll(`.mermaid-rendered`);if(!e.length)return;let t=await z();for(let n of e){let e=n.dataset.mermaidCode;if(!e)continue;let r=`mermaid-${++U}`;try{let{svg:i}=await t.render(r,e);n.innerHTML=i,G(n)}catch{}}}var W=null;function dt(){W||=new IntersectionObserver(e=>{for(let t of e){if(!t.isIntersecting)continue;let e=t.target;e.classList.contains(`mermaid-pending`)&&(W.unobserve(e),ft(e))}},{rootMargin:`200px`})}function G(e){e.querySelector(`.mermaid-copy-btn`)?.remove(),e.querySelector(`.mermaid-save-btn`)?.remove();let t=document.createElement(`button`);t.className=`mermaid-save-btn`,t.type=`button`,t.ariaLabel=`Save as image`,t.title=`Save`,t.innerHTML=P.download,e.appendChild(t);let n=document.createElement(`button`);n.className=`mermaid-copy-btn`,n.type=`button`,n.ariaLabel=`Copy source`,n.title=`Copy`,n.innerHTML=P.copy,e.appendChild(n)}function K(e,t,n){e.classList.remove(`mermaid-rendered`),e.innerHTML=`
2
2
  <div class="mermaid-error">
3
3
  <div class="mermaid-error-title">${P.warning} ${B(A(`mermaid.renderFail`)||`Mermaid render failed`)}</div>
4
4
  <div class="mermaid-error-msg">${B(n.slice(0,200))}</div>
@@ -1,4 +1,4 @@
1
- import{t as e}from"./state-O6NVkWcL.js";import{m as t,n,o as r}from"./render-C5gpc065.js";import{n as i,r as a,t as o}from"./api-Ci-lgwRp.js";import{n as s}from"./locale-DIXc-_34.js";import{a as c,i as l,r as u,t as d}from"./constants-C8_0OtK2.js";function f(e){let t=document.getElementById(`sttEngine`),n=document.getElementById(`sttGeminiKey`),r=document.getElementById(`sttGeminiModel`),i=document.getElementById(`sttGeminiModelCustom`),o=document.getElementById(`sttWhisperModel`),s=document.getElementById(`sttOpenaiBaseUrl`),c=document.getElementById(`sttOpenaiKey`),l=document.getElementById(`sttOpenaiModel`),u=document.getElementById(`sttVertexJson`);if(t&&(t.value=e.engine||`auto`),n&&(n.placeholder=e.geminiKeySet?`✓ 입력됨 ····${e.geminiKeyLast4||``}`:`AIza...`),r){let t=e.geminiModel||`gemini-2.5-flash-lite`;Array.from(r.options).some(e=>e.value===t)?r.value=t:(r.value=`__custom__`,i&&(i.value=t,i.style.display=``))}o&&(o.value=e.whisperModel||`mlx-community/whisper-large-v3-turbo`),s&&(s.value=e.openaiBaseUrl||``),c&&(c.placeholder=e.openaiKeySet?`✓ 입력됨 ····${e.openaiKeyLast4||``}`:`sk-...`),l&&(l.value=e.openaiModel||``),u&&(u.value=e.vertexConfig||``);function d(){let e=t?.value||`auto`,n=e===`auto`||e===`gemini`,r=e===`openai`,i=e===`vertex`,a=e===`auto`||e===`whisper`;document.querySelectorAll(`.stt-gemini`).forEach(e=>e.style.display=n?``:`none`),document.querySelectorAll(`.stt-openai`).forEach(e=>e.style.display=r?``:`none`),document.querySelectorAll(`.stt-vertex`).forEach(e=>e.style.display=i?``:`none`),document.querySelectorAll(`.stt-whisper`).forEach(e=>e.style.display=a?``:`none`)}d();async function f(){let e={stt:{engine:t?.value||`auto`,geminiModel:(r?.value===`__custom__`?i?.value:r?.value)||`gemini-2.5-flash-lite`,whisperModel:o?.value||``,openaiBaseUrl:s?.value||``,openaiModel:l?.value||``,vertexConfig:u?.value||``}};n?.value&&(e.stt.geminiApiKey=n.value),c?.value&&(e.stt.openaiApiKey=c.value),console.log(`[stt] saving:`,{engine:e.stt.engine,hasGeminiKey:!!e.stt.geminiApiKey,hasOpenaiKey:!!e.stt.openaiApiKey});try{if(await a(`/api/settings`,`PUT`,e),n?.value){let e=n.value.slice(-4);n.value=``,n.placeholder=`✓ 입력됨 ····${e}`}if(c?.value){let e=c.value.slice(-4);c.value=``,c.placeholder=`✓ 입력됨 ····${e}`}}catch(e){console.error(`[stt] save failed:`,e)}}t?.addEventListener(`change`,()=>{d(),f()}),r?.addEventListener(`change`,()=>{i&&(i.style.display=r.value===`__custom__`?``:`none`),r.value!==`__custom__`&&f()}),i?.addEventListener(`blur`,f),n?.addEventListener(`blur`,()=>{n.value&&f()}),c?.addEventListener(`blur`,()=>{c.value&&f()}),s?.addEventListener(`blur`,f),l?.addEventListener(`blur`,f),o?.addEventListener(`blur`,f),u?.addEventListener(`blur`,f)}async function p(){let e=document.getElementById(`tgToken`)?.value.trim()||``,t=document.getElementById(`tgChatIds`)?.value.trim()||``;await a(`/api/settings`,`PUT`,{telegram:{token:e,allowedChatIds:t?t.split(`,`).map(e=>parseInt(e.trim(),10)).filter(e=>!isNaN(e)):[]}})}async function m(e){document.getElementById(`tgOn`)?.classList.toggle(`active`,e),document.getElementById(`tgOff`)?.classList.toggle(`active`,!e),await a(`/api/settings`,`PUT`,{telegram:{enabled:e}})}async function h(e){document.getElementById(`tgForwardOn`)?.classList.toggle(`active`,e),document.getElementById(`tgForwardOff`)?.classList.toggle(`active`,!e),await a(`/api/settings`,`PUT`,{telegram:{forwardAll:e}})}function ee(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 r=document.getElementById(`tgChatIds`);t.allowedChatIds?.length&&r&&(r.value=t.allowedChatIds.join(`, `));let i=t.forwardAll!==!1;document.getElementById(`tgForwardOn`)?.classList.toggle(`active`,i),document.getElementById(`tgForwardOff`)?.classList.toggle(`active`,!i)}async function te(){let e=document.getElementById(`dcToken`)?.value.trim()||``,t=document.getElementById(`dcGuildId`)?.value.trim()||``,n=document.getElementById(`dcChannelIds`)?.value.trim()||``;await a(`/api/settings`,`PUT`,{discord:{token:e,guildId:t,channelIds:n?n.split(`,`).map(e=>e.trim()).filter(Boolean):[]}})}async function ne(e){document.getElementById(`dcOn`)?.classList.toggle(`active`,e),document.getElementById(`dcOff`)?.classList.toggle(`active`,!e),await a(`/api/settings`,`PUT`,{discord:{enabled:e}})}async function re(e){document.getElementById(`dcForwardOn`)?.classList.toggle(`active`,e),document.getElementById(`dcForwardOff`)?.classList.toggle(`active`,!e),await a(`/api/settings`,`PUT`,{discord:{forwardAll:e}})}async function ie(e){document.getElementById(`dcAllowBotsOn`)?.classList.toggle(`active`,e),document.getElementById(`dcAllowBotsOff`)?.classList.toggle(`active`,!e),await a(`/api/settings`,`PUT`,{discord:{allowBots:e}})}async function g(e){document.getElementById(`dcMentionOn`)?.classList.toggle(`active`,e),document.getElementById(`dcMentionOff`)?.classList.toggle(`active`,!e),await a(`/api/settings`,`PUT`,{discord:{mentionOnly:e}})}function _(e){if(!e.discord)return;let t=e.discord;document.getElementById(`dcOn`)?.classList.toggle(`active`,!!t.enabled),document.getElementById(`dcOff`)?.classList.toggle(`active`,!t.enabled);let n=document.getElementById(`dcToken`);t.token&&n&&(n.value=t.token);let r=document.getElementById(`dcGuildId`);t.guildId&&r&&(r.value=t.guildId);let i=document.getElementById(`dcChannelIds`);t.channelIds?.length&&i&&(i.value=t.channelIds.join(`, `));let a=t.forwardAll!==!1;document.getElementById(`dcForwardOn`)?.classList.toggle(`active`,a),document.getElementById(`dcForwardOff`)?.classList.toggle(`active`,!a);let o=!!t.allowBots;document.getElementById(`dcAllowBotsOn`)?.classList.toggle(`active`,o),document.getElementById(`dcAllowBotsOff`)?.classList.toggle(`active`,!o);let s=!!t.mentionOnly;document.getElementById(`dcMentionOn`)?.classList.toggle(`active`,s),document.getElementById(`dcMentionOff`)?.classList.toggle(`active`,!s)}async function v(e){document.getElementById(`chTelegram`)?.classList.toggle(`active`,e===`telegram`),document.getElementById(`chDiscord`)?.classList.toggle(`active`,e===`discord`),document.getElementById(`channelTelegramSettings`)?.style.setProperty(`display`,e===`telegram`?``:`none`),document.getElementById(`channelDiscordSettings`)?.style.setProperty(`display`,e===`discord`?``:`none`),await a(`/api/settings`,`PUT`,{channel:e})}function y(e){let t=e.channel||`telegram`;document.getElementById(`chTelegram`)?.classList.toggle(`active`,t===`telegram`),document.getElementById(`chDiscord`)?.classList.toggle(`active`,t===`discord`),document.getElementById(`channelTelegramSettings`)?.style.setProperty(`display`,t===`telegram`?``:`none`),document.getElementById(`channelDiscordSettings`)?.style.setProperty(`display`,t===`discord`?``:`none`)}function b(e){let r=document.getElementById(`fallbackOrderList`);if(!r)return;let i=Object.keys(e.perCli||{}),a=e.fallbackOrder||[],o=Math.min(i.length-1,3),s=``;for(let e=0;e<o;e++){let r=a[e]||``,o=i.map(e=>`<option value="${n(e)}" ${e===r?`selected`:``}>${n(e)}</option>`).join(``);s+=`
1
+ import{t as e}from"./state-O6NVkWcL.js";import{m as t,n,o as r}from"./render-DIojC86t.js";import{n as i,r as a,t as o}from"./api-Ci-lgwRp.js";import{n as s}from"./locale-DIXc-_34.js";import{a as c,i as l,r as u,t as d}from"./constants-C8_0OtK2.js";function f(e){let t=document.getElementById(`sttEngine`),n=document.getElementById(`sttGeminiKey`),r=document.getElementById(`sttGeminiModel`),i=document.getElementById(`sttGeminiModelCustom`),o=document.getElementById(`sttWhisperModel`),s=document.getElementById(`sttOpenaiBaseUrl`),c=document.getElementById(`sttOpenaiKey`),l=document.getElementById(`sttOpenaiModel`),u=document.getElementById(`sttVertexJson`);if(t&&(t.value=e.engine||`auto`),n&&(n.placeholder=e.geminiKeySet?`✓ 입력됨 ····${e.geminiKeyLast4||``}`:`AIza...`),r){let t=e.geminiModel||`gemini-2.5-flash-lite`;Array.from(r.options).some(e=>e.value===t)?r.value=t:(r.value=`__custom__`,i&&(i.value=t,i.style.display=``))}o&&(o.value=e.whisperModel||`mlx-community/whisper-large-v3-turbo`),s&&(s.value=e.openaiBaseUrl||``),c&&(c.placeholder=e.openaiKeySet?`✓ 입력됨 ····${e.openaiKeyLast4||``}`:`sk-...`),l&&(l.value=e.openaiModel||``),u&&(u.value=e.vertexConfig||``);function d(){let e=t?.value||`auto`,n=e===`auto`||e===`gemini`,r=e===`openai`,i=e===`vertex`,a=e===`auto`||e===`whisper`;document.querySelectorAll(`.stt-gemini`).forEach(e=>e.style.display=n?``:`none`),document.querySelectorAll(`.stt-openai`).forEach(e=>e.style.display=r?``:`none`),document.querySelectorAll(`.stt-vertex`).forEach(e=>e.style.display=i?``:`none`),document.querySelectorAll(`.stt-whisper`).forEach(e=>e.style.display=a?``:`none`)}d();async function f(){let e={stt:{engine:t?.value||`auto`,geminiModel:(r?.value===`__custom__`?i?.value:r?.value)||`gemini-2.5-flash-lite`,whisperModel:o?.value||``,openaiBaseUrl:s?.value||``,openaiModel:l?.value||``,vertexConfig:u?.value||``}};n?.value&&(e.stt.geminiApiKey=n.value),c?.value&&(e.stt.openaiApiKey=c.value),console.log(`[stt] saving:`,{engine:e.stt.engine,hasGeminiKey:!!e.stt.geminiApiKey,hasOpenaiKey:!!e.stt.openaiApiKey});try{if(await a(`/api/settings`,`PUT`,e),n?.value){let e=n.value.slice(-4);n.value=``,n.placeholder=`✓ 입력됨 ····${e}`}if(c?.value){let e=c.value.slice(-4);c.value=``,c.placeholder=`✓ 입력됨 ····${e}`}}catch(e){console.error(`[stt] save failed:`,e)}}t?.addEventListener(`change`,()=>{d(),f()}),r?.addEventListener(`change`,()=>{i&&(i.style.display=r.value===`__custom__`?``:`none`),r.value!==`__custom__`&&f()}),i?.addEventListener(`blur`,f),n?.addEventListener(`blur`,()=>{n.value&&f()}),c?.addEventListener(`blur`,()=>{c.value&&f()}),s?.addEventListener(`blur`,f),l?.addEventListener(`blur`,f),o?.addEventListener(`blur`,f),u?.addEventListener(`blur`,f)}async function p(){let e=document.getElementById(`tgToken`)?.value.trim()||``,t=document.getElementById(`tgChatIds`)?.value.trim()||``;await a(`/api/settings`,`PUT`,{telegram:{token:e,allowedChatIds:t?t.split(`,`).map(e=>parseInt(e.trim(),10)).filter(e=>!isNaN(e)):[]}})}async function m(e){document.getElementById(`tgOn`)?.classList.toggle(`active`,e),document.getElementById(`tgOff`)?.classList.toggle(`active`,!e),await a(`/api/settings`,`PUT`,{telegram:{enabled:e}})}async function h(e){document.getElementById(`tgForwardOn`)?.classList.toggle(`active`,e),document.getElementById(`tgForwardOff`)?.classList.toggle(`active`,!e),await a(`/api/settings`,`PUT`,{telegram:{forwardAll:e}})}function ee(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 r=document.getElementById(`tgChatIds`);t.allowedChatIds?.length&&r&&(r.value=t.allowedChatIds.join(`, `));let i=t.forwardAll!==!1;document.getElementById(`tgForwardOn`)?.classList.toggle(`active`,i),document.getElementById(`tgForwardOff`)?.classList.toggle(`active`,!i)}async function te(){let e=document.getElementById(`dcToken`)?.value.trim()||``,t=document.getElementById(`dcGuildId`)?.value.trim()||``,n=document.getElementById(`dcChannelIds`)?.value.trim()||``;await a(`/api/settings`,`PUT`,{discord:{token:e,guildId:t,channelIds:n?n.split(`,`).map(e=>e.trim()).filter(Boolean):[]}})}async function ne(e){document.getElementById(`dcOn`)?.classList.toggle(`active`,e),document.getElementById(`dcOff`)?.classList.toggle(`active`,!e),await a(`/api/settings`,`PUT`,{discord:{enabled:e}})}async function re(e){document.getElementById(`dcForwardOn`)?.classList.toggle(`active`,e),document.getElementById(`dcForwardOff`)?.classList.toggle(`active`,!e),await a(`/api/settings`,`PUT`,{discord:{forwardAll:e}})}async function ie(e){document.getElementById(`dcAllowBotsOn`)?.classList.toggle(`active`,e),document.getElementById(`dcAllowBotsOff`)?.classList.toggle(`active`,!e),await a(`/api/settings`,`PUT`,{discord:{allowBots:e}})}async function g(e){document.getElementById(`dcMentionOn`)?.classList.toggle(`active`,e),document.getElementById(`dcMentionOff`)?.classList.toggle(`active`,!e),await a(`/api/settings`,`PUT`,{discord:{mentionOnly:e}})}function _(e){if(!e.discord)return;let t=e.discord;document.getElementById(`dcOn`)?.classList.toggle(`active`,!!t.enabled),document.getElementById(`dcOff`)?.classList.toggle(`active`,!t.enabled);let n=document.getElementById(`dcToken`);t.token&&n&&(n.value=t.token);let r=document.getElementById(`dcGuildId`);t.guildId&&r&&(r.value=t.guildId);let i=document.getElementById(`dcChannelIds`);t.channelIds?.length&&i&&(i.value=t.channelIds.join(`, `));let a=t.forwardAll!==!1;document.getElementById(`dcForwardOn`)?.classList.toggle(`active`,a),document.getElementById(`dcForwardOff`)?.classList.toggle(`active`,!a);let o=!!t.allowBots;document.getElementById(`dcAllowBotsOn`)?.classList.toggle(`active`,o),document.getElementById(`dcAllowBotsOff`)?.classList.toggle(`active`,!o);let s=!!t.mentionOnly;document.getElementById(`dcMentionOn`)?.classList.toggle(`active`,s),document.getElementById(`dcMentionOff`)?.classList.toggle(`active`,!s)}async function v(e){document.getElementById(`chTelegram`)?.classList.toggle(`active`,e===`telegram`),document.getElementById(`chDiscord`)?.classList.toggle(`active`,e===`discord`),document.getElementById(`channelTelegramSettings`)?.style.setProperty(`display`,e===`telegram`?``:`none`),document.getElementById(`channelDiscordSettings`)?.style.setProperty(`display`,e===`discord`?``:`none`),await a(`/api/settings`,`PUT`,{channel:e})}function y(e){let t=e.channel||`telegram`;document.getElementById(`chTelegram`)?.classList.toggle(`active`,t===`telegram`),document.getElementById(`chDiscord`)?.classList.toggle(`active`,t===`discord`),document.getElementById(`channelTelegramSettings`)?.style.setProperty(`display`,t===`telegram`?``:`none`),document.getElementById(`channelDiscordSettings`)?.style.setProperty(`display`,t===`discord`?``:`none`)}function b(e){let r=document.getElementById(`fallbackOrderList`);if(!r)return;let i=Object.keys(e.perCli||{}),a=e.fallbackOrder||[],o=Math.min(i.length-1,3),s=``;for(let e=0;e<o;e++){let r=a[e]||``,o=i.map(e=>`<option value="${n(e)}" ${e===r?`selected`:``}>${n(e)}</option>`).join(``);s+=`
2
2
  <div class="settings-row sub-row">
3
3
  <label style="min-width:60px">Fallback ${e+1}</label>
4
4
  <select id="fallback${e}"
@@ -0,0 +1 @@
1
+ import{g as e,p as t,v as n}from"./settings-B5D4wxWj.js";export{t as loadSettings,e as savePerCli,n as updateSettings};
@@ -1,4 +1,4 @@
1
- import{t as e}from"./state-O6NVkWcL.js";import{m as t,n,o as r,s as i,u as a}from"./render-C5gpc065.js";import{r as o}from"./api-Ci-lgwRp.js";var s=[`productivity`,`communication`,`devtools`,`ai-media`,`utility`,`smarthome`,`automation`];async function c(){try{e.allSkills=await(await a(`/api/skills`)).json(),l()}catch{let e=document.getElementById(`skillsList`);e&&(e.innerHTML=`<div style="color:var(--text-dim);font-size:11px">${t(`skill.loadFail`)}</div>`)}}function l(){let a=document.getElementById(`skillsList`),o=document.getElementById(`skillsCount`);if(!a||!o)return;let c=e.allSkills,l=c;e.currentSkillFilter===`installed`?l=c.filter(e=>e.enabled):e.currentSkillFilter===`other`?l=c.filter(e=>!s.includes(e.category||``)):e.currentSkillFilter!==`all`&&(l=c.filter(t=>t.category===e.currentSkillFilter));let u=c.filter(e=>e.enabled).length;o.textContent=t(`skill.count`,{active:u,total:c.length}),a.innerHTML=l.map(e=>{let t=[];return e.requires?.env&&t.push(`${r.key} `+e.requires.env.map(e=>n(e)).join(`, `)),e.requires?.bins&&t.push(`${r.settings} `+e.requires.bins.map(e=>n(e)).join(`, `)),e.install&&t.push(n(e.install)),`
1
+ import{t as e}from"./state-O6NVkWcL.js";import{m as t,n,o as r,s as i,u as a}from"./render-DIojC86t.js";import{r as o}from"./api-Ci-lgwRp.js";var s=[`productivity`,`communication`,`devtools`,`ai-media`,`utility`,`smarthome`,`automation`];async function c(){try{e.allSkills=await(await a(`/api/skills`)).json(),l()}catch{let e=document.getElementById(`skillsList`);e&&(e.innerHTML=`<div style="color:var(--text-dim);font-size:11px">${t(`skill.loadFail`)}</div>`)}}function l(){let a=document.getElementById(`skillsList`),o=document.getElementById(`skillsCount`);if(!a||!o)return;let c=e.allSkills,l=c;e.currentSkillFilter===`installed`?l=c.filter(e=>e.enabled):e.currentSkillFilter===`other`?l=c.filter(e=>!s.includes(e.category||``)):e.currentSkillFilter!==`all`&&(l=c.filter(t=>t.category===e.currentSkillFilter));let u=c.filter(e=>e.enabled).length;o.textContent=t(`skill.count`,{active:u,total:c.length}),a.innerHTML=l.map(e=>{let t=[];return e.requires?.env&&t.push(`${r.key} `+e.requires.env.map(e=>n(e)).join(`, `)),e.requires?.bins&&t.push(`${r.settings} `+e.requires.bins.map(e=>n(e)).join(`, `)),e.install&&t.push(n(e.install)),`
2
2
  <div class="skill-card ${e.enabled?`enabled`:``}">
3
3
  <div class="skill-card-header">
4
4
  <span class="skill-emoji">${e.emoji?i(e.emoji):r.tool}</span>
@@ -0,0 +1 @@
1
+ import{n as e}from"./skills-74SoDe9K.js";export{e as loadSkills};
@@ -0,0 +1 @@
1
+ import{a as e}from"./slash-commands-cmcn-EJn.js";export{e as loadCommands};
@@ -1,4 +1,4 @@
1
- import{m as e,n as t}from"./render-C5gpc065.js";import{t as n}from"./api-Ci-lgwRp.js";import{t as r}from"./locale-DIXc-_34.js";var i=[],a=[],o=-1,s=!1,c=null;function l(e){let t=String(e||``).slice(1).trim().split(/\s+/)[0]||``;return t.includes(`/`)||t.includes(`\\`)}var u=()=>document.getElementById(`cmdDropdown`),d=()=>document.getElementById(`chatInput`);function f(e){let t=String(e||``).toLowerCase();return i.filter(e=>`/${e.name}`.startsWith(t))}function p(){let e=u(),t=d();!e||!t||(c&&=(clearTimeout(c),null),e.style.display=`block`,requestAnimationFrame(()=>e.classList.add(`visible`)),s=!0,t.setAttribute(`aria-expanded`,`true`))}function m(){let n=u(),r=d();if(!n||!r)return;if(!a.length){if(!r.value.startsWith(`/`)||l(r.value)){_();return}n.innerHTML=`
1
+ import{m as e,n as t}from"./render-DIojC86t.js";import{t as n}from"./api-Ci-lgwRp.js";import{t as r}from"./locale-DIXc-_34.js";var i=[],a=[],o=-1,s=!1,c=null;function l(e){let t=String(e||``).slice(1).trim().split(/\s+/)[0]||``;return t.includes(`/`)||t.includes(`\\`)}var u=()=>document.getElementById(`cmdDropdown`),d=()=>document.getElementById(`chatInput`);function f(e){let t=String(e||``).toLowerCase();return i.filter(e=>`/${e.name}`.startsWith(t))}function p(){let e=u(),t=d();!e||!t||(c&&=(clearTimeout(c),null),e.style.display=`block`,requestAnimationFrame(()=>e.classList.add(`visible`)),s=!0,t.setAttribute(`aria-expanded`,`true`))}function m(){let n=u(),r=d();if(!n||!r)return;if(!a.length){if(!r.value.startsWith(`/`)||l(r.value)){_();return}n.innerHTML=`
2
2
  <div class="cmd-item cmd-empty" role="option" aria-disabled="true">
3
3
  ${e(`cmd.noMatch`)}
4
4
  </div>
@@ -0,0 +1 @@
1
+ import{c as e,d as t,i as n,m as r}from"./ui-Drug8_7N.js";export{n as cleanupToolActivity,e as loadMessages,t as setStatus,r as updateQueueBadge};
@@ -1,5 +1,5 @@
1
1
  const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/vendor-render-Bjnw0wQ6.css"])))=>i.map(i=>d[i]);
2
- import{t as e}from"./state-O6NVkWcL.js";import{Z as t}from"./vendor-mermaid-lvHqQdfg.js";import{a as n,c as r,m as i,n as a,o,r as s,s as c}from"./render-C5gpc065.js";import{t as l}from"./api-Ci-lgwRp.js";var u=`agentName`,d=`CLI-JAW`,f=d;function ee(){return f}function p(e){f=(e||``).trim()||d,localStorage.setItem(u,f);let t=document.getElementById(`appNameInput`);t&&(t.value=f)}function te(){f=localStorage.getItem(u)||d;let e=document.getElementById(`appNameInput`);e&&(e.value=f),document.getElementById(`appNameSave`)?.addEventListener(`click`,()=>{let e=document.getElementById(`appNameInput`);e&&p(e.value)}),document.getElementById(`appNameInput`)?.addEventListener(`keydown`,e=>{let t=e;t.key===`Enter`&&(t.preventDefault(),p(t.target.value),t.target.blur())})}var ne=`clijaw`,re=1,m=`messages`,h=null;function g(){return h||(h=new Promise((e,t)=>{let n=indexedDB.open(ne,re);n.onupgradeneeded=()=>{let e=n.result;e.objectStoreNames.contains(m)||e.createObjectStore(m,{keyPath:`id`,autoIncrement:!0}).createIndex(`timestamp`,`timestamp`)},n.onsuccess=()=>e(n.result),n.onerror=()=>{h=null,t(n.error)}}),h)}async function ie(e){try{let t=(await g()).transaction(m,`readwrite`),n=t.objectStore(m);n.clear();for(let t of e)n.add({role:t.role,content:t.content,timestamp:t.timestamp||Date.now()});await new Promise((e,n)=>{t.oncomplete=()=>e(),t.onerror=()=>n(t.error)})}catch(e){console.warn(`[idb-cache] cacheMessages failed:`,e)}}async function ae(){try{let e=await g();return new Promise((t,n)=>{let r=e.transaction(m,`readonly`).objectStore(m).getAll();r.onsuccess=()=>t(r.result),r.onerror=()=>n(r.error)})}catch(e){return console.warn(`[idb-cache] getCachedMessages failed:`,e),[]}}async function oe(e,t){try{(await g()).transaction(m,`readwrite`).objectStore(m).add({role:e,content:t,timestamp:Date.now()})}catch(e){console.warn(`[idb-cache] appendCachedMessage failed:`,e)}}async function se(){try{(await g()).transaction(m,`readwrite`).objectStore(m).clear()}catch(e){console.warn(`[idb-cache] clearCache failed:`,e)}}var _=5,v=80,ce=class{items=[];container;spacerTop;spacerBottom;viewport;_active=!1;_totalHeight=0;rafId=null;firstVisible=0;lastVisible=0;onLazyRender=null;constructor(e){this.container=document.getElementById(e),this.spacerTop=document.createElement(`div`),this.spacerTop.className=`vs-spacer-top`,this.spacerBottom=document.createElement(`div`),this.spacerBottom.className=`vs-spacer-bottom`,this.viewport=document.createElement(`div`),this.viewport.className=`vs-viewport`}get active(){return this._active}get count(){return this.items.length}flushToDOM(){this._active&&(this.container.removeEventListener(`scroll`,this.scrollHandler),this.rafId&&=(cancelAnimationFrame(this.rafId),null),this.container.innerHTML=this.items.map(e=>e.html).join(``),this._active=!1,this.firstVisible=0,this.lastVisible=0,this.items=[],this._totalHeight=0)}addItem(e,t){let n={id:e,html:t,height:v};this.items.push(n),this._totalHeight+=v,!this._active&&this.items.length>=80&&this.activate(),this._active&&this.scheduleRender()}appendLiveItem(e){if(!this._active)return;let t=e.outerHTML,n={id:crypto.randomUUID(),html:t,height:v};this.items.push(n),this._totalHeight+=v,this.scheduleRender(),this.scrollToBottom()}updateItemHtml(e,t){this.items[e]&&(this.items[e].html=t)}scrollHandler=()=>this.scheduleRender();activate(){this._active=!0,this._totalHeight=0,this.container.querySelectorAll(`.msg`).forEach((e,t)=>{this.items[t]&&(this.items[t].height=e.getBoundingClientRect().height,this._totalHeight+=this.items[t].height)}),this.container.innerHTML=``,this.container.append(this.spacerTop,this.viewport,this.spacerBottom),this.container.addEventListener(`scroll`,this.scrollHandler,{passive:!0}),this.render()}scheduleRender(){this.rafId||=requestAnimationFrame(()=>{this.rafId=null,this.render()})}render(){let e=this.container.scrollTop,t=this.container.clientHeight,n=0,r=0;for(let t=0;t<this.items.length;t++){if(n+this.items[t].height>e){r=t;break}n+=this.items[t].height}let i=Math.max(0,r-_),a=n,o=r;for(let n=r;n<this.items.length&&(a+=this.items[n].height,o=n,!(a>e+t));n++);let s=Math.min(this.items.length-1,o+_);if(i===this.firstVisible&&s===this.lastVisible)return;this.firstVisible=i,this.lastVisible=s;let c=0;for(let e=0;e<i;e++)c+=this.items[e].height;let l=0;for(let e=s+1;e<this.items.length;e++)l+=this.items[e].height;this.spacerTop.style.height=`${c}px`,this.spacerBottom.style.height=`${l}px`;let u=document.createDocumentFragment();for(let e=i;e<=s;e++){let t=this.items[e],n=document.createElement(`div`);n.innerHTML=t.html;let r=n.firstElementChild;r&&(r.dataset.vsIdx=String(e),u.appendChild(r))}if(this.viewport.innerHTML=``,this.viewport.appendChild(u),this.viewport.querySelectorAll(`[data-vs-idx]`).forEach(e=>{let t=Number(e.dataset.vsIdx);if(this.items[t]){let n=this.items[t].height,r=e.getBoundingClientRect().height;this.items[t].height=r,this._totalHeight+=r-n}}),this.onLazyRender){let e=this.viewport.querySelectorAll(`.lazy-pending`);e.length>0&&this.onLazyRender(Array.from(e))}}scrollToBottom(){this.container.scrollTop=this._totalHeight,this.scheduleRender()}clear(){this.items=[],this._totalHeight=0,this._active&&(this.container.removeEventListener(`scroll`,this.scrollHandler),this.viewport.innerHTML=``,this.spacerTop.style.height=`0`,this.spacerBottom.style.height=`0`,this.container.innerHTML=``),this._active=!1,this.firstVisible=0,this.lastVisible=0,this.onLazyRender=null,this.rafId&&=(cancelAnimationFrame(this.rafId),null)}},y=null;function b(){return y||=new ce(`chatMessages`),y}var le=2e3,ue=80;function de(e){return{chunks:[],fullText:``,textDirty:!1,element:e,pendingRAF:null,isFinalized:!1,lastRenderTime:0}}function x(e){return e.textDirty&&=(e.fullText=e.chunks.join(``),!1),e.fullText}function fe(e,t){e.chunks.push(t),e.textDirty=!0,!e.pendingRAF&&!e.isFinalized&&(e.pendingRAF=requestAnimationFrame(()=>{if(e.pendingRAF=null,e.isFinalized)return;let t=performance.now(),n=x(e);n.length<le||t-e.lastRenderTime>ue?(e.element.innerHTML=s(n,!0)+`<span class="stream-cursor" aria-hidden="true"></span>`,e.lastRenderTime=t):e.pendingRAF=requestAnimationFrame(()=>{e.pendingRAF=null,!e.isFinalized&&(e.element.innerHTML=s(x(e),!0)+`<span class="stream-cursor" aria-hidden="true"></span>`,e.lastRenderTime=performance.now())})}))}function pe(e,t=!1){e.isFinalized=!0,e.pendingRAF&&=(cancelAnimationFrame(e.pendingRAF),null);let n=x(e);return t||(e.element.innerHTML=s(n)),n}var me=[`cdnjs.cloudflare.com`,`cdn.jsdelivr.net`,`unpkg.com`,`esm.sh`,`fonts.googleapis.com`,`fonts.gstatic.com`],he=[/\beval\s*\(/,/\bnew\s+Function\s*\(/,/\bdocument\.cookie\b/,/\bwindow\.opener\b/,/\bwindow\.top\b/,/\bparent\.postMessage\b(?!.*jaw-)/,/\blocation\.href\s*=/,/\bwindow\.location\b/,/\bsetTimeout\s*\(\s*["'`]/,/\bsetInterval\s*\(\s*["'`]/,/\.constructor\s*\.\s*constructor/,/\bdocument\.write\s*\(/,/\binsertAdjacentHTML\s*\(/,/\bimport\s*\(/],ge=[];function _e(e){let t=[];if(e.length>524288)return{valid:!1,reason:`Payload too large (>512KB)`,warnings:t};let n=/(?:src|href)\s*=\s*["']https?:\/\/([^/"']+)/gi,r;for(;(r=n.exec(e))!==null;){let e=r[1];if(!me.some(t=>e===t||e.endsWith(`.`+t)))return{valid:!1,reason:`Blocked domain: ${e}`,warnings:t}}let i=/url\s*\(\s*['"]?https?:\/\/([^)'"]+)/gi;for(;(r=i.exec(e))!==null;){let e=r[1].split(`/`)[0];me.some(t=>e===t||e.endsWith(`.`+t))||t.push(`CSS url() references external domain: ${e}`)}for(let n of he)if(n.test(e))return{valid:!1,reason:`Dangerous pattern: ${n.source}`,warnings:t};for(let n of ge)n.test(e)&&t.push(`DOM sink detected: ${n.source}`);return{valid:!0,warnings:t}}function S(){let e=document.createElement(`button`);return e.className=`diagram-copy-btn`,e.type=`button`,e.ariaLabel=`Copy source`,e.title=`Copy`,e.innerHTML=o.copy,e}function C(){let e=document.createElement(`button`);return e.className=`diagram-save-btn`,e.type=`button`,e.ariaLabel=`Save as image`,e.title=`Save`,e.innerHTML=o.download,e}var ve=[`cdnjs.cloudflare.com`,`cdn.jsdelivr.net`,`unpkg.com`,`esm.sh`,`fonts.googleapis.com`,`fonts.gstatic.com`],w=new Set,T=new Map,E=null;function ye(){if(E)return;let e=document.getElementById(`chatMessages`);e&&(E=new MutationObserver(e=>{if(w.size)for(let t of e)for(let e of t.removedNodes)e instanceof HTMLIFrameElement&&e.contentWindow&&(w.delete(e.contentWindow),T.delete(e.contentWindow)),e instanceof HTMLElement&&e.querySelectorAll(`iframe`).forEach(e=>{e.contentWindow&&(w.delete(e.contentWindow),T.delete(e.contentWindow))})}),E.observe(e,{childList:!0,subtree:!0}))}function be(e){if(e.includes(`"importmap"`)||e.includes(`'importmap'`))return``;let t={},n=e.match(/(?:cdn\.jsdelivr\.net\/npm|unpkg\.com)\/three@([\d.]+)/);if(n){let r=n[1],i=e.includes(`unpkg.com/three@`)?`unpkg.com`:`cdn.jsdelivr.net/npm`;t.three=`https://${i}/three@${r}/${i===`unpkg.com`?`build/three.module.js`:`build/three.module.min.js`}`,t[`three/addons/`]=`https://${i}/three@${r}/examples/jsm/`}return Object.keys(t).length===0?``:`<script type="importmap">${JSON.stringify({imports:t})}<\/script>`}function xe(e){let t=`'none'`;(e.includes(`cdn.jsdelivr.net/npm/us-atlas`)||e.includes(`cdn.jsdelivr.net/npm/world-atlas`)||e.includes(`cdn.jsdelivr.net/npm/datamaps`))&&(t=`https://cdn.jsdelivr.net`);let n=/Tone\.min\.js|tone@/.test(e)?`worker-src blob:;`:``,r=ve.map(e=>`https://${e}`),i=r.join(` `),a=[`data:`,`blob:`,...r],o=[`'unsafe-inline'`,`https://fonts.googleapis.com`];/L\.(map|tileLayer|marker|geoJSON|polyline|polygon|circle)\(|leaflet[\w.@/-]*\.(js|css)|tile\.openstreetmap\.org/.test(e)&&(a.push(`https://a.tile.openstreetmap.org`,`https://b.tile.openstreetmap.org`,`https://c.tile.openstreetmap.org`),o.push(`https://cdnjs.cloudflare.com`,`https://cdn.jsdelivr.net`));let s=a.join(` `);return`<meta http-equiv="Content-Security-Policy" content="default-src 'none'; script-src 'unsafe-inline' ${i}; style-src ${o.join(` `)}; img-src ${s}; font-src https://fonts.gstatic.com; connect-src ${t}; ${n} base-uri 'none';">`}function Se(){let e=!document.documentElement.hasAttribute(`data-theme`)||document.documentElement.getAttribute(`data-theme`)===`dark`,t=getComputedStyle(document.documentElement);return{isDark:e,tokens:{"--bg":t.getPropertyValue(`--bg`).trim(),"--surface":t.getPropertyValue(`--surface`).trim(),"--border":t.getPropertyValue(`--border`).trim(),"--text":t.getPropertyValue(`--text`).trim(),"--text-dim":t.getPropertyValue(`--text-dim`).trim(),"--accent":t.getPropertyValue(`--accent`).trim(),"--font-ui":t.getPropertyValue(`--font-ui`).trim(),"--font-mono":t.getPropertyValue(`--font-mono`).trim(),"--radius-sm":t.getPropertyValue(`--radius-sm`).trim(),"--radius-md":t.getPropertyValue(`--radius-md`).trim()}}}function Ce(e){return`
2
+ import{t as e}from"./state-O6NVkWcL.js";import{Z as t}from"./vendor-mermaid-lvHqQdfg.js";import{a as n,c as r,m as i,n as a,o,r as s,s as c}from"./render-DIojC86t.js";import{t as l}from"./api-Ci-lgwRp.js";var u=`agentName`,d=`CLI-JAW`,f=d;function ee(){return f}function p(e){f=(e||``).trim()||d,localStorage.setItem(u,f);let t=document.getElementById(`appNameInput`);t&&(t.value=f)}function te(){f=localStorage.getItem(u)||d;let e=document.getElementById(`appNameInput`);e&&(e.value=f),document.getElementById(`appNameSave`)?.addEventListener(`click`,()=>{let e=document.getElementById(`appNameInput`);e&&p(e.value)}),document.getElementById(`appNameInput`)?.addEventListener(`keydown`,e=>{let t=e;t.key===`Enter`&&(t.preventDefault(),p(t.target.value),t.target.blur())})}var ne=`clijaw`,re=1,m=`messages`,h=null;function g(){return h||(h=new Promise((e,t)=>{let n=indexedDB.open(ne,re);n.onupgradeneeded=()=>{let e=n.result;e.objectStoreNames.contains(m)||e.createObjectStore(m,{keyPath:`id`,autoIncrement:!0}).createIndex(`timestamp`,`timestamp`)},n.onsuccess=()=>e(n.result),n.onerror=()=>{h=null,t(n.error)}}),h)}async function ie(e){try{let t=(await g()).transaction(m,`readwrite`),n=t.objectStore(m);n.clear();for(let t of e)n.add({role:t.role,content:t.content,timestamp:t.timestamp||Date.now()});await new Promise((e,n)=>{t.oncomplete=()=>e(),t.onerror=()=>n(t.error)})}catch(e){console.warn(`[idb-cache] cacheMessages failed:`,e)}}async function ae(){try{let e=await g();return new Promise((t,n)=>{let r=e.transaction(m,`readonly`).objectStore(m).getAll();r.onsuccess=()=>t(r.result),r.onerror=()=>n(r.error)})}catch(e){return console.warn(`[idb-cache] getCachedMessages failed:`,e),[]}}async function oe(e,t){try{(await g()).transaction(m,`readwrite`).objectStore(m).add({role:e,content:t,timestamp:Date.now()})}catch(e){console.warn(`[idb-cache] appendCachedMessage failed:`,e)}}async function se(){try{(await g()).transaction(m,`readwrite`).objectStore(m).clear()}catch(e){console.warn(`[idb-cache] clearCache failed:`,e)}}var _=5,v=80,ce=class{items=[];container;spacerTop;spacerBottom;viewport;_active=!1;_totalHeight=0;rafId=null;firstVisible=0;lastVisible=0;onLazyRender=null;onPostRender=null;constructor(e){this.container=document.getElementById(e),this.spacerTop=document.createElement(`div`),this.spacerTop.className=`vs-spacer-top`,this.spacerBottom=document.createElement(`div`),this.spacerBottom.className=`vs-spacer-bottom`,this.viewport=document.createElement(`div`),this.viewport.className=`vs-viewport`}get active(){return this._active}get count(){return this.items.length}flushToDOM(){this._active&&(this.container.removeEventListener(`scroll`,this.scrollHandler),this.rafId&&=(cancelAnimationFrame(this.rafId),null),this.container.innerHTML=this.items.map(e=>e.html).join(``),this._active=!1,this.firstVisible=0,this.lastVisible=0,this.items=[],this._totalHeight=0)}addItem(e,t){let n={id:e,html:t,height:v};this.items.push(n),this._totalHeight+=v,!this._active&&this.items.length>=80&&this.activate(),this._active&&this.scheduleRender()}appendLiveItem(e){if(!this._active)return;let t=e.outerHTML,n={id:crypto.randomUUID(),html:t,height:v};this.items.push(n),this._totalHeight+=v,this.render(),this.container.scrollTop=this._totalHeight}updateItemHtml(e,t){this.items[e]&&(this.items[e].html=t)}scrollHandler=()=>this.scheduleRender();activate(){this._active=!0,this._totalHeight=0,this.container.querySelectorAll(`.msg`).forEach((e,t)=>{this.items[t]&&(this.items[t].height=e.getBoundingClientRect().height,this._totalHeight+=this.items[t].height)}),this.container.innerHTML=``,this.container.append(this.spacerTop,this.viewport,this.spacerBottom),this.container.addEventListener(`scroll`,this.scrollHandler,{passive:!0}),this.render()}scheduleRender(){this.rafId||=requestAnimationFrame(()=>{this.rafId=null,this.render()})}render(){let e=this.container.scrollTop,t=this.container.clientHeight,n=0,r=0;for(let t=0;t<this.items.length;t++){if(n+this.items[t].height>e){r=t;break}n+=this.items[t].height}let i=Math.max(0,r-_),a=n,o=r;for(let n=r;n<this.items.length&&(a+=this.items[n].height,o=n,!(a>e+t));n++);let s=Math.min(this.items.length-1,o+_);if(i===this.firstVisible&&s===this.lastVisible)return;this.firstVisible=i,this.lastVisible=s;let c=0;for(let e=0;e<i;e++)c+=this.items[e].height;let l=0;for(let e=s+1;e<this.items.length;e++)l+=this.items[e].height;this.spacerTop.style.height=`${c}px`,this.spacerBottom.style.height=`${l}px`;let u=document.createDocumentFragment();for(let e=i;e<=s;e++){let t=this.items[e],n=document.createElement(`div`);n.innerHTML=t.html;let r=n.firstElementChild;r&&(r.dataset.vsIdx=String(e),u.appendChild(r))}if(this.viewport.innerHTML=``,this.viewport.appendChild(u),this.viewport.querySelectorAll(`[data-vs-idx]`).forEach(e=>{let t=Number(e.dataset.vsIdx);if(this.items[t]){let n=this.items[t].height,r=e.getBoundingClientRect().height;this.items[t].height=r,this._totalHeight+=r-n}}),this.onLazyRender){let e=this.viewport.querySelectorAll(`.lazy-pending`);e.length>0&&this.onLazyRender(Array.from(e))}this.onPostRender&&this.onPostRender(this.viewport)}scrollToBottom(){this.container.scrollTop=this._totalHeight,this.scheduleRender()}clear(){this.items=[],this._totalHeight=0,this._active&&(this.container.removeEventListener(`scroll`,this.scrollHandler),this.viewport.innerHTML=``,this.spacerTop.style.height=`0`,this.spacerBottom.style.height=`0`,this.container.innerHTML=``),this._active=!1,this.firstVisible=0,this.lastVisible=0,this.onLazyRender=null,this.onPostRender=null,this.rafId&&=(cancelAnimationFrame(this.rafId),null)}},y=null;function b(){return y||=new ce(`chatMessages`),y}var le=2e3,ue=80;function de(e){return{chunks:[],fullText:``,textDirty:!1,element:e,pendingRAF:null,isFinalized:!1,lastRenderTime:0}}function x(e){return e.textDirty&&=(e.fullText=e.chunks.join(``),!1),e.fullText}function fe(e,t){e.chunks.push(t),e.textDirty=!0,!e.pendingRAF&&!e.isFinalized&&(e.pendingRAF=requestAnimationFrame(()=>{if(e.pendingRAF=null,e.isFinalized)return;let t=performance.now(),n=x(e);n.length<le||t-e.lastRenderTime>ue?(e.element.innerHTML=s(n,!0)+`<span class="stream-cursor" aria-hidden="true"></span>`,e.lastRenderTime=t):e.pendingRAF=requestAnimationFrame(()=>{e.pendingRAF=null,!e.isFinalized&&(e.element.innerHTML=s(x(e),!0)+`<span class="stream-cursor" aria-hidden="true"></span>`,e.lastRenderTime=performance.now())})}))}function pe(e,t=!1){e.isFinalized=!0,e.pendingRAF&&=(cancelAnimationFrame(e.pendingRAF),null);let n=x(e);return t||(e.element.innerHTML=s(n)),n}var me=[`cdnjs.cloudflare.com`,`cdn.jsdelivr.net`,`unpkg.com`,`esm.sh`,`fonts.googleapis.com`,`fonts.gstatic.com`],he=[/\beval\s*\(/,/\bnew\s+Function\s*\(/,/\bdocument\.cookie\b/,/\bwindow\.opener\b/,/\bwindow\.top\b/,/\bparent\.postMessage\b(?!.*jaw-)/,/\blocation\.href\s*=/,/\bwindow\.location\b/,/\bsetTimeout\s*\(\s*["'`]/,/\bsetInterval\s*\(\s*["'`]/,/\.constructor\s*\.\s*constructor/,/\bdocument\.write\s*\(/,/\binsertAdjacentHTML\s*\(/,/\bimport\s*\(/],ge=[];function _e(e){let t=[];if(e.length>524288)return{valid:!1,reason:`Payload too large (>512KB)`,warnings:t};let n=/(?:src|href)\s*=\s*["']https?:\/\/([^/"']+)/gi,r;for(;(r=n.exec(e))!==null;){let e=r[1];if(!me.some(t=>e===t||e.endsWith(`.`+t)))return{valid:!1,reason:`Blocked domain: ${e}`,warnings:t}}let i=/url\s*\(\s*['"]?https?:\/\/([^)'"]+)/gi;for(;(r=i.exec(e))!==null;){let e=r[1].split(`/`)[0];me.some(t=>e===t||e.endsWith(`.`+t))||t.push(`CSS url() references external domain: ${e}`)}for(let n of he)if(n.test(e))return{valid:!1,reason:`Dangerous pattern: ${n.source}`,warnings:t};for(let n of ge)n.test(e)&&t.push(`DOM sink detected: ${n.source}`);return{valid:!0,warnings:t}}function S(){let e=document.createElement(`button`);return e.className=`diagram-copy-btn`,e.type=`button`,e.ariaLabel=`Copy source`,e.title=`Copy`,e.innerHTML=o.copy,e}function C(){let e=document.createElement(`button`);return e.className=`diagram-save-btn`,e.type=`button`,e.ariaLabel=`Save as image`,e.title=`Save`,e.innerHTML=o.download,e}var ve=[`cdnjs.cloudflare.com`,`cdn.jsdelivr.net`,`unpkg.com`,`esm.sh`,`fonts.googleapis.com`,`fonts.gstatic.com`],w=new Set,T=new Map,E=null;function ye(){if(E)return;let e=document.getElementById(`chatMessages`);e&&(E=new MutationObserver(e=>{if(w.size)for(let t of e)for(let e of t.removedNodes)e instanceof HTMLIFrameElement&&e.contentWindow&&(w.delete(e.contentWindow),T.delete(e.contentWindow)),e instanceof HTMLElement&&e.querySelectorAll(`iframe`).forEach(e=>{e.contentWindow&&(w.delete(e.contentWindow),T.delete(e.contentWindow))})}),E.observe(e,{childList:!0,subtree:!0}))}function be(e){if(e.includes(`"importmap"`)||e.includes(`'importmap'`))return``;let t={},n=e.match(/(?:cdn\.jsdelivr\.net\/npm|unpkg\.com)\/three@([\d.]+)/);if(n){let r=n[1],i=e.includes(`unpkg.com/three@`)?`unpkg.com`:`cdn.jsdelivr.net/npm`;t.three=`https://${i}/three@${r}/${i===`unpkg.com`?`build/three.module.js`:`build/three.module.min.js`}`,t[`three/addons/`]=`https://${i}/three@${r}/examples/jsm/`}return Object.keys(t).length===0?``:`<script type="importmap">${JSON.stringify({imports:t})}<\/script>`}function xe(e){let t=`'none'`;(e.includes(`cdn.jsdelivr.net/npm/us-atlas`)||e.includes(`cdn.jsdelivr.net/npm/world-atlas`)||e.includes(`cdn.jsdelivr.net/npm/datamaps`))&&(t=`https://cdn.jsdelivr.net`);let n=/Tone\.min\.js|tone@/.test(e)?`worker-src blob:;`:``,r=ve.map(e=>`https://${e}`),i=r.join(` `),a=[`data:`,`blob:`,...r],o=[`'unsafe-inline'`,`https://fonts.googleapis.com`];/L\.(map|tileLayer|marker|geoJSON|polyline|polygon|circle)\(|leaflet[\w.@/-]*\.(js|css)|tile\.openstreetmap\.org/.test(e)&&(a.push(`https://a.tile.openstreetmap.org`,`https://b.tile.openstreetmap.org`,`https://c.tile.openstreetmap.org`),o.push(`https://cdnjs.cloudflare.com`,`https://cdn.jsdelivr.net`));let s=a.join(` `);return`<meta http-equiv="Content-Security-Policy" content="default-src 'none'; script-src 'unsafe-inline' ${i}; style-src ${o.join(` `)}; img-src ${s}; font-src https://fonts.gstatic.com; connect-src ${t}; ${n} base-uri 'none';">`}function Se(){let e=!document.documentElement.hasAttribute(`data-theme`)||document.documentElement.getAttribute(`data-theme`)===`dark`,t=getComputedStyle(document.documentElement);return{isDark:e,tokens:{"--bg":t.getPropertyValue(`--bg`).trim(),"--surface":t.getPropertyValue(`--surface`).trim(),"--border":t.getPropertyValue(`--border`).trim(),"--text":t.getPropertyValue(`--text`).trim(),"--text-dim":t.getPropertyValue(`--text-dim`).trim(),"--accent":t.getPropertyValue(`--accent`).trim(),"--font-ui":t.getPropertyValue(`--font-ui`).trim(),"--font-mono":t.getPropertyValue(`--font-mono`).trim(),"--radius-sm":t.getPropertyValue(`--radius-sm`).trim(),"--radius-md":t.getPropertyValue(`--radius-md`).trim()}}}function Ce(e){return`
3
3
  <script>
4
4
  (function() {
5
5
  var __nonce = '${e}';
@@ -128,4 +128,4 @@ import{t as e}from"./state-O6NVkWcL.js";import{Z as t}from"./vendor-mermaid-lvHq
128
128
  <div class="process-details">
129
129
  <div class="process-steps-inner"></div>
130
130
  </div>
131
- </div>`}function je(e){let t=e.closest(`.process-step`),n=t?.querySelector(`.process-step-details`),r=e.querySelector(`.process-step-chevron`);if(!t||!n)return;let i=n.classList.contains(`collapsed`);n.classList.toggle(`collapsed`,!i),t.classList.toggle(`expanded`,i),e.setAttribute(`aria-expanded`,i?`true`:`false`),r&&(r.innerHTML=i?o.chevronDown:o.chevronRight)}function Me(e){e.dataset.processBlockBound!==`1`&&(e.addEventListener(`click`,e=>{let t=e.target;if(!t)return;let n=t.closest(`.process-step-toggle`);if(n){je(n);return}let r=t.closest(`.process-summary`);if(r){let e=r.closest(`.process-block`);if(!e)return;let t=e.classList.contains(`collapsed`);e.classList.toggle(`collapsed`,!t),r.setAttribute(`aria-expanded`,t?`true`:`false`);let n=r.querySelector(`.process-chevron`);n&&(n.innerHTML=t?o.chevronDown:o.chevronRight)}}),e.dataset.processBlockBound=`1`)}function L(e,t=!0){let n=I(N(e),t),r=document.createElement(`div`);r.innerHTML=n;let i=r.querySelector(`.process-steps-inner`);i&&(i.innerHTML=e.map(F).join(``));let a=r.querySelector(`.process-dot`);if(a){let n=e.some(e=>e.status===`running`);a.classList.toggle(`running`,n&&!t),a.classList.toggle(`done`,!n||t)}return r.innerHTML}function R(e){let t=e.element.querySelector(`.process-summary-text`);t&&(t.innerHTML=N(e.steps));let n=e.steps.some(e=>e.status===`running`),r=e.element.querySelector(`.process-dot`);r&&(r.classList.toggle(`running`,n&&!e.collapsed),r.classList.toggle(`done`,!n||e.collapsed));let i=e.steps.length>0?Math.round((Date.now()-e.steps[0].startTime)/1e3):0,a=e.element.querySelector(`.process-duration`);a&&(a.textContent=i>0?`${i}s`:``)}function z(e){let t=document.createElement(`div`);t.innerHTML=I(``,!1);let n=t.firstElementChild,r=e.querySelector(`.msg-content`);return r?r.before(n):e.appendChild(n),{element:n,steps:[],collapsed:!1}}function B(e,t){e.steps.push(t);let n=e.element.querySelector(`.process-steps-inner`);n&&n.insertAdjacentHTML(`beforeend`,F(t)),R(e)}function Ne(e,t,n){let r=e.steps.findIndex(e=>e.id===t);if(r===-1)return;e.steps[r]=n;let i=e.element.querySelector(`[data-step-id="${t}"]`);if(i){let e=document.createElement(`div`);e.innerHTML=F(n);let t=e.firstElementChild;t&&i.replaceWith(t)}R(e)}function V(e,t,n){let r=e.steps.find(e=>e.id===t);if(!r)return;r.status=n;let i=e.element.querySelector(`[data-step-id="${t}"]`);if(i){let e=i.querySelector(`.process-step-dot`);e&&(e.classList.remove(`running`,`done`,`error`),e.classList.add(n))}R(e)}function H(e){e.collapsed=!0,e.element.classList.add(`collapsed`);let t=e.element.querySelector(`.process-summary`);t&&t.setAttribute(`aria-expanded`,`false`);let n=e.element.querySelector(`.process-chevron`);n&&(n.innerHTML=o.chevronRight);for(let t of e.steps)t.status===`running`&&(t.status=`done`);e.element.querySelectorAll(`.process-step-dot.running`).forEach(e=>{e.classList.remove(`running`),e.classList.add(`done`)}),R(e)}function U(e){if(!e)return[];try{let t=JSON.parse(e);return Array.isArray(t)?t:[]}catch{return[]}}function W(e){return o.shark}function G(e){return e.map(e=>({id:crypto.randomUUID(),icon:e.icon?c(e.icon):o.tool,label:e.label||e.name||`tool`,type:e.toolType||`tool`,detail:e.detail||``,stepRef:e.stepRef||``,status:e.status||`done`,startTime:Date.now()}))}function Pe(t){let n=document.getElementById(`statusBadge`),r=document.getElementById(`btnSend`);e.agentBusy=t===`running`,document.getElementById(`typingIndicator`)?.classList.toggle(`active`,e.agentBusy),t===`running`?(n&&(n.className=`status-badge status-running`,n.textContent=`running`),r&&(r.innerHTML=o.stop,r.title=i(`btn.stop`),r.classList.add(`stop-mode`)),Ie()):(n&&(n.className=`status-badge status-idle`,n.textContent=`idle`),r&&(r.innerHTML=o.send,r.title=`Send`,r.classList.remove(`stop-mode`)),K(),Fe(0))}function Fe(e){let t=document.getElementById(`queueBadge`);if(!t){t=document.createElement(`span`),t.id=`queueBadge`,t.className=`queue-badge`;let e=document.getElementById(`btnSend`);e?.parentElement&&(e.parentElement.style.position=`relative`),e&&(e.style.position=`relative`,e.appendChild(t))}t.textContent=e>0?String(e):``,t.style.display=e>0?`flex`:`none`}function Ie(){let e=document.getElementById(`chatMessages`);if(!e||e.querySelector(`.skeleton-msg`))return;q();let t=document.createElement(`div`);t.className=`skeleton-msg`,t.innerHTML=`<div class="skeleton-line"></div><div class="skeleton-line"></div><div class="skeleton-line"></div>`,e.appendChild(t),Q()}function K(){document.querySelectorAll(`.skeleton-msg`).forEach(e=>e.remove())}function q(){document.getElementById(`emptyState`)?.classList.remove(`visible`)}function J(){let e=document.getElementById(`chatMessages`);e&&e.children.length===0&&document.getElementById(`emptyState`)?.classList.add(`visible`)}function Le(e,t,n){let r=document.getElementById(`chatMessages`);if(!r)return;let i=b();i.active&&i.flushToDOM(),q();let a=document.createElement(`div`);a.className=`msg msg-system`+(n?` msg-type-${n}`:``)+(t?` `+t:``),a.innerHTML=e,r.appendChild(a),r.scrollTop=r.scrollHeight}function Re(){M(),e.currentAgentDiv=null,e.currentProcessBlock=null}function ze(t){if(K(),(!e.currentAgentDiv||!e.currentAgentDiv.isConnected)&&(e.currentAgentDiv=Z(`agent`,``),e.currentProcessBlock=null),!e.currentProcessBlock){let t=e.currentAgentDiv.querySelector(`.agent-body`);t&&(e.currentProcessBlock=z(t))}if(e.currentProcessBlock){let n=t.status&&t.status!==`running`?t.status:r(t.icon);if(n===`done`||n===`error`){let r=t.stepRef,i=r?[...e.currentProcessBlock.steps].reverse().find(e=>e.status===`running`&&e.stepRef===r):[...e.currentProcessBlock.steps].reverse().find(e=>e.status===`running`&&e.label===t.label);if(i){V(e.currentProcessBlock,i.id,n),Q();return}let a=[...e.currentProcessBlock.steps].reverse().find(e=>e.status===`running`);if(a){V(e.currentProcessBlock,a.id,n),Q();return}}if(t.detail){let n=[...e.currentProcessBlock.steps].reverse().find(e=>e.status===`running`&&e.label===t.label&&e.type===t.type&&!e.detail);if(n){Ne(e.currentProcessBlock,n.id,t),Q();return}}t.icon=c(t.icon),B(e.currentProcessBlock,t)}Q()}var Y=null;function Be(t){if(!t)return;K(),(!e.currentAgentDiv||!e.currentAgentDiv.isConnected)&&(e.currentAgentDiv=Z(`agent`,``),Y=null);let n=e.currentAgentDiv?.querySelector(`.msg-content`);n&&(Y||=de(n),fe(Y,t)),Q()}var X=0;function Ve(t,r){let i=Date.now();if(!e.currentAgentDiv&&i-X<500)return;M(),K();let a=!!e.currentProcessBlock;e.currentProcessBlock&&=(H(e.currentProcessBlock),null);let o=r&&r.length>0;if(t||o){(!e.currentAgentDiv||!e.currentAgentDiv.isConnected)&&(e.currentAgentDiv=Z(`agent`,``));let i=e.currentAgentDiv?.querySelector(`.msg-content`),c=Y?pe(Y,!0):``,l=t||c;Y=null;let u=o&&!a?L(G(r),!0):``;i&&(i.innerHTML=u+s(l)),i&&i.setAttribute(`data-raw`,n(l)),i&&O(i);let d=b();d.active&&e.currentAgentDiv&&e.currentAgentDiv.isConnected&&(d.appendLiveItem(e.currentAgentDiv),e.currentAgentDiv.remove())}Y=null,e.currentAgentDiv=null,X=Date.now(),Pe(`idle`),$(),t&&oe(`assistant`,t).catch(()=>{})}function Z(e,t,r){let o=document.getElementById(`chatMessages`),c=b();q(),K();let l=s(t),u=a(e===`user`?i(`msg.you`):ee()),d=document.createElement(`div`);e===`agent`?(d.className=`msg msg-agent`,d.innerHTML=`<div class="agent-icon" aria-hidden="true">${W(r)}</div><div class="agent-body"><div class="msg-content">${l}</div><button class="msg-copy" title="Copy" aria-label="Copy message"></button></div>`):(d.className=`msg msg-${e}`,d.innerHTML=`<div class="msg-label">${u}</div><div class="msg-content">${l}</div><button class="msg-copy" title="Copy" aria-label="Copy message"></button>`);let f=d.querySelector(`.msg-content`);f&&f.setAttribute(`data-raw`,n(t));let p=e===`agent`&&!t;return c.active&&!p?c.appendLiveItem(d):(o?.appendChild(d),O(d)),Q(),d}var He=null;function Q(){He||=requestAnimationFrame(()=>{He=null;let e=document.getElementById(`chatMessages`);e&&(e.scrollTop=e.scrollHeight)})}function Ue(e,n){document.querySelectorAll(`.tab-btn`).forEach(e=>{e.classList.remove(`active`),e.setAttribute(`aria-selected`,`false`)}),document.querySelectorAll(`.tab-content`).forEach(e=>e.classList.remove(`active`)),document.getElementById({agents:`tabAgents`,settings:`tabSettings`,skills:`tabSkills`}[e])?.classList.add(`active`),n&&(n.classList.add(`active`),n.setAttribute(`aria-selected`,`true`)),e===`settings`&&t(()=>import(`./settings-tOEsbIIs.js`).then(e=>e.loadSettings()),__vite__mapDeps([0])),e===`agents`&&t(()=>import(`./employees-B11suLXa.js`).then(e=>e.loadEmployees()),__vite__mapDeps([0])),e===`skills`&&t(()=>import(`./skills-kOx6rq1X.js`).then(e=>e.loadSkills()),__vite__mapDeps([0]))}function We(){document.getElementById(`tabSettings`)?.classList.contains(`active`)?t(()=>import(`./settings-tOEsbIIs.js`).then(e=>e.savePerCli()),__vite__mapDeps([0])):t(()=>import(`./settings-tOEsbIIs.js`).then(e=>e.updateSettings()),__vite__mapDeps([0]))}async function $(){let e=await l(`/api/messages`);if(!e)return;let t=document.getElementById(`statMsgs`);t&&(t.textContent=i(`stat.messages`,{count:e.length}))}async function Ge(){let e=await l(`/api/messages`);if(e!==null){let t=b();t.clear();let r=document.getElementById(`chatMessages`);if(r&&(r.innerHTML=``),e.length>=80){for(let r of e){let e=r.role===`assistant`?`agent`:r.role,o=n(r.content),s=a(e===`user`?i(`msg.you`):ee()),c=r.role===`assistant`?U(r.tool_log):[],l=c.length>0?L(G(c),!0):``,u=`<div class="skeleton-line"></div><div class="skeleton-line"></div>`,d=e===`agent`?`<div class="msg msg-agent"><div class="agent-icon" aria-hidden="true">${W(r.cli)}</div><div class="agent-body">${l}<div class="msg-content lazy-pending" data-raw="${a(o)}">${u}</div><button class="msg-copy" title="Copy" aria-label="Copy message"></button></div></div>`:`<div class="msg msg-${e}"><div class="msg-label">${s}</div><div class="msg-content lazy-pending" data-raw="${a(o)}">${u}</div><button class="msg-copy" title="Copy" aria-label="Copy message"></button></div>`;t.addItem(crypto.randomUUID(),d)}t.onLazyRender=e=>{for(let n of e){if(!n.classList.contains(`lazy-pending`))continue;let e=n.getAttribute(`data-raw`)||``;n.innerHTML=e?s(e):``,n.classList.remove(`lazy-pending`),O(n);let r=n.closest(`[data-vs-idx]`);if(r){let e=Number(r.dataset.vsIdx);t.updateItemHtml(e,r.outerHTML)}}},t.scrollToBottom()}else e.forEach(e=>{let t=Z(e.role===`assistant`?`agent`:e.role,e.content,e.cli);if(e.role===`assistant`){let n=U(e.tool_log);if(n.length>0){let e=t.querySelector(`.agent-body`);if(e){let t=z(e);for(let e of G(n))B(t,e);H(t)}}}});ie(e.map(e=>({role:e.role,content:e.content,timestamp:Date.now()}))).catch(()=>{}),J();return}let t=document.getElementById(`chatMessages`);if(t&&t.children.length>0){J();return}let r=await ae();r.length>0&&(r.forEach(e=>Z(e.role===`assistant`?`agent`:e.role,e.content)),Le(`${o.warning} 오프라인 모드 — 캐시된 메시지 표시 중`)),J()}function Ke(){let e=document.getElementById(`chatMessages`);e&&(Me(e),ke(e),e.addEventListener(`click`,e=>{let t=e.target,n=t.closest(`.tool-group-summary`);if(n){let e=n.closest(`.tool-group`),t=n.nextElementSibling;if(e&&t){let r=!e.classList.contains(`expanded`);e.classList.toggle(`expanded`),t.classList.toggle(`collapsed`),n.setAttribute(`aria-expanded`,r?`true`:`false`)}return}let r=t.closest(`.msg-copy`);if(!r)return;let i=r.closest(`.msg`)?.querySelector(`.msg-content`);if(!i)return;let a=i.getAttribute(`data-raw`)||i.innerText||i.textContent||``;navigator.clipboard.writeText(a).then(()=>{r.classList.add(`copied`),r.innerHTML=o.checkSimple,setTimeout(()=>{r.classList.remove(`copied`),r.textContent=``},600)}).catch(()=>{})}))}export{se as _,Ve as a,Ge as c,Pe as d,ze as f,b as g,Oe as h,Re as i,$ as l,Fe as m,Le as n,We as o,Ue as p,Be as r,Ke as s,Z as t,Q as u,te as v};
131
+ </div>`}function je(e){let t=e.closest(`.process-step`),n=t?.querySelector(`.process-step-details`),r=e.querySelector(`.process-step-chevron`);if(!t||!n)return;let i=n.classList.contains(`collapsed`);n.classList.toggle(`collapsed`,!i),t.classList.toggle(`expanded`,i),e.setAttribute(`aria-expanded`,i?`true`:`false`),r&&(r.innerHTML=i?o.chevronDown:o.chevronRight)}function Me(e){e.dataset.processBlockBound!==`1`&&(e.addEventListener(`click`,e=>{let t=e.target;if(!t)return;let n=t.closest(`.process-step-toggle`);if(n){je(n);return}let r=t.closest(`.process-summary`);if(r){let e=r.closest(`.process-block`);if(!e)return;let t=e.classList.contains(`collapsed`);e.classList.toggle(`collapsed`,!t),r.setAttribute(`aria-expanded`,t?`true`:`false`);let n=r.querySelector(`.process-chevron`);n&&(n.innerHTML=t?o.chevronDown:o.chevronRight)}}),e.dataset.processBlockBound=`1`)}function L(e,t=!0){let n=I(N(e),t),r=document.createElement(`div`);r.innerHTML=n;let i=r.querySelector(`.process-steps-inner`);i&&(i.innerHTML=e.map(F).join(``));let a=r.querySelector(`.process-dot`);if(a){let n=e.some(e=>e.status===`running`);a.classList.toggle(`running`,n&&!t),a.classList.toggle(`done`,!n||t)}return r.innerHTML}function R(e){let t=e.element.querySelector(`.process-summary-text`);t&&(t.innerHTML=N(e.steps));let n=e.steps.some(e=>e.status===`running`),r=e.element.querySelector(`.process-dot`);r&&(r.classList.toggle(`running`,n&&!e.collapsed),r.classList.toggle(`done`,!n||e.collapsed));let i=e.steps.length>0?Math.round((Date.now()-e.steps[0].startTime)/1e3):0,a=e.element.querySelector(`.process-duration`);a&&(a.textContent=i>0?`${i}s`:``)}function z(e){let t=document.createElement(`div`);t.innerHTML=I(``,!1);let n=t.firstElementChild,r=e.querySelector(`.msg-content`);return r?r.before(n):e.appendChild(n),{element:n,steps:[],collapsed:!1}}function B(e,t){e.steps.push(t);let n=e.element.querySelector(`.process-steps-inner`);n&&n.insertAdjacentHTML(`beforeend`,F(t)),R(e)}function Ne(e,t,n){let r=e.steps.findIndex(e=>e.id===t);if(r===-1)return;e.steps[r]=n;let i=e.element.querySelector(`[data-step-id="${t}"]`);if(i){let e=document.createElement(`div`);e.innerHTML=F(n);let t=e.firstElementChild;t&&i.replaceWith(t)}R(e)}function V(e,t,n){let r=e.steps.find(e=>e.id===t);if(!r)return;r.status=n;let i=e.element.querySelector(`[data-step-id="${t}"]`);if(i){let e=i.querySelector(`.process-step-dot`);e&&(e.classList.remove(`running`,`done`,`error`),e.classList.add(n))}R(e)}function H(e){e.collapsed=!0,e.element.classList.add(`collapsed`);let t=e.element.querySelector(`.process-summary`);t&&t.setAttribute(`aria-expanded`,`false`);let n=e.element.querySelector(`.process-chevron`);n&&(n.innerHTML=o.chevronRight);for(let t of e.steps)t.status===`running`&&(t.status=`done`);e.element.querySelectorAll(`.process-step-dot.running`).forEach(e=>{e.classList.remove(`running`),e.classList.add(`done`)}),R(e)}function U(e){if(!e)return[];try{let t=JSON.parse(e);return Array.isArray(t)?t:[]}catch{return[]}}function W(e){return o.shark}function G(e){return e.map(e=>({id:crypto.randomUUID(),icon:e.icon?c(e.icon):o.tool,label:e.label||e.name||`tool`,type:e.toolType||`tool`,detail:e.detail||``,stepRef:e.stepRef||``,status:e.status||`done`,startTime:Date.now()}))}function Pe(t){let n=document.getElementById(`statusBadge`),r=document.getElementById(`btnSend`);e.agentBusy=t===`running`,document.getElementById(`typingIndicator`)?.classList.toggle(`active`,e.agentBusy),t===`running`?(n&&(n.className=`status-badge status-running`,n.textContent=`running`),r&&(r.innerHTML=o.stop,r.title=i(`btn.stop`),r.classList.add(`stop-mode`)),Ie()):(n&&(n.className=`status-badge status-idle`,n.textContent=`idle`),r&&(r.innerHTML=o.send,r.title=`Send`,r.classList.remove(`stop-mode`)),K(),Fe(0))}function Fe(e){let t=document.getElementById(`queueBadge`);if(!t){t=document.createElement(`span`),t.id=`queueBadge`,t.className=`queue-badge`;let e=document.getElementById(`btnSend`);e?.parentElement&&(e.parentElement.style.position=`relative`),e&&(e.style.position=`relative`,e.appendChild(t))}t.textContent=e>0?String(e):``,t.style.display=e>0?`flex`:`none`}function Ie(){let e=document.getElementById(`chatMessages`);if(!e||e.querySelector(`.skeleton-msg`))return;q();let t=document.createElement(`div`);t.className=`skeleton-msg`,t.innerHTML=`<div class="skeleton-line"></div><div class="skeleton-line"></div><div class="skeleton-line"></div>`,e.appendChild(t),Q()}function K(){document.querySelectorAll(`.skeleton-msg`).forEach(e=>e.remove())}function q(){document.getElementById(`emptyState`)?.classList.remove(`visible`)}function J(){let e=document.getElementById(`chatMessages`);e&&e.children.length===0&&document.getElementById(`emptyState`)?.classList.add(`visible`)}function Le(e,t,n){let r=document.getElementById(`chatMessages`);if(!r)return;let i=b();q();let a=document.createElement(`div`);a.className=`msg msg-system`+(n?` msg-type-${n}`:``)+(t?` `+t:``),a.innerHTML=e,i.active?i.appendLiveItem(a):r.appendChild(a),Q()}function Re(){M(),e.currentAgentDiv=null,e.currentProcessBlock=null}function ze(t){if(K(),(!e.currentAgentDiv||!e.currentAgentDiv.isConnected)&&(e.currentAgentDiv=Z(`agent`,``),e.currentProcessBlock=null),!e.currentProcessBlock){let t=e.currentAgentDiv.querySelector(`.agent-body`);t&&(e.currentProcessBlock=z(t))}if(e.currentProcessBlock){let n=t.status&&t.status!==`running`?t.status:r(t.icon);if(n===`done`||n===`error`){let r=t.stepRef,i=r?[...e.currentProcessBlock.steps].reverse().find(e=>e.status===`running`&&e.stepRef===r):[...e.currentProcessBlock.steps].reverse().find(e=>e.status===`running`&&e.label===t.label);if(i){V(e.currentProcessBlock,i.id,n),Q();return}let a=[...e.currentProcessBlock.steps].reverse().find(e=>e.status===`running`);if(a){V(e.currentProcessBlock,a.id,n),Q();return}}if(t.detail){let n=[...e.currentProcessBlock.steps].reverse().find(e=>e.status===`running`&&e.label===t.label&&e.type===t.type&&!e.detail);if(n){Ne(e.currentProcessBlock,n.id,t),Q();return}}t.icon=c(t.icon),B(e.currentProcessBlock,t)}Q()}var Y=null;function Be(t){if(!t)return;K(),(!e.currentAgentDiv||!e.currentAgentDiv.isConnected)&&(e.currentAgentDiv=Z(`agent`,``),Y=null);let n=e.currentAgentDiv?.querySelector(`.msg-content`);n&&(Y||=de(n),fe(Y,t)),Q()}var X=0;function Ve(t,r){let i=Date.now();if(!e.currentAgentDiv&&i-X<500)return;M(),K();let a=!!e.currentProcessBlock;e.currentProcessBlock&&=(H(e.currentProcessBlock),null);let o=r&&r.length>0;if(t||o){(!e.currentAgentDiv||!e.currentAgentDiv.isConnected)&&(e.currentAgentDiv=Z(`agent`,``));let i=e.currentAgentDiv?.querySelector(`.msg-content`),c=Y?pe(Y,!0):``,l=t||c;Y=null;let u=o&&!a?L(G(r),!0):``;i&&(i.innerHTML=u+s(l)),i&&i.setAttribute(`data-raw`,n(l)),i&&O(i);let d=b();d.active&&e.currentAgentDiv&&e.currentAgentDiv.isConnected&&(d.appendLiveItem(e.currentAgentDiv),e.currentAgentDiv.remove())}Y=null,e.currentAgentDiv=null,X=Date.now(),Pe(`idle`),$(),t&&oe(`assistant`,t).catch(()=>{})}function Z(e,t,r){let o=document.getElementById(`chatMessages`),c=b();q(),K();let l=s(t),u=a(e===`user`?i(`msg.you`):ee()),d=document.createElement(`div`);e===`agent`?(d.className=`msg msg-agent`,d.innerHTML=`<div class="agent-icon" aria-hidden="true">${W(r)}</div><div class="agent-body"><div class="msg-content">${l}</div><button class="msg-copy" title="Copy" aria-label="Copy message"></button></div>`):(d.className=`msg msg-${e}`,d.innerHTML=`<div class="msg-label">${u}</div><div class="msg-content">${l}</div><button class="msg-copy" title="Copy" aria-label="Copy message"></button>`);let f=d.querySelector(`.msg-content`);f&&f.setAttribute(`data-raw`,n(t));let p=e===`agent`&&!t;return c.active&&!p?c.appendLiveItem(d):(o?.appendChild(d),O(d),!c.active&&!p&&o&&o.querySelectorAll(`.msg`).length>=80&&(o.querySelectorAll(`.msg`).forEach(e=>{c.addItem(crypto.randomUUID(),e.outerHTML)}),c.onPostRender=e=>{O(e)})),Q(),d}var He=null;function Q(){He||=requestAnimationFrame(()=>{He=null;let e=document.getElementById(`chatMessages`);e&&(e.scrollTop=e.scrollHeight)})}function Ue(e,n){document.querySelectorAll(`.tab-btn`).forEach(e=>{e.classList.remove(`active`),e.setAttribute(`aria-selected`,`false`)}),document.querySelectorAll(`.tab-content`).forEach(e=>e.classList.remove(`active`)),document.getElementById({agents:`tabAgents`,settings:`tabSettings`,skills:`tabSkills`}[e])?.classList.add(`active`),n&&(n.classList.add(`active`),n.setAttribute(`aria-selected`,`true`)),e===`settings`&&t(()=>import(`./settings-uJ9ftA50.js`).then(e=>e.loadSettings()),__vite__mapDeps([0])),e===`agents`&&t(()=>import(`./employees-Epnu4Dr0.js`).then(e=>e.loadEmployees()),__vite__mapDeps([0])),e===`skills`&&t(()=>import(`./skills-BG6RWbOV.js`).then(e=>e.loadSkills()),__vite__mapDeps([0]))}function We(){document.getElementById(`tabSettings`)?.classList.contains(`active`)?t(()=>import(`./settings-uJ9ftA50.js`).then(e=>e.savePerCli()),__vite__mapDeps([0])):t(()=>import(`./settings-uJ9ftA50.js`).then(e=>e.updateSettings()),__vite__mapDeps([0]))}async function $(){let e=await l(`/api/messages`);if(!e)return;let t=document.getElementById(`statMsgs`);t&&(t.textContent=i(`stat.messages`,{count:e.length}))}async function Ge(){let e=await l(`/api/messages`);if(e!==null){let t=b();t.clear();let r=document.getElementById(`chatMessages`);if(r&&(r.innerHTML=``),e.length>=80){for(let r of e){let e=r.role===`assistant`?`agent`:r.role,o=n(r.content),s=a(e===`user`?i(`msg.you`):ee()),c=r.role===`assistant`?U(r.tool_log):[],l=c.length>0?L(G(c),!0):``,u=`<div class="skeleton-line"></div><div class="skeleton-line"></div>`,d=e===`agent`?`<div class="msg msg-agent"><div class="agent-icon" aria-hidden="true">${W(r.cli)}</div><div class="agent-body">${l}<div class="msg-content lazy-pending" data-raw="${a(o)}">${u}</div><button class="msg-copy" title="Copy" aria-label="Copy message"></button></div></div>`:`<div class="msg msg-${e}"><div class="msg-label">${s}</div><div class="msg-content lazy-pending" data-raw="${a(o)}">${u}</div><button class="msg-copy" title="Copy" aria-label="Copy message"></button></div>`;t.addItem(crypto.randomUUID(),d)}t.onLazyRender=e=>{for(let n of e){if(!n.classList.contains(`lazy-pending`))continue;let e=n.getAttribute(`data-raw`)||``;n.innerHTML=e?s(e):``,n.classList.remove(`lazy-pending`),O(n);let r=n.closest(`[data-vs-idx]`);if(r){let e=Number(r.dataset.vsIdx);t.updateItemHtml(e,r.outerHTML)}}},t.onPostRender=e=>{O(e)},t.scrollToBottom()}else e.forEach(e=>{let t=Z(e.role===`assistant`?`agent`:e.role,e.content,e.cli);if(e.role===`assistant`){let n=U(e.tool_log);if(n.length>0){let e=t.querySelector(`.agent-body`);if(e){let t=z(e);for(let e of G(n))B(t,e);H(t)}}}});ie(e.map(e=>({role:e.role,content:e.content,timestamp:Date.now()}))).catch(()=>{}),J();return}let t=document.getElementById(`chatMessages`);if(t&&t.children.length>0){J();return}let r=await ae();r.length>0&&(r.forEach(e=>Z(e.role===`assistant`?`agent`:e.role,e.content)),Le(`${o.warning} 오프라인 모드 — 캐시된 메시지 표시 중`)),J()}function Ke(){let e=document.getElementById(`chatMessages`);e&&(Me(e),ke(e),e.addEventListener(`click`,e=>{let t=e.target,n=t.closest(`.tool-group-summary`);if(n){let e=n.closest(`.tool-group`),t=n.nextElementSibling;if(e&&t){let r=!e.classList.contains(`expanded`);e.classList.toggle(`expanded`),t.classList.toggle(`collapsed`),n.setAttribute(`aria-expanded`,r?`true`:`false`)}return}let r=t.closest(`.msg-copy`);if(!r)return;let i=r.closest(`.msg`)?.querySelector(`.msg-content`);if(!i)return;let a=i.getAttribute(`data-raw`)||i.innerText||i.textContent||``;navigator.clipboard.writeText(a).then(()=>{r.classList.add(`copied`),r.innerHTML=o.checkSimple,setTimeout(()=>{r.classList.remove(`copied`),r.textContent=``},600)}).catch(()=>{})}))}export{se as _,Ve as a,Ge as c,Pe as d,ze as f,b as g,Oe as h,Re as i,$ as l,Fe as m,Le as n,We as o,Ue as p,Be as r,Ke as s,Z as t,Q as u,te as v};
@@ -1,2 +1,2 @@
1
1
  const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/vendor-render-Bjnw0wQ6.css"])))=>i.map(i=>d[i]);
2
- import{t as e}from"./state-O6NVkWcL.js";import{Z as t}from"./vendor-mermaid-lvHqQdfg.js";import{d as n,m as r,n as i,o as a,t as o}from"./render-C5gpc065.js";import{a as s,d as c,f as l,g as u,i as d,m as f,n as p,r as m,t as h}from"./ui-ORW7tzea.js";var g=[`P`,`A`,`B`,`C`],_=null;function v(e,t,n){let r=g.indexOf(n);if(r<0)return;let i=e.getBoundingClientRect(),a=t.offsetWidth||36,o=document.getElementById(`dot-${n}`);if(!o)return;let s=g[r+1],c=s?document.getElementById(`dot-${s}`):null;if(c){let e=o.getBoundingClientRect(),n=c.getBoundingClientRect(),r=(e.right+n.left)/2;t.style.left=r-i.left-a/2+`px`}else{let e=o.getBoundingClientRect();t.style.left=e.left-i.left+e.width/2-a/2+`px`}}var y={},b=``;function x(e){for(let e of Object.keys(y))delete y[e];for(let t of e)t.state===`running`&&t.phase&&(y[t.agentId]={phase:t.phase,phaseLabel:t.phaseLabel||``})}function S(t,n){let r=new Set([`IDLE`,`P`,`A`,`B`,`C`,`D`]).has(t)?t:`IDLE`;if(e.orcState=r,r===`IDLE`||r===`D`)document.body.removeAttribute(`data-orc-state`),document.body.style.removeProperty(`--orc-glow`);else{document.body.setAttribute(`data-orc-state`,r);let e=`--orc-glow-${r}`,t=getComputedStyle(document.documentElement).getPropertyValue(e).trim();document.body.style.setProperty(`--orc-glow`,t)}document.body.classList.add(`orc-pulse`),setTimeout(()=>document.body.classList.remove(`orc-pulse`),700);let i=document.getElementById(`orcStateBadge`);i&&(i.textContent={IDLE:``,P:`PLAN`,A:`AUDIT`,B:`BUILD`,C:`CHECK`,D:`DONE`}[r],i.style.display=r===`IDLE`?`none`:`inline-block`);let a=document.getElementById(`pabcRoadmap`),o=document.getElementById(`sharkRunner`),s=document.getElementById(`pabcBrand`);if(a&&o){if(!a.dataset.resizeObserved){a.dataset.resizeObserved=`1`,new ResizeObserver(()=>{_&&o.classList.contains(`running`)&&v(a,o,_)}).observe(a);let e=0;window.addEventListener(`resize`,()=>{cancelAnimationFrame(e),e=requestAnimationFrame(()=>{_&&o.classList.contains(`running`)&&v(a,o,_)})})}if(r===`IDLE`)a.classList.remove(`visible`,`shimmer-out`),o.classList.remove(`running`),_=null;else if(r===`D`){g.forEach(e=>{let t=document.getElementById(`dot-${e}`);t&&(t.className=`pabc-dot done`,t.setAttribute(`data-phase`,e))});for(let e=0;e<4;e++){let t=document.getElementById(`pabc-conn-${e}`);t&&(t.className=`pabc-connector done`)}o.classList.remove(`running`),_=null,a.classList.add(`shimmer-out`),setTimeout(()=>a.classList.remove(`visible`,`shimmer-out`),1e3)}else{a.classList.remove(`shimmer-out`),a.classList.add(`visible`),o.classList.add(`running`);let e=g.indexOf(r);g.forEach((t,n)=>{let r=document.getElementById(`dot-${t}`);r&&(r.className=`pabc-dot ${n<e?`done`:n===e?`active`:`future`}`,r.setAttribute(`data-phase`,t))});for(let t=0;t<4;t++){let n=document.getElementById(`pabc-conn-${t}`);n&&(n.className=`pabc-connector ${t<e?`done`:``}`)}_=r,requestAnimationFrame(()=>v(a,o,r))}s&&n&&(s.textContent=n)}}function C(){let g=`ws://${location.host}`;e.ws=new WebSocket(`${g}?lang=${n()}`),e.ws.onmessage=e=>{let n;try{n=JSON.parse(e.data)}catch{console.warn(`[ws] malformed message:`,e.data);return}if(!n||typeof n!=`object`||typeof n.type!=`string`){console.warn(`[ws] invalid message shape:`,n);return}if(n.type===`agent_status`)n.running===void 0?c(n.status||`idle`):c(n.running?`running`:`idle`),n.agentId&&n.phase&&(y[n.agentId]={phase:n.phase,phaseLabel:n.phaseLabel||``},t(()=>import(`./employees-B11suLXa.js`).then(e=>e.loadEmployees()),__vite__mapDeps([0])));else if(n.type===`queue_update`)f(n.pending||0);else if(n.type===`worklog_created`)p(`${a.clipboard} Worklog: ${i(n.path||``)}`);else if(n.type===`round_start`){let e=n.agentPhases||n.subtasks||[],t=e.map(e=>i(e.agent||e.name||``)).join(`, `);p(r(`ws.roundStart`,{round:n.round||0,count:e.length,names:t}))}else if(n.type===`round_done`)n.action===`complete`?p(r(`ws.roundDone`,{round:n.round||0})):n.action===`next`?p(r(`ws.roundNext`,{round:n.round||0})):p(r(`ws.roundRetry`,{round:n.round||0}));else if(n.type===`agent_tool`){let e=n.toolType===`thinking`?`thinking`:n.toolType===`search`?`search`:`tool`;l({id:`step-${Date.now()}-${Math.random().toString(36).slice(2,6)}`,type:e,icon:n.icon||a.tool,label:n.label||``,detail:n.detail||``,stepRef:n.stepRef||``,status:n.status||`running`,startTime:Date.now()})}else if(n.type===`agent_output`)m(n.text||``);else if(n.type===`agent_retry`)p(r(`ws.retry`,{cli:i(n.cli||``),delay:n.delay||10}),`tool-activity`);else if(n.type===`agent_fallback`)p(r(`ws.fallback`,{from:i(n.from||``),to:i(n.to||``)}),`tool-activity`);else if(n.type===`agent_smoke`)p(`${a.warning} ${i(n.cli||`agent`)}: smoke response detected — auto-continuing`,`tool-activity`);else if(n.type===`agent_done`)s(n.text||``,n.toolLog);else if(n.type===`orchestrate_done`)s(n.text||``);else if(n.type===`clear`){o(),d(),u().clear();let e=document.getElementById(`chatMessages`);e&&(e.innerHTML=``)}else if(n.type===`session_reset`)p(`${a.refresh} Session reset — history preserved`,`tool-activity`);else if(n.type===`agent_added`||n.type===`agent_updated`||n.type===`agent_deleted`)t(()=>import(`./employees-B11suLXa.js`).then(e=>e.loadEmployees()),__vite__mapDeps([0]));else if(n.type===`orc_state`){if(n.scope&&b&&n.scope!==b)return;S(typeof n.state==`string`?n.state:`IDLE`,n.title)}else n.type===`new_message`&&(n.source===`telegram`||n.source===`discord`)&&h(n.role===`assistant`?`agent`:n.role||`user`,n.content||``,n.cli)},e.ws.onopen=()=>{console.log(`[ws] connected`),t(()=>import(`./ui-ByJAyywC.js`).then(e=>{e.cleanupToolActivity(),e.loadMessages(),e.setStatus(`idle`)}),__vite__mapDeps([0])),fetch(`/api/orchestrate/snapshot`).then(e=>e.json()).then(e=>{b=String(e.orc.scope||``),S(e.orc.state),x(e.workers),f(e.runtime.queuePending),c(e.runtime.busy?`running`:`idle`),t(()=>import(`./employees-B11suLXa.js`).then(e=>{typeof e.renderEmployees==`function`&&e.renderEmployees()}),__vite__mapDeps([0]))}).catch(()=>{})},e.ws.onclose=()=>{console.log(`[ws] disconnected, reconnecting in 2s...`),t(()=>import(`./ui-ByJAyywC.js`).then(e=>e.cleanupToolActivity()),__vite__mapDeps([0])),c(`idle`),p(`${a.exec} 연결 끊김 — 재연결 중...`,`tool-activity`),setTimeout(C,2e3)}}function w(e){return y[e]||null}export{w as n,C as t};
2
+ import{t as e}from"./state-O6NVkWcL.js";import{Z as t}from"./vendor-mermaid-lvHqQdfg.js";import{d as n,m as r,n as i,o as a,t as o}from"./render-DIojC86t.js";import{a as s,d as c,f as l,g as u,i as d,m as f,n as p,r as m,t as h}from"./ui-Drug8_7N.js";var g=[`P`,`A`,`B`,`C`],_=null;function v(e,t,n){let r=g.indexOf(n);if(r<0)return;let i=e.getBoundingClientRect(),a=t.offsetWidth||36,o=document.getElementById(`dot-${n}`);if(!o)return;let s=g[r+1],c=s?document.getElementById(`dot-${s}`):null;if(c){let e=o.getBoundingClientRect(),n=c.getBoundingClientRect(),r=(e.right+n.left)/2;t.style.left=r-i.left-a/2+`px`}else{let e=o.getBoundingClientRect();t.style.left=e.left-i.left+e.width/2-a/2+`px`}}var y={},b=``;function x(e){for(let e of Object.keys(y))delete y[e];for(let t of e)t.state===`running`&&t.phase&&(y[t.agentId]={phase:t.phase,phaseLabel:t.phaseLabel||``})}function S(t,n){let r=new Set([`IDLE`,`P`,`A`,`B`,`C`,`D`]).has(t)?t:`IDLE`;if(e.orcState=r,r===`IDLE`||r===`D`)document.body.removeAttribute(`data-orc-state`),document.body.style.removeProperty(`--orc-glow`);else{document.body.setAttribute(`data-orc-state`,r);let e=`--orc-glow-${r}`,t=getComputedStyle(document.documentElement).getPropertyValue(e).trim();document.body.style.setProperty(`--orc-glow`,t)}document.body.classList.add(`orc-pulse`),setTimeout(()=>document.body.classList.remove(`orc-pulse`),700);let i=document.getElementById(`orcStateBadge`);i&&(i.textContent={IDLE:``,P:`PLAN`,A:`AUDIT`,B:`BUILD`,C:`CHECK`,D:`DONE`}[r],i.style.display=r===`IDLE`?`none`:`inline-block`);let a=document.getElementById(`pabcRoadmap`),o=document.getElementById(`sharkRunner`),s=document.getElementById(`pabcBrand`);if(a&&o){if(!a.dataset.resizeObserved){a.dataset.resizeObserved=`1`,new ResizeObserver(()=>{_&&o.classList.contains(`running`)&&v(a,o,_)}).observe(a);let e=0;window.addEventListener(`resize`,()=>{cancelAnimationFrame(e),e=requestAnimationFrame(()=>{_&&o.classList.contains(`running`)&&v(a,o,_)})})}if(r===`IDLE`)a.classList.remove(`visible`,`shimmer-out`),o.classList.remove(`running`),_=null;else if(r===`D`){g.forEach(e=>{let t=document.getElementById(`dot-${e}`);t&&(t.className=`pabc-dot done`,t.setAttribute(`data-phase`,e))});for(let e=0;e<4;e++){let t=document.getElementById(`pabc-conn-${e}`);t&&(t.className=`pabc-connector done`)}o.classList.remove(`running`),_=null,a.classList.add(`shimmer-out`),setTimeout(()=>a.classList.remove(`visible`,`shimmer-out`),1e3)}else{a.classList.remove(`shimmer-out`),a.classList.add(`visible`),o.classList.add(`running`);let e=g.indexOf(r);g.forEach((t,n)=>{let r=document.getElementById(`dot-${t}`);r&&(r.className=`pabc-dot ${n<e?`done`:n===e?`active`:`future`}`,r.setAttribute(`data-phase`,t))});for(let t=0;t<4;t++){let n=document.getElementById(`pabc-conn-${t}`);n&&(n.className=`pabc-connector ${t<e?`done`:``}`)}_=r,requestAnimationFrame(()=>v(a,o,r))}s&&n&&(s.textContent=n)}}function C(){let g=`ws://${location.host}`;e.ws=new WebSocket(`${g}?lang=${n()}`),e.ws.onmessage=e=>{let n;try{n=JSON.parse(e.data)}catch{console.warn(`[ws] malformed message:`,e.data);return}if(!n||typeof n!=`object`||typeof n.type!=`string`){console.warn(`[ws] invalid message shape:`,n);return}if(n.type===`agent_status`)n.running===void 0?c(n.status||`idle`):c(n.running?`running`:`idle`),n.agentId&&n.phase&&(y[n.agentId]={phase:n.phase,phaseLabel:n.phaseLabel||``},t(()=>import(`./employees-Epnu4Dr0.js`).then(e=>e.loadEmployees()),__vite__mapDeps([0])));else if(n.type===`queue_update`)f(n.pending||0);else if(n.type===`worklog_created`)p(`${a.clipboard} Worklog: ${i(n.path||``)}`);else if(n.type===`round_start`){let e=n.agentPhases||n.subtasks||[],t=e.map(e=>i(e.agent||e.name||``)).join(`, `);p(r(`ws.roundStart`,{round:n.round||0,count:e.length,names:t}))}else if(n.type===`round_done`)n.action===`complete`?p(r(`ws.roundDone`,{round:n.round||0})):n.action===`next`?p(r(`ws.roundNext`,{round:n.round||0})):p(r(`ws.roundRetry`,{round:n.round||0}));else if(n.type===`agent_tool`){let e=n.toolType===`thinking`?`thinking`:n.toolType===`search`?`search`:`tool`;l({id:`step-${Date.now()}-${Math.random().toString(36).slice(2,6)}`,type:e,icon:n.icon||a.tool,label:n.label||``,detail:n.detail||``,stepRef:n.stepRef||``,status:n.status||`running`,startTime:Date.now()})}else if(n.type===`agent_output`)m(n.text||``);else if(n.type===`agent_retry`)p(r(`ws.retry`,{cli:i(n.cli||``),delay:n.delay||10}),`tool-activity`);else if(n.type===`agent_fallback`)p(r(`ws.fallback`,{from:i(n.from||``),to:i(n.to||``)}),`tool-activity`);else if(n.type===`agent_smoke`)p(`${a.warning} ${i(n.cli||`agent`)}: smoke response detected — auto-continuing`,`tool-activity`);else if(n.type===`agent_done`)s(n.text||``,n.toolLog);else if(n.type===`orchestrate_done`)s(n.text||``);else if(n.type===`clear`){o(),d(),u().clear();let e=document.getElementById(`chatMessages`);e&&(e.innerHTML=``)}else if(n.type===`session_reset`)p(`${a.refresh} Session reset — history preserved`,`tool-activity`);else if(n.type===`agent_added`||n.type===`agent_updated`||n.type===`agent_deleted`)t(()=>import(`./employees-Epnu4Dr0.js`).then(e=>e.loadEmployees()),__vite__mapDeps([0]));else if(n.type===`orc_state`){if(n.scope&&b&&n.scope!==b)return;S(typeof n.state==`string`?n.state:`IDLE`,n.title)}else n.type===`new_message`&&(n.source===`telegram`||n.source===`discord`)&&h(n.role===`assistant`?`agent`:n.role||`user`,n.content||``,n.cli)},e.ws.onopen=()=>{console.log(`[ws] connected`),t(()=>import(`./ui-DWkhzfMp.js`).then(e=>{e.cleanupToolActivity(),e.loadMessages(),e.setStatus(`idle`)}),__vite__mapDeps([0])),fetch(`/api/orchestrate/snapshot`).then(e=>e.json()).then(e=>{b=String(e.orc.scope||``),S(e.orc.state),x(e.workers),f(e.runtime.queuePending),c(e.runtime.busy?`running`:`idle`),t(()=>import(`./employees-Epnu4Dr0.js`).then(e=>{typeof e.renderEmployees==`function`&&e.renderEmployees()}),__vite__mapDeps([0]))}).catch(()=>{})},e.ws.onclose=()=>{console.log(`[ws] disconnected, reconnecting in 2s...`),t(()=>import(`./ui-DWkhzfMp.js`).then(e=>e.cleanupToolActivity()),__vite__mapDeps([0])),c(`idle`),p(`${a.exec} 연결 끊김 — 재연결 중...`,`tool-activity`),setTimeout(C,2e3)}}function w(e){return y[e]||null}export{w as n,C as t};
@@ -17,7 +17,7 @@
17
17
  href="https://fonts.googleapis.com/css2?family=Chakra+Petch:wght@400;500;600;700&family=Outfit:wght@400;500;600;700&display=swap"
18
18
  rel="stylesheet">
19
19
  <!-- Vite handles module bundling in dev (HMR) and production (build) -->
20
- <script type="module" crossorigin src="/dist/assets/index-CMUmeewA.js"></script>
20
+ <script type="module" crossorigin src="/dist/assets/index-BGm4_nDe.js"></script>
21
21
  <link rel="stylesheet" crossorigin href="/dist/assets/vendor-render-Bjnw0wQ6.css">
22
22
  <link rel="stylesheet" crossorigin href="/dist/assets/index-C3xIEYRH.css">
23
23
  </head>
package/public/js/ui.ts CHANGED
@@ -113,14 +113,17 @@ export function addSystemMsg(text: string, extraClass?: string, type?: string):
113
113
  const container = document.getElementById('chatMessages');
114
114
  if (!container) return;
115
115
  const vs = getVirtualScroll();
116
- if (vs.active) vs.flushToDOM();
117
116
  hideEmptyState();
118
117
  const div = document.createElement('div');
119
118
  const typeClass = type ? ` msg-type-${type}` : '';
120
119
  div.className = 'msg msg-system' + typeClass + (extraClass ? ' ' + extraClass : '');
121
120
  div.innerHTML = text;
122
- container.appendChild(div);
123
- container.scrollTop = container.scrollHeight;
121
+ if (vs.active) {
122
+ vs.appendLiveItem(div);
123
+ } else {
124
+ container.appendChild(div);
125
+ }
126
+ scrollToBottom();
124
127
  }
125
128
 
126
129
  export function cleanupToolActivity(): void {
@@ -289,6 +292,21 @@ export function addMessage(role: string, text: string, cli?: string | null): HTM
289
292
  } else {
290
293
  container?.appendChild(div);
291
294
  activateWidgets(div);
295
+
296
+ // Check if live growth crossed threshold — activate VS
297
+ if (!vs.active && !isStreamingPlaceholder && container) {
298
+ const msgCount = container.querySelectorAll('.msg').length;
299
+ if (msgCount >= VS_THRESHOLD) {
300
+ // Feed all existing DOM messages into VS items array
301
+ container.querySelectorAll('.msg').forEach(el => {
302
+ vs.addItem(crypto.randomUUID(), el.outerHTML);
303
+ });
304
+ // Wire widget activation for VS-rendered items
305
+ vs.onPostRender = (viewport: HTMLElement) => {
306
+ activateWidgets(viewport);
307
+ };
308
+ }
309
+ }
292
310
  }
293
311
  scrollToBottom();
294
312
  return div;
@@ -384,6 +402,11 @@ export async function loadMessages(): Promise<void> {
384
402
  }
385
403
  };
386
404
 
405
+ // Activate widgets on all VS-rendered items (covers live appends too)
406
+ vs.onPostRender = (viewport: HTMLElement) => {
407
+ activateWidgets(viewport);
408
+ };
409
+
387
410
  vs.scrollToBottom();
388
411
  } else {
389
412
  msgs.forEach(m => {
@@ -26,8 +26,9 @@ export class VirtualScroll {
26
26
  private firstVisible = 0;
27
27
  private lastVisible = 0;
28
28
 
29
- /** Called after render() mounts items in viewport — for lazy rendering */
29
+ /** Called after render() mounts items in viewport — for lazy rendering and widget activation */
30
30
  onLazyRender: LazyRenderCallback | null = null;
31
+ onPostRender: ((viewport: HTMLElement) => void) | null = null;
31
32
 
32
33
  constructor(containerId: string) {
33
34
  this.container = document.getElementById(containerId)!;
@@ -77,8 +78,9 @@ export class VirtualScroll {
77
78
  const item: VirtualItem = { id, html, height: EST_HEIGHT };
78
79
  this.items.push(item);
79
80
  this._totalHeight += EST_HEIGHT;
80
- this.scheduleRender();
81
- this.scrollToBottom();
81
+ // Render immediately then scroll again after height is remeasured
82
+ this.render();
83
+ this.container.scrollTop = this._totalHeight;
82
84
  }
83
85
 
84
86
  /** Update cached HTML for a specific item index (used by lazy render). */
@@ -182,6 +184,11 @@ export class VirtualScroll {
182
184
  this.onLazyRender(Array.from(lazyTargets));
183
185
  }
184
186
  }
187
+
188
+ // Fire post-render callback for widget activation on all mounted items
189
+ if (this.onPostRender) {
190
+ this.onPostRender(this.viewport);
191
+ }
185
192
  }
186
193
 
187
194
  scrollToBottom(): void {
@@ -203,6 +210,7 @@ export class VirtualScroll {
203
210
  this.firstVisible = 0;
204
211
  this.lastVisible = 0;
205
212
  this.onLazyRender = null;
213
+ this.onPostRender = null;
206
214
  if (this.rafId) {
207
215
  cancelAnimationFrame(this.rafId);
208
216
  this.rafId = null;
@@ -1 +0,0 @@
1
- import{g as e,p as t,v as n}from"./settings-BbG1hQmA.js";export{t as loadSettings,e as savePerCli,n as updateSettings};
@@ -1 +0,0 @@
1
- import{n as e}from"./skills-DL7wTirZ.js";export{e as loadSkills};
@@ -1 +0,0 @@
1
- import{a as e}from"./slash-commands-D_tV86er.js";export{e as loadCommands};
@@ -1 +0,0 @@
1
- import{c as e,d as t,i as n,m as r}from"./ui-ORW7tzea.js";export{n as cleanupToolActivity,e as loadMessages,t as setStatus,r as updateQueueBadge};