cli-jaw 1.6.8 → 1.6.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (35) hide show
  1. package/dist/server.js +31 -2
  2. package/dist/server.js.map +1 -1
  3. package/dist/src/agent/events.js +13 -0
  4. package/dist/src/agent/events.js.map +1 -1
  5. package/dist/src/agent/spawn.js +70 -8
  6. package/dist/src/agent/spawn.js.map +1 -1
  7. package/dist/src/orchestrator/distribute.js +3 -2
  8. package/dist/src/orchestrator/distribute.js.map +1 -1
  9. package/package.json +1 -1
  10. package/public/css/chat.css +40 -0
  11. package/public/dist/assets/{employees-Epnu4Dr0.js → employees-CEPHfNVY.js} +1 -1
  12. package/public/dist/assets/index-B8IrnbgE.css +1 -0
  13. package/public/dist/assets/index-C3x_6k57.js +49 -0
  14. package/public/dist/assets/render-QlEu2oeu.js +25 -0
  15. package/public/dist/assets/settings-BVVQnHUF.js +1 -0
  16. package/public/dist/assets/{settings-B5D4wxWj.js → settings-CdnaPnan.js} +1 -1
  17. package/public/dist/assets/skills-CvwX9OYV.js +12 -0
  18. package/public/dist/assets/skills-DGycsx4Z.js +1 -0
  19. package/public/dist/assets/slash-commands-hc_emveP.js +1 -0
  20. package/public/dist/assets/{slash-commands-cmcn-EJn.js → slash-commands-wMKxlUbq.js} +1 -1
  21. package/public/dist/assets/ui-BFp92C79.js +1 -0
  22. package/public/dist/assets/ui-DCgxuZBA.js +131 -0
  23. package/public/dist/assets/{ws-CWswsLQB.js → ws-DiLqX1Jg.js} +1 -1
  24. package/public/dist/index.html +2 -2
  25. package/public/js/render.ts +136 -0
  26. package/public/js/ui.ts +5 -3
  27. package/public/dist/assets/index-BGm4_nDe.js +0 -49
  28. package/public/dist/assets/index-C3xIEYRH.css +0 -1
  29. package/public/dist/assets/render-DIojC86t.js +0 -25
  30. package/public/dist/assets/settings-uJ9ftA50.js +0 -1
  31. package/public/dist/assets/skills-74SoDe9K.js +0 -12
  32. package/public/dist/assets/skills-BG6RWbOV.js +0 -1
  33. package/public/dist/assets/slash-commands-DRdRDhAK.js +0 -1
  34. package/public/dist/assets/ui-DWkhzfMp.js +0 -1
  35. package/public/dist/assets/ui-Drug8_7N.js +0 -131
@@ -1,131 +0,0 @@
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-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
- <script>
4
- (function() {
5
- var __nonce = '${e}';
6
-
7
- window.addEventListener('message', function(e) {
8
- if (e.source !== window.parent) return;
9
- if (!e.data || typeof e.data !== 'object') return;
10
-
11
- if (e.data.type === 'jaw-theme-update') {
12
- window.__jawTheme = { isDark: !!e.data.isDark };
13
- window.__jawTokens = e.data.tokens || {};
14
- window.dispatchEvent(new CustomEvent('jaw-theme-change', { detail: window.__jawTheme }));
15
- }
16
- if (e.data.type === 'jaw-request-resize') {
17
- postHeight();
18
- }
19
- if (e.data.type === 'jaw-request-screenshot') {
20
- var canvas = document.querySelector('canvas');
21
- if (canvas) {
22
- try {
23
- var dataUrl = canvas.toDataURL('image/png');
24
- window.parent.postMessage({ type: 'jaw-screenshot', dataUrl: dataUrl, nonce: __nonce }, '*');
25
- } catch(ex) { /* tainted canvas or other error */ }
26
- }
27
- }
28
- });
29
-
30
- function postHeight() {
31
- var h = Math.max(
32
- document.body.scrollHeight,
33
- document.body.offsetHeight,
34
- document.documentElement.scrollHeight
35
- );
36
- window.parent.postMessage({ type: 'jaw-diagram-resize', height: h, nonce: __nonce }, '*');
37
- }
38
-
39
- if (typeof ResizeObserver !== 'undefined') {
40
- var ro = new ResizeObserver(function() {
41
- clearTimeout(ro._t);
42
- ro._t = setTimeout(postHeight, 50);
43
- });
44
- ro.observe(document.body);
45
- }
46
-
47
- window.addEventListener('load', function() {
48
- postHeight();
49
- // Deferred re-measure for async chart renders (Chart.js animation, CDN loading)
50
- setTimeout(postHeight, 200);
51
- setTimeout(postHeight, 800);
52
- window.parent.postMessage({ type: 'jaw-widget-ready', nonce: __nonce }, '*');
53
- });
54
-
55
- var lastSend = 0;
56
- window.sendPrompt = function(text) {
57
- var now = Date.now();
58
- if (now - lastSend < 3000) return;
59
- lastSend = now;
60
- window.parent.postMessage({ type: 'jaw-send-prompt', text: String(text).slice(0, 500), nonce: __nonce }, '*');
61
- };
62
-
63
- // Ctrl+C / Cmd+C: forward selected text to host for clipboard access
64
- document.addEventListener('copy', function() {
65
- var sel = window.getSelection();
66
- if (sel && sel.toString().trim()) {
67
- window.parent.postMessage({
68
- type: 'jaw-copy-text',
69
- text: sel.toString().slice(0, 512),
70
- nonce: __nonce
71
- }, '*');
72
- }
73
- });
74
- })();
75
- <\/script>`}var we=[[/\/p5\.js\/1\.11\.1[1-9]\//g,`/p5.js/1.11.10/`]];function Te(e){for(let[t,n]of we)e=e.replace(t,n);return e}function D(e){ye(),Ee(),e=Te(e);let t=Array.from(crypto.getRandomValues(new Uint8Array(16)),e=>e.toString(16).padStart(2,`0`)).join(``),n=Se(),r=xe(e),i=be(e),a=Ce(t),o=`<!DOCTYPE html>
76
- <html>
77
- <head>
78
- <meta charset="utf-8">
79
- ${r}
80
- ${i}
81
- <style>
82
- :root { ${Object.entries(n.tokens).map(([e,t])=>`${e}: ${t};`).join(`
83
- `)} }
84
- * { margin: 0; box-sizing: border-box; }
85
- body {
86
- font-family: var(--font-ui), system-ui, sans-serif;
87
- color: var(--text);
88
- background: transparent;
89
- padding: 16px;
90
- overflow: hidden;
91
- }
92
- </style>
93
- </head>
94
- <body>
95
- <script>
96
- window.__jawTheme = ${JSON.stringify({isDark:n.isDark})};
97
- window.__jawTokens = ${JSON.stringify(n.tokens).replace(/<\//g,`<\\/`)};
98
- <\/script>
99
- ${a}
100
- ${e}
101
- </body>
102
- </html>`,s=document.createElement(`iframe`);return s.sandbox.add(`allow-scripts`),s.srcdoc=o,s.style.cssText=`width: 100%; border: none; overflow: hidden; display: block;`,s.setAttribute(`aria-label`,`Interactive diagram widget`),{iframe:s,nonce:t}}function O(e){(e||document).querySelectorAll(`.diagram-widget-pending`).forEach(e=>{let t=e.dataset.diagramHtml;if(!t)return;let n;try{if(t.length>524288)throw Error(`Widget payload too large`);n=decodeURIComponent(escape(atob(t)))}catch{e.replaceWith(Object.assign(document.createElement(`div`),{className:`diagram-error`,textContent:`Failed to decode widget content`,role:`alert`}));return}let r=_e(n);if(!r.valid){e.replaceWith(Object.assign(document.createElement(`div`),{className:`diagram-error`,textContent:`Widget blocked: ${r.reason}`,role:`alert`}));return}r.warnings.length&&console.warn(`[jaw-diagram] Widget warnings:`,r.warnings);let i=document.createElement(`div`);i.className=`diagram-container diagram-widget`,i.dataset.widgetHtml=t,i.appendChild(C()),i.appendChild(S());let{iframe:a,nonce:o}=D(n);i.appendChild(a),e.replaceWith(i);let s=!1;a.addEventListener(`load`,()=>{s?(a.contentWindow&&(w.delete(a.contentWindow),T.delete(a.contentWindow)),console.warn(`[jaw-diagram] iframe navigated — postMessage channel revoked`)):(s=!0,a.contentWindow&&(w.add(a.contentWindow),T.set(a.contentWindow,o),a.contentWindow.postMessage({type:`jaw-request-resize`},`*`),setTimeout(()=>a.contentWindow?.postMessage({type:`jaw-request-resize`},`*`),300),setTimeout(()=>a.contentWindow?.postMessage({type:`jaw-request-resize`},`*`),1e3)))});let c=Number(i.dataset.gen||`0`);i.dataset.gen=String(c);let l=!1,u=e=>{e.source===a.contentWindow&&e.data?.type===`jaw-widget-ready`&&e.data.nonce===o&&(l=!0,window.removeEventListener(`message`,u))};window.addEventListener(`message`,u),setTimeout(()=>{if(window.removeEventListener(`message`,u),Number(i.dataset.gen||`0`)===c&&!l&&i.isConnected){let e=a.contentWindow;e&&(w.delete(e),T.delete(e)),i.innerHTML=`<div class="diagram-error" role="alert">
103
- Widget failed to load within 10 seconds.
104
- </div>`,console.warn(`[jaw-diagram] Widget timeout — iframe deregistered`)}},1e4)})}var k=null;function Ee(){if(k)return;let e=document.getElementById(`chatMessages`);e&&(k=new MutationObserver(t=>{for(let n of t)for(let t of n.addedNodes)if(t instanceof HTMLElement&&(t.classList?.contains(`diagram-widget-pending`)||t.querySelector?.(`.diagram-widget-pending`))){requestAnimationFrame(()=>O(t.parentElement||e));return}}),k.observe(e,{childList:!0}))}var A=new WeakMap;function De(e,t){A.has(e)||(A.set(e,window.setTimeout(()=>A.delete(e),100)),document.querySelectorAll(`iframe`).forEach(n=>{n.contentWindow===e&&(n.style.height=`${Math.min(Math.max(t,60),2e3)}px`)}))}function Oe(){document.querySelectorAll(`.diagram-widget`).forEach(e=>{let t=e.dataset.widgetHtml;if(!t)return;let n;try{n=decodeURIComponent(escape(atob(t)))}catch{return}let r=e.querySelector(`iframe`);r?.contentWindow&&(w.delete(r.contentWindow),T.delete(r.contentWindow));let i=e;i.dataset.gen=String((Number(i.dataset.gen||`0`)||0)+1);let{iframe:a,nonce:o}=D(n);e.innerHTML=``,e.appendChild(C()),e.appendChild(S()),e.appendChild(a);let s=!1;a.addEventListener(`load`,()=>{s?a.contentWindow&&(w.delete(a.contentWindow),T.delete(a.contentWindow)):(s=!0,a.contentWindow&&(w.add(a.contentWindow),T.set(a.contentWindow,o),a.contentWindow.postMessage({type:`jaw-request-resize`},`*`),setTimeout(()=>a.contentWindow?.postMessage({type:`jaw-request-resize`},`*`),300),setTimeout(()=>a.contentWindow?.postMessage({type:`jaw-request-resize`},`*`),1e3)))})})}var j=0;window.addEventListener(`message`,e=>{if(!e.data||typeof e.data!=`object`||!e.source||e.origin!==`null`||!w.has(e.source)||![...document.querySelectorAll(`iframe`)].find(t=>t.contentWindow===e.source)?.isConnected)return;let t=T.get(e.source);if(!(!t||e.data.nonce!==t))switch(e.data.type){case`jaw-diagram-resize`:{let t=Number(e.data.height);if(!Number.isFinite(t)||t<0)return;De(e.source,t);break}case`jaw-send-prompt`:{let t=Date.now();if(t-j<3e3)return;j=t;let n=String(e.data.text||``).trim().slice(0,500);if(!n)return;let r=document.getElementById(`chatInput`);r&&(r.value=n,r.dispatchEvent(new Event(`input`,{bubbles:!0})),r.focus());break}case`jaw-copy-text`:{let t=String(e.data.text||``).trim().slice(0,512);if(!t)return;navigator.clipboard.writeText(t).catch(()=>{});break}case`jaw-screenshot`:{let t=String(e.data.dataUrl||``);if(!t.startsWith(`data:image/`)||t.length>5242880)return;fetch(t).then(e=>e.blob()).then(e=>{let t=URL.createObjectURL(e),n=document.createElement(`a`);n.href=t,n.download=`widget-${Date.now()}.png`,n.click(),setTimeout(()=>URL.revokeObjectURL(t),1e3)}).catch(()=>{});break}case`jaw-widget-ready`:break}});function ke(e){e.dataset.toolItemBound!==`1`&&(e.addEventListener(`click`,e=>{let t=e.target;if(!t)return;let n=t.closest(`.tool-item-toggle`);if(!n)return;let r=n.closest(`.tool-item`),i=r?.querySelector(`.tool-item-details`),a=n.querySelector(`.tool-item-chevron`);if(!r||!i)return;let s=i.classList.contains(`collapsed`);i.classList.toggle(`collapsed`,!s),r.classList.toggle(`expanded`,s),n.setAttribute(`aria-expanded`,s?`true`:`false`),a&&(a.innerHTML=s?o.chevronDown:o.chevronRight)}),e.dataset.toolItemBound=`1`)}function M(){document.querySelectorAll(`.tool-activity-live`).forEach(e=>e.remove()),document.querySelectorAll(`.msg-system.tool-activity`).forEach(e=>e.remove())}function N(e){let t={};for(let n of e){let e=n.type===`thinking`?`${o.thinking} Thinking`:n.type===`search`?`${o.search} Search`:`${o.tool} Tool`;t[e]=(t[e]||0)+1}return Object.entries(t).map(([e,t])=>t>1?`${e}&times;${t}`:e).join(` + `)}function Ae(e,t=120){let n=e.replace(/\s+/g,` `).trim();return n?n.length>t?`${n.slice(0,t-1)}…`:n:``}function P(e){let t=(e.detail||``).trim();return t?t!==(e.label||``).trim():!1}function F(e){let t=`process-step-dot ${e.status}`,n=`process-step-badge ${e.type}`,r=e.type.toUpperCase(),i=a(e.label||e.icon||``),s=e.detail||``,c=`process-detail-${e.id}`,l=P(e)?Ae(s,e.type===`thinking`?120:100):``,u=l?`<span class="process-step-snippet">${a(l)}</span>`:``;return P(e)?`<div class="process-step process-step-expandable" data-step-id="${e.id}" data-type="${e.type}">
105
- <button class="process-step-toggle" aria-expanded="false" aria-controls="${c}">
106
- <span class="${t}"></span>
107
- <span class="${n}">${r}</span>
108
- <span class="process-step-main">
109
- <span class="process-step-label">${i}</span>
110
- ${u}
111
- </span>
112
- <span class="process-step-chevron">${o.chevronRight}</span>
113
- </button>
114
- <div class="process-step-details collapsed" id="${c}">
115
- <pre class="process-step-full">${a(s)}</pre>
116
- </div>
117
- </div>`:`<div class="process-step" data-step-id="${e.id}" data-type="${e.type}">
118
- <span class="${t}"></span>
119
- <span class="${n}">${r}</span>
120
- <span class="process-step-label">${i}</span>
121
- </div>`}function I(e=``,t=!1){return`<div class="process-block${t?` collapsed`:``}">
122
- <button class="process-summary" aria-expanded="${t?`false`:`true`}">
123
- <span class="process-dot ${t?`done`:`running`}"></span>
124
- <span class="process-summary-text">${e}</span>
125
- <span class="process-duration"></span>
126
- <span class="process-chevron">${t?o.chevronRight:o.chevronDown}</span>
127
- </button>
128
- <div class="process-details">
129
- <div class="process-steps-inner"></div>
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();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};