jinn-cli 0.3.0 → 0.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/dist/bin/jimmy.js +0 -0
- package/dist/src/cli/chrome-allow.d.ts.map +1 -1
- package/dist/src/cli/chrome-allow.js +14 -5
- package/dist/src/cli/chrome-allow.js.map +1 -1
- package/dist/src/cli/list.js +1 -1
- package/dist/src/cli/list.js.map +1 -1
- package/dist/src/cli/nuke.js +2 -2
- package/dist/src/cli/nuke.js.map +1 -1
- package/dist/src/cli/setup.d.ts.map +1 -1
- package/dist/src/cli/setup.js +2 -1
- package/dist/src/cli/setup.js.map +1 -1
- package/dist/src/connectors/slack/index.d.ts +9 -1
- package/dist/src/connectors/slack/index.d.ts.map +1 -1
- package/dist/src/connectors/slack/index.js +172 -8
- package/dist/src/connectors/slack/index.js.map +1 -1
- package/dist/src/connectors/slack/threads.d.ts +1 -4
- package/dist/src/connectors/slack/threads.d.ts.map +1 -1
- package/dist/src/connectors/slack/threads.js +17 -7
- package/dist/src/connectors/slack/threads.js.map +1 -1
- package/dist/src/connectors/slack/threads.test.js +42 -8
- package/dist/src/connectors/slack/threads.test.js.map +1 -1
- package/dist/src/cron/runner.d.ts.map +1 -1
- package/dist/src/cron/runner.js +16 -5
- package/dist/src/cron/runner.js.map +1 -1
- package/dist/src/engines/claude.d.ts.map +1 -1
- package/dist/src/engines/claude.js +19 -4
- package/dist/src/engines/claude.js.map +1 -1
- package/dist/src/gateway/api.d.ts.map +1 -1
- package/dist/src/gateway/api.js +207 -3
- package/dist/src/gateway/api.js.map +1 -1
- package/dist/src/gateway/lifecycle.d.ts.map +1 -1
- package/dist/src/gateway/lifecycle.js +16 -6
- package/dist/src/gateway/lifecycle.js.map +1 -1
- package/dist/src/gateway/org.d.ts.map +1 -1
- package/dist/src/gateway/org.js +1 -0
- package/dist/src/gateway/org.js.map +1 -1
- package/dist/src/gateway/server.d.ts.map +1 -1
- package/dist/src/gateway/server.js +40 -1
- package/dist/src/gateway/server.js.map +1 -1
- package/dist/src/gateway/watcher.d.ts.map +1 -1
- package/dist/src/gateway/watcher.js +9 -2
- package/dist/src/gateway/watcher.js.map +1 -1
- package/dist/src/mcp/gateway-server.d.ts +13 -0
- package/dist/src/mcp/gateway-server.d.ts.map +1 -0
- package/dist/src/mcp/gateway-server.js +375 -0
- package/dist/src/mcp/gateway-server.js.map +1 -0
- package/dist/src/mcp/resolver.d.ts +19 -0
- package/dist/src/mcp/resolver.d.ts.map +1 -0
- package/dist/src/mcp/resolver.js +153 -0
- package/dist/src/mcp/resolver.js.map +1 -0
- package/dist/src/sessions/context.d.ts +1 -0
- package/dist/src/sessions/context.d.ts.map +1 -1
- package/dist/src/sessions/context.js +34 -3
- package/dist/src/sessions/context.js.map +1 -1
- package/dist/src/sessions/limits.d.ts +7 -0
- package/dist/src/sessions/limits.d.ts.map +1 -0
- package/dist/src/sessions/limits.js +42 -0
- package/dist/src/sessions/limits.js.map +1 -0
- package/dist/src/sessions/manager.d.ts +3 -1
- package/dist/src/sessions/manager.d.ts.map +1 -1
- package/dist/src/sessions/manager.js +38 -17
- package/dist/src/sessions/manager.js.map +1 -1
- package/dist/src/sessions/registry.d.ts +6 -0
- package/dist/src/sessions/registry.d.ts.map +1 -1
- package/dist/src/sessions/registry.js +34 -5
- package/dist/src/sessions/registry.js.map +1 -1
- package/dist/src/shared/effort.d.ts +17 -0
- package/dist/src/shared/effort.d.ts.map +1 -0
- package/dist/src/shared/effort.js +44 -0
- package/dist/src/shared/effort.js.map +1 -0
- package/dist/src/shared/paths.d.ts +2 -0
- package/dist/src/shared/paths.d.ts.map +1 -1
- package/dist/src/shared/paths.js +2 -0
- package/dist/src/shared/paths.js.map +1 -1
- package/dist/src/shared/types.d.ts +57 -1
- package/dist/src/shared/types.d.ts.map +1 -1
- package/dist/src/stt/stt.d.ts +24 -0
- package/dist/src/stt/stt.d.ts.map +1 -0
- package/dist/src/stt/stt.js +203 -0
- package/dist/src/stt/stt.js.map +1 -0
- package/dist/web/404.html +1 -1
- package/dist/web/_next/static/chunks/198-3e82ded4f04a0aae.js +1 -0
- package/dist/web/_next/static/chunks/{704-af2893821e1d18dc.js → 704-ca24be493a922639.js} +1 -1
- package/dist/web/_next/static/chunks/{73-c226535579393e21.js → 73-2d6e730cea0fe6c8.js} +1 -1
- package/dist/web/_next/static/chunks/app/_not-found/{page-bb075b0779827928.js → page-7d43a486b7014af3.js} +1 -1
- package/dist/web/_next/static/chunks/app/chat/page-2f3c561ed768ed58.js +1 -0
- package/dist/web/_next/static/chunks/app/costs/{page-d6c03718defdb599.js → page-13a6f2c65a827f8a.js} +1 -1
- package/dist/web/_next/static/chunks/app/cron/{page-4c563eef2b6231fe.js → page-0ee07a679c7b79aa.js} +1 -1
- package/dist/web/_next/static/chunks/app/kanban/{page-55a73165a36f4077.js → page-a7facadd4194faae.js} +1 -1
- package/dist/web/_next/static/chunks/app/layout-fd975d16033dab25.js +1 -0
- package/dist/web/_next/static/chunks/app/logs/page-6de6b16523e85193.js +1 -0
- package/dist/web/_next/static/chunks/app/org/{page-d5cd8d9b7864737b.js → page-cd9d362e77f4799e.js} +1 -1
- package/dist/web/_next/static/chunks/app/{page-b81992940fd1dbc6.js → page-b98417ed4f4d45a0.js} +1 -1
- package/dist/web/_next/static/chunks/app/sessions/page-7148306182017841.js +1 -0
- package/dist/web/_next/static/chunks/app/settings/page-34c9276e2a012445.js +1 -0
- package/dist/web/_next/static/chunks/app/skills/page-18cf3b7bb9a7339c.js +1 -0
- package/dist/web/_next/static/chunks/main-app-0c65af8a0fd99888.js +1 -0
- package/dist/web/_next/static/css/24da9dfc818cea32.css +1 -0
- package/dist/web/chat.html +1 -1
- package/dist/web/chat.txt +5 -5
- package/dist/web/costs.html +2 -2
- package/dist/web/costs.txt +5 -5
- package/dist/web/cron.html +1 -1
- package/dist/web/cron.txt +5 -5
- package/dist/web/index.html +1 -1
- package/dist/web/index.txt +5 -5
- package/dist/web/kanban.html +1 -1
- package/dist/web/kanban.txt +5 -5
- package/dist/web/logs.html +2 -2
- package/dist/web/logs.txt +5 -5
- package/dist/web/org.html +1 -1
- package/dist/web/org.txt +5 -5
- package/dist/web/sessions.html +1 -1
- package/dist/web/sessions.txt +5 -5
- package/dist/web/settings.html +1 -1
- package/dist/web/settings.txt +5 -5
- package/dist/web/skills.html +1 -1
- package/dist/web/skills.txt +5 -5
- package/package.json +9 -9
- package/template/config.default.yaml +32 -0
- package/template/docs/mcp.md +108 -0
- package/dist/web/_next/static/chunks/198-fd91406a158c5c25.js +0 -1
- package/dist/web/_next/static/chunks/app/chat/page-6d5bc707a45c92c6.js +0 -1
- package/dist/web/_next/static/chunks/app/layout-5129b67d5f126cf0.js +0 -1
- package/dist/web/_next/static/chunks/app/logs/page-e18889d67e48c9c9.js +0 -1
- package/dist/web/_next/static/chunks/app/sessions/page-c83c890177c18258.js +0 -1
- package/dist/web/_next/static/chunks/app/settings/page-2583d55551abdf72.js +0 -1
- package/dist/web/_next/static/chunks/app/skills/page-df9465e314561bb5.js +0 -1
- package/dist/web/_next/static/chunks/main-app-437f51faf74fbb3b.js +0 -1
- package/dist/web/_next/static/css/4a6a5bca9238c104.css +0 -1
- /package/dist/web/_next/static/{jt8R5JvUgfB9CMfFwWFr0 → Zn588p2VvgjCSLr44R__1}/_buildManifest.js +0 -0
- /package/dist/web/_next/static/{jt8R5JvUgfB9CMfFwWFr0 → Zn588p2VvgjCSLr44R__1}/_ssgManifest.js +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[73],{1298:(e,t,a)=>{a.d(t,{E:()=>r});function r(e,t){let a="".concat("https:"===window.location.protocol?"wss:":"ws:","//").concat(window.location.host,"/ws"),r=null,n=null,l=!1;return!function i(){l||((r=new WebSocket(a)).onopen=()=>{var e;null==t||null==(e=t.onOpen)||e.call(t)},r.onmessage=t=>{try{let a=JSON.parse(t.data);e(a.event,a.payload)}catch(e){}},r.onclose=()=>{var e;null==t||null==(e=t.onClose)||e.call(t),l||(n=setTimeout(i,3e3))},r.onerror=()=>null==r?void 0:r.close())}(),{close:()=>{l=!0,n&&clearTimeout(n),null==r||r.close()}}}},2755:(e,t,a)=>{a.d(t,{Qc:()=>u,Z6:()=>d,t0:()=>p});var r=a(8111),n=a(5271);let l={accentColor:null,portalName:null,portalSubtitle:null,portalEmoji:null,portalIcon:null,iconBgHidden:!1,emojiOnly:!1,operatorName:null,language:"English",employeeOverrides:{}},i="jinn-settings";function o(e){localStorage.setItem(i,JSON.stringify(e))}var s=a(3176);let c=(0,n.createContext)({settings:{accentColor:null,portalName:null,portalSubtitle:null,portalEmoji:null,portalIcon:null,iconBgHidden:!1,emojiOnly:!1,operatorName:null,language:"English",employeeOverrides:{}},setAccentColor:()=>{},setPortalName:()=>{},setPortalSubtitle:()=>{},setPortalEmoji:()=>{},setPortalIcon:()=>{},setIconBgHidden:()=>{},setEmojiOnly:()=>{},setOperatorName:()=>{},setLanguage:()=>{},setEmployeeOverride:()=>{},clearEmployeeOverride:()=>{},getEmployeeDisplay:e=>({emoji:e.emoji}),resetAll:()=>{}});function d(e){let{children:t}=e,[a,d]=(0,n.useState)({...l});(0,n.useEffect)(()=>{let e=function(){try{let e=localStorage.getItem(i);if(!e)return{...l};let t=JSON.parse(e);return{...l,...t}}catch(e){return{...l}}}();d(e),s.F.getOnboarding().then(t=>{if(t.portalName||t.operatorName){let a={...e,...t.portalName&&{portalName:t.portalName},...t.operatorName&&{operatorName:t.operatorName}};d(a),o(a)}}).catch(()=>{})},[]),(0,n.useEffect)(()=>{let e=document.documentElement.style;a.accentColor?(e.setProperty("--accent",a.accentColor),e.setProperty("--accent-fill",function(e){let t=parseInt(e.slice(1,3),16),a=parseInt(e.slice(3,5),16),r=parseInt(e.slice(5,7),16);return"rgba(".concat(t,",").concat(a,",").concat(r,",0.15)")}(a.accentColor)),e.setProperty("--accent-contrast",function(e){let t=parseInt(e.slice(1,3),16)/255,a=parseInt(e.slice(3,5),16)/255,r=parseInt(e.slice(5,7),16)/255,n=e=>e<=.03928?e/12.92:Math.pow((e+.055)/1.055,2.4);return .2126*n(t)+.7152*n(a)+.0722*n(r)>.4?"#000":"#fff"}(a.accentColor))):(e.removeProperty("--accent"),e.removeProperty("--accent-fill"),e.removeProperty("--accent-contrast"))},[a.accentColor]);let p=(0,n.useCallback)(e=>{d(e),o(e)},[]),u=(0,n.useCallback)(e=>{p({...a,accentColor:e})},[a,p]),h=(0,n.useCallback)(e=>{p({...a,portalName:e||null})},[a,p]),g=(0,n.useCallback)(e=>{p({...a,portalSubtitle:e||null})},[a,p]),x=(0,n.useCallback)(e=>{p({...a,portalEmoji:e||null})},[a,p]),f=(0,n.useCallback)(e=>{p({...a,portalIcon:e})},[a,p]),m=(0,n.useCallback)(e=>{p({...a,iconBgHidden:e})},[a,p]),v=(0,n.useCallback)(e=>{p({...a,emojiOnly:e})},[a,p]),y=(0,n.useCallback)(e=>{p({...a,operatorName:e||null})},[a,p]),b=(0,n.useCallback)(e=>{p({...a,language:e||"English"})},[a,p]),j=(0,n.useCallback)((e,t)=>{let r=a.employeeOverrides[e]||{};p({...a,employeeOverrides:{...a.employeeOverrides,[e]:{...r,...t}}})},[a,p]),k=(0,n.useCallback)(e=>{let{[e]:t,...r}=a.employeeOverrides;p({...a,employeeOverrides:r})},[a,p]),w=(0,n.useCallback)(e=>{let t=a.employeeOverrides[e.id];return{emoji:(null==t?void 0:t.emoji)||e.emoji,profileImage:null==t?void 0:t.profileImage,emojiOnly:a.emojiOnly}},[a.employeeOverrides,a.emojiOnly]),S=(0,n.useCallback)(()=>{p({accentColor:null,portalName:null,portalSubtitle:null,portalEmoji:null,portalIcon:null,iconBgHidden:!1,emojiOnly:!1,operatorName:null,language:"English",employeeOverrides:{}})},[p]);return(0,r.jsx)(c.Provider,{value:{settings:a,setAccentColor:u,setPortalName:h,setPortalSubtitle:g,setPortalEmoji:x,setPortalIcon:f,setIconBgHidden:m,setEmojiOnly:v,setOperatorName:y,setLanguage:b,setEmployeeOverride:j,clearEmployeeOverride:k,getEmployeeDisplay:w,resetAll:S},children:t})}let p=()=>(0,n.useContext)(c);function u(){let{settings:e}=p(),t=(0,n.useRef)(e.portalName);return t.current=e.portalName,(0,n.useEffect)(()=>{function e(){let e=t.current||"Jinn",a="".concat(e," - AI Gateway");document.title!==a&&(document.title=a)}e();let a=document.querySelector("title");if(!a)return;let r=new MutationObserver(()=>e());return r.observe(a,{childList:!0,characterData:!0,subtree:!0}),()=>r.disconnect()},[e.portalName]),null}},3073:(e,t,a)=>{a.d(t,{M:()=>ea});var r=a(8111),n=a(1251),l=a.n(n),i=a(5271),o=a(5935),s=a.n(o),c=a(4736),d=a(2755),p=a(8193),u=a(6778),h=a(7549),g=a(2265),x=a(6808),f=a(1935),m=a(6361),v=a(4514),y=a(9026),b=a(3254),j=a(5275),k=a(9006),w=a(4206),S=a(7460),C=a(9834);let N=[{href:"/",label:"Home",icon:p.A},{href:"/chat",label:"Chat",icon:u.A},{href:"/sessions",label:"Sessions",icon:h.A},{href:"/org",label:"Organization",icon:g.A},{href:"/kanban",label:"Kanban",icon:x.A},{href:"/cron",label:"Cron",icon:f.A},{href:"/costs",label:"Costs",icon:m.A},{href:"/logs",label:"Activity",icon:v.A},{href:"/skills",label:"Skills",icon:y.A},{href:"/settings",label:"Settings",icon:b.A}];function z(e){let{theme:t}=e;switch(t){case"light":return(0,r.jsx)(j.A,{size:18});case"dark":return(0,r.jsx)(k.A,{size:18});default:return(0,r.jsx)(w.A,{size:18})}}function A(){var e,t;let a=(0,c.usePathname)(),{theme:n,setTheme:l}=(0,S.D)(),{settings:o}=(0,d.t0)(),[p,u]=(0,i.useState)(!1),h=null!=(e=o.portalEmoji)?e:"\uD83E\uDD16",g=null!=(t=o.portalName)?t:"Jinn";return(0,r.jsxs)("aside",{onMouseEnter:()=>u(!0),onMouseLeave:()=>u(!1),style:{position:"fixed",left:0,top:0,bottom:0,width:p?200:56,background:"var(--bg-secondary)",borderRight:"1px solid var(--separator)",flexDirection:"column",zIndex:50,transition:"width 200ms var(--ease-smooth)",overflow:"hidden"},className:"hidden lg:flex",children:[(0,r.jsxs)("div",{style:{display:"flex",alignItems:"center",gap:10,padding:"16px 14px 12px",minHeight:56,flexShrink:0},children:[(0,r.jsx)("span",{style:{fontSize:24,lineHeight:1,flexShrink:0,width:28,textAlign:"center"},children:h}),(0,r.jsx)("span",{style:{fontSize:17,fontWeight:600,color:"var(--text-primary)",whiteSpace:"nowrap",opacity:+!!p,transition:"opacity 200ms var(--ease-smooth)"},children:g})]}),(0,r.jsx)("nav",{style:{flex:1,display:"flex",flexDirection:"column",gap:2,padding:"0 8px"},children:N.map(e=>{let t="/"===e.href?"/"===a:a.startsWith(e.href),n=e.icon;return(0,r.jsxs)(s(),{href:e.href,className:"nav-item","aria-label":e.label,"aria-current":t?"page":void 0,style:{display:"flex",alignItems:"center",gap:10,height:40,padding:"0 12px",textDecoration:"none",color:t?"var(--accent)":"var(--text-secondary)",background:t?"var(--accent-fill)":"transparent",fontWeight:t?600:400,fontSize:13,whiteSpace:"nowrap"},children:[(0,r.jsx)(n,{size:18,style:{flexShrink:0,color:t?"var(--accent)":"var(--text-secondary)"}}),(0,r.jsx)("span",{style:{opacity:+!!p,transition:"opacity 200ms var(--ease-smooth)"},children:e.label})]},e.href)})}),(0,r.jsx)("div",{style:{padding:"8px 8px 12px",flexShrink:0},children:(0,r.jsxs)("button",{onClick:function(){let e=C.z.map(e=>e.id),t=e.indexOf(n);l(e[(t+1)%e.length])},className:"nav-item","aria-label":"Theme: ".concat(n,". Click to cycle."),style:{display:"flex",alignItems:"center",gap:10,height:40,padding:"0 12px",width:"100%",border:"none",background:"transparent",color:"var(--text-secondary)",cursor:"pointer",fontSize:13,whiteSpace:"nowrap"},children:[(0,r.jsx)("span",{style:{flexShrink:0},children:(0,r.jsx)(z,{theme:n})}),(0,r.jsx)("span",{style:{opacity:+!!p,transition:"opacity 200ms var(--ease-smooth)",textTransform:"capitalize"},children:n})]})})]})}var E=a(8067);let I=window.location.origin,R=[{id:"page-home",label:"Dashboard",icon:(0,r.jsx)(p.A,{size:16}),href:"/",category:"Pages"},{id:"page-chat",label:"Chat",icon:(0,r.jsx)(u.A,{size:16}),href:"/chat",category:"Pages"},{id:"page-sessions",label:"Sessions",icon:(0,r.jsx)(h.A,{size:16}),href:"/sessions",category:"Pages"},{id:"page-org",label:"Organization",icon:(0,r.jsx)(g.A,{size:16}),href:"/org",category:"Pages"},{id:"page-kanban",label:"Kanban",icon:(0,r.jsx)(x.A,{size:16}),href:"/kanban",category:"Pages"},{id:"page-cron",label:"Cron",icon:(0,r.jsx)(f.A,{size:16}),href:"/cron",category:"Pages"},{id:"page-costs",label:"Costs",icon:(0,r.jsx)(m.A,{size:16}),href:"/costs",category:"Pages"},{id:"page-logs",label:"Activity",icon:(0,r.jsx)(v.A,{size:16}),href:"/logs",category:"Pages"},{id:"page-skills",label:"Skills",icon:(0,r.jsx)(y.A,{size:16}),href:"/skills",category:"Pages"},{id:"page-settings",label:"Settings",icon:(0,r.jsx)(b.A,{size:16}),href:"/settings",category:"Pages"}];function W(e,t){return t.toLowerCase().includes(e.toLowerCase())}function O(){var e;let{settings:t}=(0,d.t0)(),a=null!=(e=t.portalName)?e:"Jinn",[n,l]=(0,i.useState)(!1),[o,s]=(0,i.useState)(""),[p,u]=(0,i.useState)(0),[h,x]=(0,i.useState)([]),[m,v]=(0,i.useState)([]),y=(0,i.useRef)(null),b=(0,i.useRef)(null),j=(0,c.useRouter)();(0,i.useEffect)(()=>{function e(e){(e.metaKey||e.ctrlKey)&&"k"===e.key&&(e.preventDefault(),l(e=>!e))}return window.addEventListener("keydown",e),()=>window.removeEventListener("keydown",e)},[]),(0,i.useEffect)(()=>{n&&(s(""),u(0),fetch("".concat(I,"/api/org")).then(e=>{if(!e.ok)throw Error("HTTP ".concat(e.status));return e.json()}).then(e=>{if(Array.isArray(e))x(e);else if(e&&"object"==typeof e&&"employees"in e){var t;x(null!=(t=e.employees)?t:[])}}).catch(()=>x([])),fetch("".concat(I,"/api/cron")).then(e=>{if(!e.ok)throw Error("HTTP ".concat(e.status));return e.json()}).then(e=>{if(Array.isArray(e))v(e);else if(e&&"object"==typeof e&&"crons"in e){var t;v(null!=(t=e.crons)?t:[])}}).catch(()=>v([])))},[n]),(0,i.useEffect)(()=>{n&&requestAnimationFrame(()=>{var e;return null==(e=y.current)?void 0:e.focus()})},[n]),(0,i.useEffect)(()=>(n?document.body.style.overflow="hidden":document.body.style.overflow="",()=>{document.body.style.overflow=""}),[n]);let k=(0,i.useMemo)(()=>{let e=[...R];return(h.forEach(t=>{e.push({id:"emp-".concat(t.id),label:t.name,subtitle:t.title,icon:(0,r.jsx)(g.A,{size:16}),href:"/org",category:"Employees"})}),m.forEach(t=>{e.push({id:"cron-".concat(t.id),label:t.name,subtitle:t.schedule,icon:(0,r.jsx)(f.A,{size:16}),href:"/cron",category:"Cron Jobs"})}),o.trim())?e.filter(e=>W(o,e.label)||e.subtitle&&W(o,e.subtitle)):e},[o,h,m]),w=(0,i.useMemo)(()=>{let e=[];for(let t of["Pages","Employees","Cron Jobs"]){let a=k.filter(e=>e.category===t);a.length>0&&e.push({category:t,items:a})}return e},[k]),S=(0,i.useMemo)(()=>w.flatMap(e=>e.items),[w]),C=(0,i.useCallback)(e=>{l(!1),j.push(e.href)},[j]),N=(0,i.useCallback)(e=>{if("Escape"===e.key){e.preventDefault(),l(!1);return}if("ArrowDown"===e.key){e.preventDefault(),u(e=>Math.min(e+1,S.length-1));return}if("ArrowUp"===e.key){e.preventDefault(),u(e=>Math.max(e-1,0));return}if("Enter"===e.key){e.preventDefault(),S[p]&&C(S[p]);return}},[p,S,C]);if((0,i.useEffect)(()=>{u(0)},[o]),(0,i.useEffect)(()=>{if(!b.current)return;let e=b.current.querySelector('[data-active="true"]');e&&e.scrollIntoView({block:"nearest"})},[p]),!n)return null;let z=0;return(0,r.jsxs)("div",{style:{position:"fixed",inset:0,zIndex:100,display:"flex",alignItems:"flex-start",justifyContent:"center",paddingTop:"20vh"},children:[(0,r.jsx)("div",{style:{position:"absolute",inset:0,background:"rgba(0,0,0,0.5)",backdropFilter:"blur(4px)",WebkitBackdropFilter:"blur(4px)"},onClick:()=>l(!1),"aria-hidden":"true"}),(0,r.jsxs)("div",{role:"dialog","aria-modal":"true","aria-label":"Search ".concat(a),className:"animate-scale-in",onKeyDown:N,style:{position:"relative",width:"100%",maxWidth:560,margin:"0 16px",borderRadius:"var(--radius-xl)",background:"var(--bg-secondary)",border:"1px solid var(--separator)",boxShadow:"var(--shadow-overlay)",overflow:"hidden",display:"flex",flexDirection:"column",maxHeight:480},children:[(0,r.jsxs)("div",{style:{display:"flex",alignItems:"center",gap:10,padding:"14px 16px",borderBottom:"1px solid var(--separator)"},children:[(0,r.jsx)(E.A,{size:18,style:{color:"var(--text-tertiary)",flexShrink:0},"aria-hidden":"true"}),(0,r.jsx)("input",{ref:y,type:"text",value:o,onChange:e=>s(e.target.value),placeholder:"Search ".concat(a,"..."),"aria-label":"Search ".concat(a),style:{flex:1,background:"transparent",border:"none",outline:"none",fontSize:15,color:"var(--text-primary)",fontFamily:"inherit"}}),(0,r.jsx)("kbd",{style:{fontSize:11,fontFamily:"var(--font-mono)",padding:"2px 6px",borderRadius:4,background:"var(--fill-quaternary)",color:"var(--text-quaternary)",border:"1px solid var(--separator)",lineHeight:"16px"},children:"esc"})]}),(0,r.jsxs)("div",{ref:b,role:"listbox","aria-label":"Search results",style:{flex:1,overflowY:"auto",padding:8},children:[0===S.length&&o.trim()&&(0,r.jsxs)("div",{style:{padding:"24px 16px",textAlign:"center",color:"var(--text-tertiary)",fontSize:13},children:["No results for “",o,"”"]}),w.map(e=>(0,r.jsxs)("div",{style:{marginBottom:4},children:[(0,r.jsx)("div",{style:{fontSize:11,fontWeight:600,letterSpacing:"0.06em",textTransform:"uppercase",color:"var(--text-tertiary)",padding:"6px 8px 4px"},children:e.category}),e.items.map(e=>{let t=z++,a=t===p;return(0,r.jsxs)("button",{role:"option","aria-selected":a,"data-active":a,onClick:()=>C(e),onMouseEnter:()=>u(t),style:{display:"flex",alignItems:"center",gap:10,width:"100%",minHeight:40,padding:"8px 10px",borderRadius:"var(--radius-sm)",border:"none",background:a?"var(--accent-fill)":"transparent",cursor:"pointer",textAlign:"left",transition:"background 80ms var(--ease-smooth)",outline:"none",color:"var(--text-primary)",fontFamily:"inherit",fontSize:13},children:[(0,r.jsx)("span",{style:{width:28,height:28,display:"flex",alignItems:"center",justifyContent:"center",borderRadius:6,background:"var(--fill-quaternary)",flexShrink:0,color:"var(--text-secondary)"},children:e.icon}),(0,r.jsxs)("div",{style:{flex:1,minWidth:0},children:[(0,r.jsx)("div",{style:{fontWeight:500,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:e.label}),e.subtitle&&(0,r.jsx)("div",{style:{fontSize:11,color:"var(--text-tertiary)",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:e.subtitle})]})]},e.id)})]},e.category))]}),(0,r.jsxs)("div",{style:{display:"flex",alignItems:"center",justifyContent:"center",gap:16,padding:"8px 16px",borderTop:"1px solid var(--separator)",fontSize:11,color:"var(--text-quaternary)"},children:[(0,r.jsxs)("span",{children:[(0,r.jsx)("kbd",{style:{fontFamily:"var(--font-mono)"},children:"↑↓"})," Navigate"]}),(0,r.jsxs)("span",{children:[(0,r.jsx)("kbd",{style:{fontFamily:"var(--font-mono)"},children:"↵"})," Open"]}),(0,r.jsxs)("span",{children:[(0,r.jsx)("kbd",{style:{fontFamily:"var(--font-mono)"},children:"esc"})," Close"]})]})]})]})}var B=a(6650),D=a(4640),P=a(1061),F=a(3176),L=a(4263),T=a(5310);let H="open-live-stream",J={info:{bg:"rgba(48,209,88,0.12)",color:"var(--system-green)",label:"INF"},warn:{bg:"rgba(255,159,10,0.12)",color:"var(--system-orange)",label:"WRN"},error:{bg:"rgba(255,69,58,0.12)",color:"var(--system-red)",label:"ERR"},debug:{bg:"var(--fill-secondary)",color:"var(--text-tertiary)",label:"DBG"}};function M(e){return"[".concat(e.timestamp,"] [").concat(e.level.toUpperCase(),"] ").concat(e.message)}function q(e){var t;let{entry:a}=e,[n,l]=(0,i.useState)(!1),o=null!=(t=J[a.level])?t:J.debug,s=a.message.length>100;return(0,r.jsxs)("div",{style:{borderBottom:"1px solid var(--separator)",background:"error"===a.level?"rgba(255,69,58,0.03)":void 0},children:[(0,r.jsxs)("button",{onClick:()=>s&&l(e=>!e),style:{display:"flex",alignItems:"center",width:"100%",padding:"5px 12px",gap:8,border:"none",background:"transparent",cursor:s?"pointer":"default",textAlign:"left"},children:[s?(0,r.jsx)("span",{style:{fontSize:10,color:"var(--text-tertiary)",flexShrink:0,transition:"transform 150ms var(--ease-smooth)",transform:n?"rotate(90deg)":"rotate(0deg)",display:"inline-block"},children:"›"}):(0,r.jsx)("span",{style:{width:10,flexShrink:0}}),(0,r.jsx)("span",{className:"font-mono",style:{color:"var(--text-tertiary)",fontSize:10,flexShrink:0,minWidth:58},children:function(e){if(!e)return"";let t=e.split(" ");return t.length>1?t[1]:e}(a.timestamp)}),(0,r.jsx)("span",{style:{fontSize:9,fontWeight:700,letterSpacing:"0.5px",padding:"1px 5px",borderRadius:3,background:o.bg,color:o.color,flexShrink:0,lineHeight:"14px"},children:o.label}),(0,r.jsx)("span",{className:"font-mono",style:{color:"error"===a.level?"var(--system-red)":"var(--text-secondary)",fontSize:10,lineHeight:1.4,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap",flex:1,minWidth:0},children:a.message})]}),n&&s&&(0,r.jsx)("div",{style:{padding:"6px 12px 8px 30px",borderTop:"1px solid var(--separator)",background:"var(--fill-secondary)"},children:(0,r.jsx)("pre",{className:"font-mono",style:{fontSize:9,lineHeight:1.5,color:"var(--text-secondary)",whiteSpace:"pre-wrap",wordBreak:"break-word",margin:0},children:a.message})})]})}function K(){let[e,t]=(0,i.useState)("hidden"),[a,n]=(0,i.useState)([]),[l,o]=(0,i.useState)(!0),[s,c]=(0,i.useState)(!1),[d,p]=(0,i.useState)(null),u=(0,i.useRef)(null),{events:h}=(0,L.G)();(0,i.useEffect)(()=>{l&&u.current&&(u.current.scrollTop=u.current.scrollHeight)},[a,l]);let g=(0,i.useCallback)(()=>{if(!u.current)return;let{scrollTop:e,scrollHeight:t,clientHeight:a}=u.current;t-e-a<40?o(!0):o(!1)},[]);(0,i.useEffect)(()=>{"expanded"===e&&F.F.getLogs(50).then(e=>{var t;n((null!=(t=e.lines)?t:[]).map(T.w)),p(null)}).catch(e=>{p(e instanceof Error?e.message:"Failed to load logs")})},[e]),(0,i.useEffect)(()=>{if("hidden"===e||0===h.length)return;let t=h[h.length-1];if("log"===t.event&&"object"==typeof t.payload&&null!==t.payload){let e=t.payload,a=e.line||e.message||JSON.stringify(t.payload),r=(0,T.w)(a,Date.now());n(e=>[...e,r].slice(-500))}},[h,e]);let x=(0,i.useCallback)(()=>{t("hidden")},[]),f=(0,i.useCallback)(async()=>{let e=a.map(M).join("\n");await navigator.clipboard.writeText(e),c(!0),setTimeout(()=>c(!1),1500)},[a]);return((0,i.useEffect)(()=>{function e(){t("expanded")}return window.addEventListener(H,e),()=>window.removeEventListener(H,e)},[]),"hidden"===e)?null:"collapsed"===e?(0,r.jsxs)("button",{onClick:()=>t("expanded"),className:"focus-ring flex items-center",style:{position:"fixed",bottom:20,right:20,zIndex:50,padding:"8px 14px",borderRadius:"var(--radius-pill)",border:"1px solid var(--separator)",background:"var(--material-regular)",backdropFilter:"blur(40px) saturate(180%)",WebkitBackdropFilter:"blur(40px) saturate(180%)",cursor:"pointer",gap:8,boxShadow:"0 4px 24px rgba(0,0,0,0.25)"},children:[(0,r.jsx)("span",{style:{width:8,height:8,borderRadius:"50%",background:"var(--system-green)",animation:"lsw-pulse 2s ease-in-out infinite",flexShrink:0}}),(0,r.jsx)("span",{style:{fontSize:"var(--text-caption1)",color:"var(--text-secondary)",fontWeight:"var(--weight-medium)"},children:"Live Stream"}),a.length>0&&(0,r.jsx)("span",{style:{fontSize:"var(--text-caption2)",color:"var(--text-tertiary)",background:"var(--fill-secondary)",padding:"1px 6px",borderRadius:"var(--radius-sm)"},children:a.length}),(0,r.jsx)("style",{children:"@keyframes lsw-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }"})]}):(0,r.jsxs)("div",{className:"panel-slide-in",style:{position:"fixed",bottom:20,right:20,zIndex:50,width:440,height:400,borderRadius:"var(--radius-lg)",border:"1px solid var(--separator)",background:"var(--material-regular)",backdropFilter:"blur(40px) saturate(180%)",WebkitBackdropFilter:"blur(40px) saturate(180%)",boxShadow:"0 8px 40px rgba(0,0,0,0.35)",display:"flex",flexDirection:"column",overflow:"hidden"},children:[(0,r.jsxs)("div",{className:"flex items-center flex-shrink-0",style:{padding:"10px 14px",borderBottom:"1px solid var(--separator)",gap:8},children:[(0,r.jsx)("span",{style:{width:8,height:8,borderRadius:"50%",background:"var(--system-green)",animation:"lsw-pulse 2s ease-in-out infinite",flexShrink:0}}),(0,r.jsx)("span",{style:{fontSize:"var(--text-footnote)",fontWeight:"var(--weight-semibold)",color:"var(--text-primary)"},children:"Live Stream"}),a.length>0&&(0,r.jsxs)("span",{style:{fontSize:"var(--text-caption2)",color:"var(--text-tertiary)"},children:[a.length," line",1!==a.length?"s":""]}),(0,r.jsxs)("div",{style:{marginLeft:"auto",display:"flex",gap:4},children:[(0,r.jsx)("button",{onClick:f,className:"focus-ring",title:"Copy all logs",disabled:0===a.length,style:{width:28,height:28,display:"flex",alignItems:"center",justifyContent:"center",borderRadius:"var(--radius-sm)",border:"none",background:s?"var(--accent-fill)":"transparent",color:s?"var(--accent)":"var(--text-tertiary)",cursor:0===a.length?"default":"pointer",opacity:0===a.length?.3:1,transition:"all 150ms var(--ease-smooth)"},children:(0,r.jsx)(B.A,{size:14})}),(0,r.jsx)("button",{onClick:()=>t("collapsed"),className:"focus-ring",title:"Minimize",style:{width:28,height:28,display:"flex",alignItems:"center",justifyContent:"center",borderRadius:"var(--radius-sm)",border:"none",background:"transparent",color:"var(--text-tertiary)",cursor:"pointer",transition:"color 150ms var(--ease-smooth)"},children:(0,r.jsx)(D.A,{size:14})}),(0,r.jsx)("button",{onClick:x,className:"focus-ring",title:"Close",style:{width:28,height:28,display:"flex",alignItems:"center",justifyContent:"center",borderRadius:"var(--radius-sm)",border:"none",background:"transparent",color:"var(--text-tertiary)",cursor:"pointer",transition:"color 150ms var(--ease-smooth)"},children:(0,r.jsx)(P.A,{size:14})})]})]}),d&&(0,r.jsx)("div",{style:{padding:"6px 14px",background:"rgba(255,69,58,0.06)",borderBottom:"1px solid rgba(255,69,58,0.15)",fontSize:"var(--text-caption2)",color:"var(--system-red)",flexShrink:0},children:d}),(0,r.jsx)("div",{ref:u,onScroll:g,style:{flex:1,minHeight:0,overflowY:"auto",overflowX:"hidden"},children:0===a.length?(0,r.jsxs)("div",{className:"flex flex-col items-center justify-center",style:{height:"100%",color:"var(--text-secondary)",gap:"var(--space-2)",padding:"var(--space-4)"},children:[(0,r.jsx)("svg",{width:"28",height:"28",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round",style:{color:"var(--text-tertiary)"},children:(0,r.jsx)("polyline",{points:"22 12 18 12 15 21 9 3 6 12 2 12"})}),(0,r.jsx)("span",{style:{fontSize:"var(--text-caption1)",fontWeight:"var(--weight-medium)"},children:"Waiting for log data..."})]}):(0,r.jsx)("div",{children:a.map(e=>(0,r.jsx)(q,{entry:e},e.id))})}),(0,r.jsx)("div",{className:"flex items-center flex-shrink-0",style:{padding:"8px 14px",borderTop:"1px solid var(--separator)",gap:8},children:!l&&a.length>0&&(0,r.jsx)("button",{onClick:()=>o(!0),className:"focus-ring",style:{padding:"4px 10px",borderRadius:"var(--radius-sm)",border:"none",cursor:"pointer",fontSize:"var(--text-caption2)",fontWeight:"var(--weight-medium)",background:"var(--fill-secondary)",color:"var(--text-secondary)"},children:"Scroll to bottom"})}),(0,r.jsx)("style",{children:"@keyframes lsw-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }"})]})}var G=a(4430),Y=a(1509),_=a(8146),U=a(2407),V=a(5136);let Q=[{label:"Red",value:"#EF4444"},{label:"Orange",value:"#F97316"},{label:"Amber",value:"#F59E0B"},{label:"Yellow",value:"#EAB308"},{label:"Lime",value:"#84CC16"},{label:"Green",value:"#22C55E"},{label:"Emerald",value:"#10B981"},{label:"Cyan",value:"#06B6D4"},{label:"Blue",value:"#3B82F6"},{label:"Indigo",value:"#6366F1"},{label:"Violet",value:"#8B5CF6"},{label:"Pink",value:"#EC4899"}],X=[{icon:u.A,name:"Chat",desc:"Direct conversations with any employee"},{icon:g.A,name:"Organization",desc:"Visual org chart of your AI team"},{icon:G.A,name:"Kanban",desc:"Task boards for work management"},{icon:f.A,name:"Cron",desc:"Scheduled jobs with status monitoring"},{icon:m.A,name:"Costs",desc:"Token usage and cost tracking"},{icon:v.A,name:"Activity",desc:"Real-time logs and event stream"}];function Z(e){var t;let{forceOpen:a,onClose:n}=e,{settings:l,setPortalName:o,setOperatorName:s,setAccentColor:p,setLanguage:u}=(0,d.t0)(),{theme:h,setTheme:g}=(0,S.D)(),x=(0,c.useRouter)(),[f,m]=(0,i.useState)(!1),[v,y]=(0,i.useState)(0),[b,j]=(0,i.useState)("forward"),[k,w]=(0,i.useState)(""),[N,z]=(0,i.useState)(""),[A,E]=(0,i.useState)(null!=(t=l.language)?t:"English");(0,i.useEffect)(()=>{if(a){var e,t;w(null!=(e=l.portalName)?e:""),z(null!=(t=l.operatorName)?t:""),m(!0);return}localStorage.getItem("jinn-onboarded")||m(!0)},[a]);let I=(0,i.useCallback)(()=>{0===v&&(o(k||null),s(N||null),u(A||"English")),v<3?(j("forward"),y(v+1)):(F.F.completeOnboarding({portalName:k||void 0,operatorName:N||void 0,language:A||void 0}).catch(()=>{}),a||localStorage.setItem("jinn-onboarded","true"),m(!1),null==n||n(),x.push("/chat"))},[v,k,N,a,n,o,s,x]),R=(0,i.useCallback)(()=>{v>0&&(j("back"),y(v-1))},[v]);return f?(0,r.jsx)("div",{style:{position:"fixed",inset:0,zIndex:50,display:"flex",alignItems:"center",justifyContent:"center",background:"rgba(0,0,0,0.6)",backdropFilter:"blur(12px)",WebkitBackdropFilter:"blur(12px)"},children:(0,r.jsxs)("div",{className:"animate-fade-in",style:{width:"100%",maxWidth:520,margin:"0 var(--space-4)",background:"var(--material-regular)",borderRadius:"var(--radius-lg)",border:"1px solid var(--separator)",boxShadow:"0 24px 48px rgba(0,0,0,0.3)",overflow:"hidden",display:"flex",flexDirection:"column",maxHeight:"90vh"},children:[(0,r.jsx)("div",{style:{display:"flex",justifyContent:"center",gap:8,padding:"var(--space-4) var(--space-4) 0"},children:Array.from({length:4}).map((e,t)=>(0,r.jsx)("div",{style:{width:t===v?24:8,height:8,borderRadius:4,background:t===v||t<v?"var(--accent)":"var(--fill-tertiary)",opacity:t<v?.5:1,transition:"all 200ms var(--ease-smooth)"}},t))}),(0,r.jsxs)("div",{style:{padding:"var(--space-5) var(--space-5) var(--space-4)",overflowY:"auto",flex:1},children:[0===v&&(0,r.jsxs)("div",{className:"animate-fade-in",style:{textAlign:"center"},children:[(0,r.jsx)("div",{style:{fontSize:56,marginBottom:"var(--space-3)",lineHeight:1},children:"\ud83e\udd16"}),(0,r.jsxs)("h2",{style:{fontSize:"var(--text-large-title)",fontWeight:"var(--weight-bold)",letterSpacing:"var(--tracking-tight)",color:"var(--text-primary)",marginBottom:"var(--space-2)"},children:["Welcome to ",k||"Jinn"]}),(0,r.jsx)("p",{style:{fontSize:"var(--text-body)",color:"var(--text-secondary)",lineHeight:"var(--leading-relaxed)",maxWidth:400,margin:"0 auto var(--space-5)"},children:"Your AI team management portal. Let's get you set up."}),(0,r.jsxs)("div",{style:{display:"flex",flexDirection:"column",gap:"var(--space-3)",textAlign:"left"},children:[(0,r.jsxs)("div",{children:[(0,r.jsx)("label",{style:{display:"block",fontSize:"var(--text-caption1)",color:"var(--text-tertiary)",marginBottom:"var(--space-1)"},children:"Portal Name"}),(0,r.jsx)("input",{type:"text",className:"apple-input",placeholder:"Jinn",value:k,onChange:e=>w(e.target.value),autoFocus:!0,style:{width:"100%",background:"var(--bg-secondary)",border:"1px solid var(--separator)",borderRadius:"var(--radius-sm)",padding:"8px 12px",fontSize:"var(--text-body)",color:"var(--text-primary)"}})]}),(0,r.jsxs)("div",{children:[(0,r.jsx)("label",{style:{display:"block",fontSize:"var(--text-caption1)",color:"var(--text-tertiary)",marginBottom:"var(--space-1)"},children:"What should we call you?"}),(0,r.jsx)("input",{type:"text",className:"apple-input",placeholder:"Your Name",value:N,onChange:e=>z(e.target.value),style:{width:"100%",background:"var(--bg-secondary)",border:"1px solid var(--separator)",borderRadius:"var(--radius-sm)",padding:"8px 12px",fontSize:"var(--text-body)",color:"var(--text-primary)"}})]}),(0,r.jsxs)("div",{children:[(0,r.jsx)("label",{style:{display:"block",fontSize:"var(--text-caption1)",color:"var(--text-tertiary)",marginBottom:"var(--space-1)"},children:"Preferred Language"}),(0,r.jsxs)("select",{value:A,onChange:e=>E(e.target.value),style:{width:"100%",background:"var(--bg-secondary)",border:"1px solid var(--separator)",borderRadius:"var(--radius-sm)",padding:"8px 12px",fontSize:"var(--text-body)",color:"var(--text-primary)",cursor:"pointer"},children:[(0,r.jsx)("option",{value:"English",children:"English"}),(0,r.jsx)("option",{value:"Spanish",children:"Spanish"}),(0,r.jsx)("option",{value:"French",children:"French"}),(0,r.jsx)("option",{value:"German",children:"German"}),(0,r.jsx)("option",{value:"Portuguese",children:"Portuguese"}),(0,r.jsx)("option",{value:"Italian",children:"Italian"}),(0,r.jsx)("option",{value:"Dutch",children:"Dutch"}),(0,r.jsx)("option",{value:"Russian",children:"Russian"}),(0,r.jsx)("option",{value:"Chinese",children:"Chinese"}),(0,r.jsx)("option",{value:"Japanese",children:"Japanese"}),(0,r.jsx)("option",{value:"Korean",children:"Korean"}),(0,r.jsx)("option",{value:"Arabic",children:"Arabic"}),(0,r.jsx)("option",{value:"Hindi",children:"Hindi"}),(0,r.jsx)("option",{value:"Bulgarian",children:"Bulgarian"})]})]})]})]},"step-0"),1===v&&(0,r.jsxs)("div",{className:"animate-fade-in",children:[(0,r.jsx)("h2",{style:{fontSize:"var(--text-title1)",fontWeight:"var(--weight-bold)",letterSpacing:"var(--tracking-tight)",color:"var(--text-primary)",marginBottom:"var(--space-1)"},children:"Choose your theme"}),(0,r.jsx)("p",{style:{fontSize:"var(--text-subheadline)",color:"var(--text-tertiary)",marginBottom:"var(--space-4)"},children:"Pick the look that suits you. This applies live."}),(0,r.jsx)("div",{style:{display:"grid",gridTemplateColumns:"repeat(auto-fill, minmax(130px, 1fr))",gap:"var(--space-3)"},children:C.z.map(e=>{let t=h===e.id;return(0,r.jsxs)("button",{onClick:()=>g(e.id),style:{display:"flex",flexDirection:"column",alignItems:"center",gap:"var(--space-2)",padding:"var(--space-4) var(--space-3)",borderRadius:"var(--radius-md)",background:"var(--fill-quaternary)",border:t?"2px solid var(--accent)":"2px solid var(--separator)",cursor:"pointer",transition:"all 150ms var(--ease-smooth)"},children:[(0,r.jsx)("span",{style:{fontSize:28},children:e.emoji}),(0,r.jsx)("span",{style:{fontSize:"var(--text-footnote)",fontWeight:t?"var(--weight-semibold)":"var(--weight-medium)",color:t?"var(--accent)":"var(--text-secondary)"},children:e.label})]},e.id)})})]},"step-1"),2===v&&(0,r.jsxs)("div",{className:"animate-fade-in",children:[(0,r.jsx)("h2",{style:{fontSize:"var(--text-title1)",fontWeight:"var(--weight-bold)",letterSpacing:"var(--tracking-tight)",color:"var(--text-primary)",marginBottom:"var(--space-1)"},children:"Pick an accent color"}),(0,r.jsx)("p",{style:{fontSize:"var(--text-subheadline)",color:"var(--text-tertiary)",marginBottom:"var(--space-4)"},children:"Personalize with your favorite color."}),(0,r.jsx)("div",{style:{display:"grid",gridTemplateColumns:"repeat(6, 1fr)",gap:"var(--space-3)",justifyItems:"center"},children:Q.map(e=>{let t=l.accentColor===e.value;return(0,r.jsx)("button",{onClick:()=>p(e.value),"aria-label":e.label,title:e.label,style:{width:40,height:40,borderRadius:"50%",background:e.value,border:"none",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",outline:t?"3px solid ".concat(e.value):"none",outlineOffset:3,transition:"all 100ms var(--ease-smooth)"},children:t&&(0,r.jsx)(Y.A,{size:18,color:"#fff",strokeWidth:3})},e.value)})})]},"step-2"),3===v&&(0,r.jsxs)("div",{className:"animate-fade-in",children:[(0,r.jsx)("h2",{style:{fontSize:"var(--text-title1)",fontWeight:"var(--weight-bold)",letterSpacing:"var(--tracking-tight)",color:"var(--text-primary)",marginBottom:"var(--space-1)"},children:"You're all set!"}),(0,r.jsx)("p",{style:{fontSize:"var(--text-subheadline)",color:"var(--text-tertiary)",marginBottom:"var(--space-4)"},children:"Here's what you can do."}),(0,r.jsx)("div",{style:{display:"flex",flexDirection:"column",gap:"var(--space-2)"},children:X.map(e=>{let t=e.icon;return(0,r.jsxs)("div",{style:{display:"flex",alignItems:"center",gap:"var(--space-3)",padding:"var(--space-3)",borderRadius:"var(--radius-md)",background:"var(--fill-quaternary)",border:"1px solid var(--separator)"},children:[(0,r.jsx)("div",{style:{width:36,height:36,borderRadius:8,background:"var(--accent-fill)",display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0},children:(0,r.jsx)(t,{size:18,style:{color:"var(--accent)"}})}),(0,r.jsxs)("div",{style:{minWidth:0},children:[(0,r.jsx)("div",{style:{fontSize:"var(--text-subheadline)",fontWeight:"var(--weight-semibold)",color:"var(--text-primary)"},children:e.name}),(0,r.jsx)("div",{style:{fontSize:"var(--text-caption1)",color:"var(--text-tertiary)"},children:e.desc})]})]},e.name)})})]},"step-3")]}),(0,r.jsxs)("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",padding:"var(--space-3) var(--space-5) var(--space-5)",gap:"var(--space-3)"},children:[v>0?(0,r.jsxs)("button",{onClick:R,style:{padding:"var(--space-2) var(--space-4)",borderRadius:"var(--radius-md)",background:"var(--fill-tertiary)",color:"var(--text-secondary)",border:"none",cursor:"pointer",fontSize:"var(--text-subheadline)",fontWeight:"var(--weight-medium)",transition:"all 150ms var(--ease-smooth)",display:"inline-flex",alignItems:"center",gap:6},children:[(0,r.jsx)(_.A,{size:16}),"Back"]}):(0,r.jsx)("div",{}),(0,r.jsxs)("button",{onClick:I,style:{padding:"var(--space-2) var(--space-6)",borderRadius:"var(--radius-md)",background:"var(--accent)",color:"var(--accent-contrast)",border:"none",cursor:"pointer",fontSize:"var(--text-subheadline)",fontWeight:"var(--weight-semibold)",transition:"all 150ms var(--ease-smooth)",display:"inline-flex",alignItems:"center",gap:6},children:[0===v?"Next":3===v?"Get Started":"Next",3===v?(0,r.jsx)(U.A,{size:16}):(0,r.jsx)(V.A,{size:16})]})]})]})}):null}var $=a(7836);let ee=[{href:"/",label:"Home",icon:p.A},{href:"/chat",label:"Chat",icon:u.A},{href:"/sessions",label:"Sessions",icon:h.A},{href:"/org",label:"Organization",icon:g.A},{href:"/kanban",label:"Kanban",icon:x.A},{href:"/cron",label:"Cron",icon:f.A},{href:"/costs",label:"Costs",icon:m.A},{href:"/logs",label:"Activity",icon:v.A},{href:"/skills",label:"Skills",icon:y.A},{href:"/settings",label:"Settings",icon:b.A}];function et(){var e,t;let[a,n]=(0,i.useState)(!1),o=(0,c.usePathname)(),{settings:p}=(0,d.t0)(),u=null!=(e=p.portalEmoji)?e:"\uD83E\uDD16",h=null!=(t=p.portalName)?t:"Jinn";return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsxs)("div",{style:{height:48,display:"flex",alignItems:"center",padding:"0 12px",borderBottom:"1px solid var(--separator)",background:"var(--material-thick)",flexShrink:0,position:"relative",zIndex:60},className:"jsx-906cbf20b7aa1777 lg:hidden",children:[(0,r.jsx)("button",{onClick:()=>n(!0),"aria-label":"Open menu",style:{width:36,height:36,display:"flex",alignItems:"center",justifyContent:"center",background:"transparent",border:"none",cursor:"pointer",color:"var(--text-primary)"},className:"jsx-906cbf20b7aa1777",children:(0,r.jsx)($.A,{size:20})}),(0,r.jsxs)("div",{style:{flex:1,textAlign:"center"},className:"jsx-906cbf20b7aa1777",children:[(0,r.jsx)("span",{style:{fontSize:18,marginRight:6},className:"jsx-906cbf20b7aa1777",children:u}),(0,r.jsx)("span",{style:{fontSize:15,fontWeight:600,color:"var(--text-primary)"},className:"jsx-906cbf20b7aa1777",children:h})]}),(0,r.jsx)("div",{style:{width:36},className:"jsx-906cbf20b7aa1777"})]}),a&&(0,r.jsxs)("div",{style:{position:"fixed",inset:0,zIndex:100},className:"jsx-906cbf20b7aa1777 lg:hidden",children:[(0,r.jsx)("div",{style:{position:"absolute",inset:0,background:"rgba(0,0,0,0.5)"},onClick:()=>n(!1),className:"jsx-906cbf20b7aa1777"}),(0,r.jsxs)("nav",{style:{position:"absolute",top:0,left:0,bottom:0,width:260,background:"var(--bg-secondary)",borderRight:"1px solid var(--separator)",display:"flex",flexDirection:"column",animation:"slideInLeft 200ms ease"},className:"jsx-906cbf20b7aa1777",children:[(0,r.jsxs)("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",padding:"12px 14px",borderBottom:"1px solid var(--separator)"},className:"jsx-906cbf20b7aa1777",children:[(0,r.jsxs)("div",{style:{display:"flex",alignItems:"center",gap:8},className:"jsx-906cbf20b7aa1777",children:[(0,r.jsx)("span",{style:{fontSize:22},className:"jsx-906cbf20b7aa1777",children:u}),(0,r.jsx)("span",{style:{fontSize:16,fontWeight:600,color:"var(--text-primary)"},className:"jsx-906cbf20b7aa1777",children:h})]}),(0,r.jsx)("button",{onClick:()=>n(!1),"aria-label":"Close menu",style:{width:32,height:32,display:"flex",alignItems:"center",justifyContent:"center",background:"transparent",border:"none",cursor:"pointer",color:"var(--text-secondary)"},className:"jsx-906cbf20b7aa1777",children:(0,r.jsx)(P.A,{size:18})})]}),(0,r.jsx)("div",{style:{flex:1,padding:"8px",display:"flex",flexDirection:"column",gap:2},className:"jsx-906cbf20b7aa1777",children:ee.map(e=>{let t="/"===e.href?"/"===o:o.startsWith(e.href),a=e.icon;return(0,r.jsxs)(s(),{href:e.href,onClick:()=>n(!1),style:{display:"flex",alignItems:"center",gap:12,height:44,padding:"0 14px",borderRadius:10,textDecoration:"none",color:t?"var(--accent)":"var(--text-secondary)",background:t?"var(--accent-fill)":"transparent",fontWeight:t?600:400,fontSize:15},children:[(0,r.jsx)(a,{size:18,style:{flexShrink:0},className:"jsx-906cbf20b7aa1777"}),e.label]},e.href)})})]})]}),(0,r.jsx)(l(),{id:"906cbf20b7aa1777",children:"@keyframes slideInLeft{from{transform:translatex(-100%)}to{transform:translatex(0)}}"})]})}function ea(e){let{children:t}=e;return(0,r.jsxs)("div",{className:"flex h-screen overflow-hidden",style:{background:"var(--bg)"},children:[(0,r.jsx)(A,{}),(0,r.jsx)(O,{}),(0,r.jsxs)("main",{className:"flex-1 overflow-hidden lg:ml-[56px]",children:[(0,r.jsx)(et,{}),t]}),(0,r.jsx)(K,{}),(0,r.jsx)(Z,{})]})}},3176:(e,t,a)=>{a.d(t,{F:()=>s});let r=window.location.origin;async function n(e){let t=await fetch("".concat(r).concat(e));if(!t.ok)throw Error("API error: ".concat(t.status));return t.json()}async function l(e,t){let a=await fetch("".concat(r).concat(e),{method:"POST",headers:{"Content-Type":"application/json"},body:t?JSON.stringify(t):void 0});if(!a.ok)throw Error("API error: ".concat(a.status));return a.json()}async function i(e){let t=await fetch("".concat(r).concat(e),{method:"DELETE"});if(!t.ok)throw Error("API error: ".concat(t.status));return t.json()}async function o(e,t){let a=await fetch("".concat(r).concat(e),{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(t)});if(!a.ok)throw Error("API error: ".concat(a.status));return a.json()}let s={getStatus:()=>n("/api/status"),getSessions:()=>n("/api/sessions"),getSession:e=>n("/api/sessions/".concat(e)),getSessionChildren:e=>n("/api/sessions/".concat(e,"/children")),deleteSession:e=>i("/api/sessions/".concat(e)),createSession:e=>l("/api/sessions",e),createStubSession:e=>l("/api/sessions/stub",e),sendMessage:(e,t)=>l("/api/sessions/".concat(e,"/message"),t),getCronJobs:()=>n("/api/cron"),getCronRuns:e=>n("/api/cron/".concat(e,"/runs")),updateCronJob:(e,t)=>o("/api/cron/".concat(e),t),getOrg:()=>n("/api/org"),getEmployee:e=>n("/api/org/employees/".concat(e)),getDepartmentBoard:e=>n("/api/org/departments/".concat(e,"/board")),getSkills:()=>n("/api/skills"),getSkill:e=>n("/api/skills/".concat(e)),getConfig:()=>n("/api/config"),updateConfig:e=>o("/api/config",e),getLogs:e=>n("/api/logs".concat(e?"?n=".concat(e):"")),getOnboarding:()=>n("/api/onboarding"),completeOnboarding:e=>l("/api/onboarding",e),getActivity:()=>n("/api/activity"),updateDepartmentBoard:(e,t)=>o("/api/org/departments/".concat(e,"/board"),t)}},4263:(e,t,a)=>{a.d(t,{G:()=>o});var r=a(5271),n=a(1298),l=a(2755);function i(e,t){"Notification"in window&&"granted"===Notification.permission&&document.hidden&&new Notification(e,{body:t,icon:"/favicon.ico",tag:"jinn-session"})}function o(){var e;let{settings:t}=(0,l.t0)(),a=null!=(e=t.portalName)?e:"Jinn",[o,s]=(0,r.useState)([]),[c,d]=(0,r.useState)(!1),[p,u]=(0,r.useState)(0),[h,g]=(0,r.useState)(0),x=(0,r.useRef)(!1),f=(0,r.useRef)(a);return f.current=a,(0,r.useEffect)(()=>{!x.current&&(x.current=!0,"Notification"in window&&"default"===Notification.permission&&Notification.requestPermission());let e=(0,n.E)((e,t)=>{if(s(a=>[...a.slice(-99),{event:e,payload:t}]),"skills:changed"===e&&g(e=>e+1),"session:completed"===e){let e=t.employee||f.current,a=t.error;a?i("".concat(e," - Error"),a.slice(0,100)):i("".concat(e," - Done"),"Session completed successfully")}},{onOpen:()=>{d(!0),u(e=>e+1)},onClose:()=>{d(!1)}});return()=>e.close()},[]),{events:o,connected:c,connectionSeq:p,skillsVersion:h}}},5310:(e,t,a)=>{a.d(t,{b:()=>c,w:()=>s});var r=a(8111),n=a(5271);let l={info:"var(--system-green)",warn:"var(--system-orange)",error:"var(--system-red)",debug:"var(--text-tertiary)"},i={info:"rgba(48,209,88,0.12)",warn:"rgba(255,159,10,0.12)",error:"rgba(255,69,58,0.12)",debug:"var(--fill-secondary)"},o=[{key:"all",label:"All"},{key:"info",label:"Info"},{key:"warn",label:"Warn"},{key:"error",label:"Errors"}];function s(e,t){let a=e.match(/^(\d{4}-\d{2}-\d{2}\s+\d{2}:\d{2}:\d{2})\s+\[(\w+)\]\s*(.*)$/);return a?{id:"log-".concat(t),timestamp:a[1],level:a[2].toLowerCase(),message:a[3]}:{id:"log-".concat(t),timestamp:"",level:"info",message:e}}function c(e){let{lines:t}=e,[a,c]=(0,n.useState)("all"),[d,p]=(0,n.useState)(""),[u,h]=(0,n.useState)(null),g=t.map(s),x=g.filter(e=>("all"===a||e.level===a)&&(!d||!!e.message.toLowerCase().includes(d.toLowerCase()))),f={all:g.length,info:g.filter(e=>"info"===e.level).length,warn:g.filter(e=>"warn"===e.level).length,error:g.filter(e=>"error"===e.level).length};return(0,r.jsxs)("div",{children:[(0,r.jsxs)("div",{className:"flex items-center flex-wrap",style:{gap:"var(--space-2)",marginBottom:"var(--space-3)"},children:[o.map(e=>{let t=a===e.key;return(0,r.jsxs)("button",{onClick:()=>c(e.key),className:"focus-ring flex items-center flex-shrink-0",style:{borderRadius:20,padding:"6px 14px",fontSize:"var(--text-footnote)",fontWeight:"var(--weight-medium)",border:"none",cursor:"pointer",gap:"var(--space-2)",transition:"all 200ms var(--ease-smooth)",...t?{background:"var(--accent-fill)",color:"var(--accent)",boxShadow:"0 0 0 1px color-mix(in srgb, var(--accent) 40%, transparent)"}:{background:"var(--fill-secondary)",color:"var(--text-primary)"}},children:[(0,r.jsx)("span",{children:e.label}),(0,r.jsx)("span",{style:{fontWeight:"var(--weight-semibold)",color:t?"var(--accent)":"var(--text-secondary)"},children:f[e.key]})]},e.key)}),(0,r.jsx)("input",{type:"text",placeholder:"Search logs...",value:d,onChange:e=>p(e.target.value),className:"focus-ring",style:{marginLeft:"auto",padding:"6px 12px",fontSize:"var(--text-footnote)",borderRadius:"var(--radius-sm)",border:"1px solid var(--separator)",background:"var(--fill-secondary)",color:"var(--text-primary)",outline:"none",minWidth:160,maxWidth:240}})]}),0===x.length?(0,r.jsxs)("div",{className:"flex flex-col items-center justify-center",style:{height:200,color:"var(--text-secondary)",gap:"var(--space-2)"},children:[(0,r.jsx)("span",{style:{fontSize:"var(--text-subheadline)",fontWeight:"var(--weight-medium)"},children:0===g.length?"No log entries found":"No entries match this filter"}),(0,r.jsx)("span",{style:{fontSize:"var(--text-footnote)",color:"var(--text-tertiary)"},children:0===g.length?"Log entries will appear here when available":"Try adjusting your filter or search"})]}):(0,r.jsx)("div",{style:{borderRadius:"var(--radius-md)",overflow:"hidden",background:"var(--material-regular)",backdropFilter:"blur(20px)",WebkitBackdropFilter:"blur(20px)"},children:x.map((e,t)=>{var a,n;let o=u===e.id,s=null!=(a=l[e.level])?a:"var(--text-tertiary)",c=e.message.length>120;return(0,r.jsxs)("div",{children:[t>0&&(0,r.jsx)("div",{style:{height:1,background:"var(--separator)",marginLeft:"var(--space-4)",marginRight:"var(--space-4)"}}),(0,r.jsxs)("div",{role:"button",tabIndex:0,"aria-expanded":c?o:void 0,onClick:()=>c&&h(o?null:e.id),onKeyDown:t=>{c&&("Enter"===t.key||" "===t.key)&&(t.preventDefault(),h(o?null:e.id))},className:"flex items-center hover-bg focus-ring",style:{minHeight:44,padding:"0 var(--space-4)",cursor:c?"pointer":"default",background:"error"===e.level?"rgba(255,69,58,0.06)":void 0},children:[(0,r.jsx)("span",{className:"flex-shrink-0 rounded-full",style:{width:8,height:8,background:s}}),e.timestamp&&(0,r.jsx)("span",{className:"flex-shrink-0 font-mono",style:{fontSize:"var(--text-caption1)",color:"var(--text-tertiary)",marginLeft:"var(--space-3)",minWidth:130},children:e.timestamp}),(0,r.jsx)("span",{className:"flex-shrink-0",style:{fontSize:"var(--text-caption2)",fontWeight:"var(--weight-semibold)",padding:"1px 6px",borderRadius:4,background:null!=(n=i[e.level])?n:"var(--fill-secondary)",color:s,marginLeft:"var(--space-2)",letterSpacing:"0.04em",textTransform:"uppercase"},children:e.level}),(0,r.jsx)("span",{className:"truncate",style:{fontSize:"var(--text-footnote)",color:"var(--text-primary)",marginLeft:"var(--space-3)",flex:1,minWidth:0},children:c&&!o?e.message.slice(0,117)+"...":e.message}),c&&(0,r.jsx)("span",{"aria-hidden":"true",style:{fontSize:"var(--text-footnote)",color:"var(--text-tertiary)",transition:"transform 200ms var(--ease-smooth)",transform:o?"rotate(90deg)":"rotate(0deg)",display:"inline-block",marginLeft:"var(--space-2)"},children:"›"})]}),o&&c&&(0,r.jsx)("div",{className:"animate-slide-down",style:{padding:"0 var(--space-4) var(--space-4) var(--space-4)"},children:(0,r.jsx)("div",{style:{borderRadius:"var(--radius-sm)",background:"var(--fill-secondary)",padding:"var(--space-3)",marginTop:"var(--space-2)"},children:(0,r.jsx)("pre",{className:"font-mono",style:{fontSize:"var(--text-caption2)",color:"var(--text-secondary)",whiteSpace:"pre-wrap",wordBreak:"break-word",margin:0,maxHeight:300,overflow:"auto",lineHeight:"var(--leading-relaxed)"},children:e.message})})})]},e.id)})})]})}},7460:(e,t,a)=>{a.d(t,{D:()=>o,N:()=>i});var r=a(8111),n=a(5271);let l=(0,n.createContext)({theme:"dark",setTheme:()=>{}});function i(e){let{children:t}=e,[a,i]=(0,n.useState)("dark"),o=(0,n.useCallback)(e=>{i(e),localStorage.setItem("jinn-theme",e);let t=document.documentElement;if(t.removeAttribute("data-theme"),"system"===e){let e=window.matchMedia("(prefers-color-scheme: dark)").matches;t.setAttribute("data-theme",e?"dark":"light")}else t.setAttribute("data-theme",e)},[]);return(0,n.useEffect)(()=>{let e=localStorage.getItem("jinn-theme");e&&o(e)},[o]),(0,r.jsx)(l.Provider,{value:{theme:a,setTheme:o},children:t})}function o(){return(0,n.useContext)(l)}},9834:(e,t,a)=>{a.d(t,{z:()=>r});let r=[{id:"dark",label:"Dark",emoji:"\uD83C\uDF11"},{id:"glass",label:"Glass",emoji:"\uD83E\uDE9F"},{id:"color",label:"Color",emoji:"\uD83C\uDFA8"},{id:"light",label:"Light",emoji:"☀️"},{id:"system",label:"System",emoji:"⚙️"}]}}]);
|
|
1
|
+
"use strict";(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[73],{1298:(e,t,a)=>{a.d(t,{E:()=>r});function r(e,t){let a="".concat("https:"===window.location.protocol?"wss:":"ws:","//").concat(window.location.host,"/ws"),r=null,n=null,l=!1;return!function i(){l||((r=new WebSocket(a)).onopen=()=>{var e;null==t||null==(e=t.onOpen)||e.call(t)},r.onmessage=t=>{try{let a=JSON.parse(t.data);e(a.event,a.payload)}catch(e){}},r.onclose=()=>{var e;null==t||null==(e=t.onClose)||e.call(t),l||(n=setTimeout(i,3e3))},r.onerror=()=>null==r?void 0:r.close())}(),{close:()=>{l=!0,n&&clearTimeout(n),null==r||r.close()}}}},2755:(e,t,a)=>{a.d(t,{Qc:()=>u,Z6:()=>d,t0:()=>p});var r=a(8111),n=a(5271);let l={accentColor:null,portalName:null,portalSubtitle:null,portalEmoji:null,portalIcon:null,iconBgHidden:!1,emojiOnly:!1,operatorName:null,language:"English",employeeOverrides:{}},i="jinn-settings";function o(e){localStorage.setItem(i,JSON.stringify(e))}var s=a(3176);let c=(0,n.createContext)({settings:{accentColor:null,portalName:null,portalSubtitle:null,portalEmoji:null,portalIcon:null,iconBgHidden:!1,emojiOnly:!1,operatorName:null,language:"English",employeeOverrides:{}},setAccentColor:()=>{},setPortalName:()=>{},setPortalSubtitle:()=>{},setPortalEmoji:()=>{},setPortalIcon:()=>{},setIconBgHidden:()=>{},setEmojiOnly:()=>{},setOperatorName:()=>{},setLanguage:()=>{},setEmployeeOverride:()=>{},clearEmployeeOverride:()=>{},getEmployeeDisplay:e=>({emoji:e.emoji}),resetAll:()=>{}});function d(e){let{children:t}=e,[a,d]=(0,n.useState)({...l});(0,n.useEffect)(()=>{let e=function(){try{let e=localStorage.getItem(i);if(!e)return{...l};let t=JSON.parse(e);return{...l,...t}}catch(e){return{...l}}}();d(e),s.F.getOnboarding().then(t=>{if(t.portalName||t.operatorName){let a={...e,...t.portalName&&{portalName:t.portalName},...t.operatorName&&{operatorName:t.operatorName}};d(a),o(a)}}).catch(()=>{})},[]),(0,n.useEffect)(()=>{let e=document.documentElement.style;a.accentColor?(e.setProperty("--accent",a.accentColor),e.setProperty("--accent-fill",function(e){let t=parseInt(e.slice(1,3),16),a=parseInt(e.slice(3,5),16),r=parseInt(e.slice(5,7),16);return"rgba(".concat(t,",").concat(a,",").concat(r,",0.15)")}(a.accentColor)),e.setProperty("--accent-contrast",function(e){let t=parseInt(e.slice(1,3),16)/255,a=parseInt(e.slice(3,5),16)/255,r=parseInt(e.slice(5,7),16)/255,n=e=>e<=.03928?e/12.92:Math.pow((e+.055)/1.055,2.4);return .2126*n(t)+.7152*n(a)+.0722*n(r)>.4?"#000":"#fff"}(a.accentColor))):(e.removeProperty("--accent"),e.removeProperty("--accent-fill"),e.removeProperty("--accent-contrast"))},[a.accentColor]);let p=(0,n.useCallback)(e=>{d(e),o(e)},[]),u=(0,n.useCallback)(e=>{p({...a,accentColor:e})},[a,p]),h=(0,n.useCallback)(e=>{p({...a,portalName:e||null})},[a,p]),g=(0,n.useCallback)(e=>{p({...a,portalSubtitle:e||null})},[a,p]),x=(0,n.useCallback)(e=>{p({...a,portalEmoji:e||null})},[a,p]),f=(0,n.useCallback)(e=>{p({...a,portalIcon:e})},[a,p]),m=(0,n.useCallback)(e=>{p({...a,iconBgHidden:e})},[a,p]),v=(0,n.useCallback)(e=>{p({...a,emojiOnly:e})},[a,p]),y=(0,n.useCallback)(e=>{p({...a,operatorName:e||null})},[a,p]),b=(0,n.useCallback)(e=>{p({...a,language:e||"English"})},[a,p]),j=(0,n.useCallback)((e,t)=>{let r=a.employeeOverrides[e]||{};p({...a,employeeOverrides:{...a.employeeOverrides,[e]:{...r,...t}}})},[a,p]),k=(0,n.useCallback)(e=>{let{[e]:t,...r}=a.employeeOverrides;p({...a,employeeOverrides:r})},[a,p]),w=(0,n.useCallback)(e=>{let t=a.employeeOverrides[e.id];return{emoji:(null==t?void 0:t.emoji)||e.emoji,profileImage:null==t?void 0:t.profileImage,emojiOnly:a.emojiOnly}},[a.employeeOverrides,a.emojiOnly]),S=(0,n.useCallback)(()=>{p({accentColor:null,portalName:null,portalSubtitle:null,portalEmoji:null,portalIcon:null,iconBgHidden:!1,emojiOnly:!1,operatorName:null,language:"English",employeeOverrides:{}})},[p]);return(0,r.jsx)(c.Provider,{value:{settings:a,setAccentColor:u,setPortalName:h,setPortalSubtitle:g,setPortalEmoji:x,setPortalIcon:f,setIconBgHidden:m,setEmojiOnly:v,setOperatorName:y,setLanguage:b,setEmployeeOverride:j,clearEmployeeOverride:k,getEmployeeDisplay:w,resetAll:S},children:t})}let p=()=>(0,n.useContext)(c);function u(){let{settings:e}=p(),t=(0,n.useRef)(e.portalName);return t.current=e.portalName,(0,n.useEffect)(()=>{function e(){let e=t.current||"Jinn",a="".concat(e," - AI Gateway");document.title!==a&&(document.title=a)}e();let a=document.querySelector("title");if(!a)return;let r=new MutationObserver(()=>e());return r.observe(a,{childList:!0,characterData:!0,subtree:!0}),()=>r.disconnect()},[e.portalName]),null}},3073:(e,t,a)=>{a.d(t,{M:()=>ea});var r=a(8111),n=a(1251),l=a.n(n),i=a(5271),o=a(5935),s=a.n(o),c=a(4736),d=a(2755),p=a(8193),u=a(6778),h=a(7549),g=a(2265),x=a(6808),f=a(1935),m=a(6361),v=a(4514),y=a(9026),b=a(3254),j=a(5275),k=a(9006),w=a(4206),S=a(7460),C=a(9834);let N=[{href:"/",label:"Home",icon:p.A},{href:"/chat",label:"Chat",icon:u.A},{href:"/sessions",label:"Sessions",icon:h.A},{href:"/org",label:"Organization",icon:g.A},{href:"/kanban",label:"Kanban",icon:x.A},{href:"/cron",label:"Cron",icon:f.A},{href:"/costs",label:"Costs",icon:m.A},{href:"/logs",label:"Activity",icon:v.A},{href:"/skills",label:"Skills",icon:y.A},{href:"/settings",label:"Settings",icon:b.A}];function z(e){let{theme:t}=e;switch(t){case"light":return(0,r.jsx)(j.A,{size:18});case"dark":return(0,r.jsx)(k.A,{size:18});default:return(0,r.jsx)(w.A,{size:18})}}function A(){var e,t;let a=(0,c.usePathname)(),{theme:n,setTheme:l}=(0,S.D)(),{settings:o}=(0,d.t0)(),[p,u]=(0,i.useState)(!1),h=null!=(e=o.portalEmoji)?e:"\uD83E\uDD16",g=null!=(t=o.portalName)?t:"Jinn";return(0,r.jsxs)("aside",{onMouseEnter:()=>u(!0),onMouseLeave:()=>u(!1),style:{position:"fixed",left:0,top:0,bottom:0,width:p?200:56,background:"var(--bg-secondary)",borderRight:"1px solid var(--separator)",flexDirection:"column",zIndex:50,transition:"width 200ms var(--ease-smooth)",overflow:"hidden"},className:"hidden lg:flex",children:[(0,r.jsxs)("div",{style:{display:"flex",alignItems:"center",gap:10,padding:"16px 14px 12px",minHeight:56,flexShrink:0},children:[(0,r.jsx)("span",{style:{fontSize:24,lineHeight:1,flexShrink:0,width:28,textAlign:"center"},children:h}),(0,r.jsx)("span",{style:{fontSize:17,fontWeight:600,color:"var(--text-primary)",whiteSpace:"nowrap",opacity:+!!p,transition:"opacity 200ms var(--ease-smooth)"},children:g})]}),(0,r.jsx)("nav",{style:{flex:1,display:"flex",flexDirection:"column",gap:2,padding:"0 8px"},children:N.map(e=>{let t="/"===e.href?"/"===a:a.startsWith(e.href),n=e.icon;return(0,r.jsxs)(s(),{href:e.href,className:"nav-item","aria-label":e.label,"aria-current":t?"page":void 0,style:{display:"flex",alignItems:"center",gap:10,height:40,padding:"0 12px",textDecoration:"none",color:t?"var(--accent)":"var(--text-secondary)",background:t?"var(--accent-fill)":"transparent",fontWeight:t?600:400,fontSize:13,whiteSpace:"nowrap"},children:[(0,r.jsx)(n,{size:18,style:{flexShrink:0,color:t?"var(--accent)":"var(--text-secondary)"}}),(0,r.jsx)("span",{style:{opacity:+!!p,transition:"opacity 200ms var(--ease-smooth)"},children:e.label})]},e.href)})}),(0,r.jsx)("div",{style:{padding:"8px 8px 12px",flexShrink:0},children:(0,r.jsxs)("button",{onClick:function(){let e=C.z.map(e=>e.id),t=e.indexOf(n);l(e[(t+1)%e.length])},className:"nav-item","aria-label":"Theme: ".concat(n,". Click to cycle."),style:{display:"flex",alignItems:"center",gap:10,height:40,padding:"0 12px",width:"100%",border:"none",background:"transparent",color:"var(--text-secondary)",cursor:"pointer",fontSize:13,whiteSpace:"nowrap"},children:[(0,r.jsx)("span",{style:{flexShrink:0},children:(0,r.jsx)(z,{theme:n})}),(0,r.jsx)("span",{style:{opacity:+!!p,transition:"opacity 200ms var(--ease-smooth)",textTransform:"capitalize"},children:n})]})})]})}var E=a(8067);let I=window.location.origin,R=[{id:"page-home",label:"Dashboard",icon:(0,r.jsx)(p.A,{size:16}),href:"/",category:"Pages"},{id:"page-chat",label:"Chat",icon:(0,r.jsx)(u.A,{size:16}),href:"/chat",category:"Pages"},{id:"page-sessions",label:"Sessions",icon:(0,r.jsx)(h.A,{size:16}),href:"/sessions",category:"Pages"},{id:"page-org",label:"Organization",icon:(0,r.jsx)(g.A,{size:16}),href:"/org",category:"Pages"},{id:"page-kanban",label:"Kanban",icon:(0,r.jsx)(x.A,{size:16}),href:"/kanban",category:"Pages"},{id:"page-cron",label:"Cron",icon:(0,r.jsx)(f.A,{size:16}),href:"/cron",category:"Pages"},{id:"page-costs",label:"Costs",icon:(0,r.jsx)(m.A,{size:16}),href:"/costs",category:"Pages"},{id:"page-logs",label:"Activity",icon:(0,r.jsx)(v.A,{size:16}),href:"/logs",category:"Pages"},{id:"page-skills",label:"Skills",icon:(0,r.jsx)(y.A,{size:16}),href:"/skills",category:"Pages"},{id:"page-settings",label:"Settings",icon:(0,r.jsx)(b.A,{size:16}),href:"/settings",category:"Pages"}];function W(e,t){return t.toLowerCase().includes(e.toLowerCase())}function O(){var e;let{settings:t}=(0,d.t0)(),a=null!=(e=t.portalName)?e:"Jinn",[n,l]=(0,i.useState)(!1),[o,s]=(0,i.useState)(""),[p,u]=(0,i.useState)(0),[h,x]=(0,i.useState)([]),[m,v]=(0,i.useState)([]),y=(0,i.useRef)(null),b=(0,i.useRef)(null),j=(0,c.useRouter)();(0,i.useEffect)(()=>{function e(e){(e.metaKey||e.ctrlKey)&&"k"===e.key&&(e.preventDefault(),l(e=>!e))}return window.addEventListener("keydown",e),()=>window.removeEventListener("keydown",e)},[]),(0,i.useEffect)(()=>{n&&(s(""),u(0),fetch("".concat(I,"/api/org")).then(e=>{if(!e.ok)throw Error("HTTP ".concat(e.status));return e.json()}).then(e=>{if(Array.isArray(e))x(e);else if(e&&"object"==typeof e&&"employees"in e){var t;x(null!=(t=e.employees)?t:[])}}).catch(()=>x([])),fetch("".concat(I,"/api/cron")).then(e=>{if(!e.ok)throw Error("HTTP ".concat(e.status));return e.json()}).then(e=>{if(Array.isArray(e))v(e);else if(e&&"object"==typeof e&&"crons"in e){var t;v(null!=(t=e.crons)?t:[])}}).catch(()=>v([])))},[n]),(0,i.useEffect)(()=>{n&&requestAnimationFrame(()=>{var e;return null==(e=y.current)?void 0:e.focus()})},[n]),(0,i.useEffect)(()=>(n?document.body.style.overflow="hidden":document.body.style.overflow="",()=>{document.body.style.overflow=""}),[n]);let k=(0,i.useMemo)(()=>{let e=[...R];return(h.forEach(t=>{e.push({id:"emp-".concat(t.id),label:t.name,subtitle:t.title,icon:(0,r.jsx)(g.A,{size:16}),href:"/org",category:"Employees"})}),m.forEach(t=>{e.push({id:"cron-".concat(t.id),label:t.name,subtitle:t.schedule,icon:(0,r.jsx)(f.A,{size:16}),href:"/cron",category:"Cron Jobs"})}),o.trim())?e.filter(e=>W(o,e.label)||e.subtitle&&W(o,e.subtitle)):e},[o,h,m]),w=(0,i.useMemo)(()=>{let e=[];for(let t of["Pages","Employees","Cron Jobs"]){let a=k.filter(e=>e.category===t);a.length>0&&e.push({category:t,items:a})}return e},[k]),S=(0,i.useMemo)(()=>w.flatMap(e=>e.items),[w]),C=(0,i.useCallback)(e=>{l(!1),j.push(e.href)},[j]),N=(0,i.useCallback)(e=>{if("Escape"===e.key){e.preventDefault(),l(!1);return}if("ArrowDown"===e.key){e.preventDefault(),u(e=>Math.min(e+1,S.length-1));return}if("ArrowUp"===e.key){e.preventDefault(),u(e=>Math.max(e-1,0));return}if("Enter"===e.key){e.preventDefault(),S[p]&&C(S[p]);return}},[p,S,C]);if((0,i.useEffect)(()=>{u(0)},[o]),(0,i.useEffect)(()=>{if(!b.current)return;let e=b.current.querySelector('[data-active="true"]');e&&e.scrollIntoView({block:"nearest"})},[p]),!n)return null;let z=0;return(0,r.jsxs)("div",{style:{position:"fixed",inset:0,zIndex:100,display:"flex",alignItems:"flex-start",justifyContent:"center",paddingTop:"20vh"},children:[(0,r.jsx)("div",{style:{position:"absolute",inset:0,background:"rgba(0,0,0,0.5)",backdropFilter:"blur(4px)",WebkitBackdropFilter:"blur(4px)"},onClick:()=>l(!1),"aria-hidden":"true"}),(0,r.jsxs)("div",{role:"dialog","aria-modal":"true","aria-label":"Search ".concat(a),className:"animate-scale-in",onKeyDown:N,style:{position:"relative",width:"100%",maxWidth:560,margin:"0 16px",borderRadius:"var(--radius-xl)",background:"var(--bg-secondary)",border:"1px solid var(--separator)",boxShadow:"var(--shadow-overlay)",overflow:"hidden",display:"flex",flexDirection:"column",maxHeight:480},children:[(0,r.jsxs)("div",{style:{display:"flex",alignItems:"center",gap:10,padding:"14px 16px",borderBottom:"1px solid var(--separator)"},children:[(0,r.jsx)(E.A,{size:18,style:{color:"var(--text-tertiary)",flexShrink:0},"aria-hidden":"true"}),(0,r.jsx)("input",{ref:y,type:"text",value:o,onChange:e=>s(e.target.value),placeholder:"Search ".concat(a,"..."),"aria-label":"Search ".concat(a),style:{flex:1,background:"transparent",border:"none",outline:"none",fontSize:15,color:"var(--text-primary)",fontFamily:"inherit"}}),(0,r.jsx)("kbd",{style:{fontSize:11,fontFamily:"var(--font-mono)",padding:"2px 6px",borderRadius:4,background:"var(--fill-quaternary)",color:"var(--text-quaternary)",border:"1px solid var(--separator)",lineHeight:"16px"},children:"esc"})]}),(0,r.jsxs)("div",{ref:b,role:"listbox","aria-label":"Search results",style:{flex:1,overflowY:"auto",padding:8},children:[0===S.length&&o.trim()&&(0,r.jsxs)("div",{style:{padding:"24px 16px",textAlign:"center",color:"var(--text-tertiary)",fontSize:13},children:["No results for “",o,"”"]}),w.map(e=>(0,r.jsxs)("div",{style:{marginBottom:4},children:[(0,r.jsx)("div",{style:{fontSize:11,fontWeight:600,letterSpacing:"0.06em",textTransform:"uppercase",color:"var(--text-tertiary)",padding:"6px 8px 4px"},children:e.category}),e.items.map(e=>{let t=z++,a=t===p;return(0,r.jsxs)("button",{role:"option","aria-selected":a,"data-active":a,onClick:()=>C(e),onMouseEnter:()=>u(t),style:{display:"flex",alignItems:"center",gap:10,width:"100%",minHeight:40,padding:"8px 10px",borderRadius:"var(--radius-sm)",border:"none",background:a?"var(--accent-fill)":"transparent",cursor:"pointer",textAlign:"left",transition:"background 80ms var(--ease-smooth)",outline:"none",color:"var(--text-primary)",fontFamily:"inherit",fontSize:13},children:[(0,r.jsx)("span",{style:{width:28,height:28,display:"flex",alignItems:"center",justifyContent:"center",borderRadius:6,background:"var(--fill-quaternary)",flexShrink:0,color:"var(--text-secondary)"},children:e.icon}),(0,r.jsxs)("div",{style:{flex:1,minWidth:0},children:[(0,r.jsx)("div",{style:{fontWeight:500,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:e.label}),e.subtitle&&(0,r.jsx)("div",{style:{fontSize:11,color:"var(--text-tertiary)",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:e.subtitle})]})]},e.id)})]},e.category))]}),(0,r.jsxs)("div",{style:{display:"flex",alignItems:"center",justifyContent:"center",gap:16,padding:"8px 16px",borderTop:"1px solid var(--separator)",fontSize:11,color:"var(--text-quaternary)"},children:[(0,r.jsxs)("span",{children:[(0,r.jsx)("kbd",{style:{fontFamily:"var(--font-mono)"},children:"↑↓"})," Navigate"]}),(0,r.jsxs)("span",{children:[(0,r.jsx)("kbd",{style:{fontFamily:"var(--font-mono)"},children:"↵"})," Open"]}),(0,r.jsxs)("span",{children:[(0,r.jsx)("kbd",{style:{fontFamily:"var(--font-mono)"},children:"esc"})," Close"]})]})]})]})}var D=a(6650),B=a(4640),P=a(1061),T=a(3176),F=a(4263),L=a(5310);let H="open-live-stream",J={info:{bg:"rgba(48,209,88,0.12)",color:"var(--system-green)",label:"INF"},warn:{bg:"rgba(255,159,10,0.12)",color:"var(--system-orange)",label:"WRN"},error:{bg:"rgba(255,69,58,0.12)",color:"var(--system-red)",label:"ERR"},debug:{bg:"var(--fill-secondary)",color:"var(--text-tertiary)",label:"DBG"}};function M(e){return"[".concat(e.timestamp,"] [").concat(e.level.toUpperCase(),"] ").concat(e.message)}function q(e){var t;let{entry:a}=e,[n,l]=(0,i.useState)(!1),o=null!=(t=J[a.level])?t:J.debug,s=a.message.length>100;return(0,r.jsxs)("div",{style:{borderBottom:"1px solid var(--separator)",background:"error"===a.level?"rgba(255,69,58,0.03)":void 0},children:[(0,r.jsxs)("button",{onClick:()=>s&&l(e=>!e),style:{display:"flex",alignItems:"center",width:"100%",padding:"5px 12px",gap:8,border:"none",background:"transparent",cursor:s?"pointer":"default",textAlign:"left"},children:[s?(0,r.jsx)("span",{style:{fontSize:10,color:"var(--text-tertiary)",flexShrink:0,transition:"transform 150ms var(--ease-smooth)",transform:n?"rotate(90deg)":"rotate(0deg)",display:"inline-block"},children:"›"}):(0,r.jsx)("span",{style:{width:10,flexShrink:0}}),(0,r.jsx)("span",{className:"font-mono",style:{color:"var(--text-tertiary)",fontSize:10,flexShrink:0,minWidth:58},children:function(e){if(!e)return"";let t=e.split(" ");return t.length>1?t[1]:e}(a.timestamp)}),(0,r.jsx)("span",{style:{fontSize:9,fontWeight:700,letterSpacing:"0.5px",padding:"1px 5px",borderRadius:3,background:o.bg,color:o.color,flexShrink:0,lineHeight:"14px"},children:o.label}),(0,r.jsx)("span",{className:"font-mono",style:{color:"error"===a.level?"var(--system-red)":"var(--text-secondary)",fontSize:10,lineHeight:1.4,overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap",flex:1,minWidth:0},children:a.message})]}),n&&s&&(0,r.jsx)("div",{style:{padding:"6px 12px 8px 30px",borderTop:"1px solid var(--separator)",background:"var(--fill-secondary)"},children:(0,r.jsx)("pre",{className:"font-mono",style:{fontSize:9,lineHeight:1.5,color:"var(--text-secondary)",whiteSpace:"pre-wrap",wordBreak:"break-word",margin:0},children:a.message})})]})}function K(){let[e,t]=(0,i.useState)("hidden"),[a,n]=(0,i.useState)([]),[l,o]=(0,i.useState)(!0),[s,c]=(0,i.useState)(!1),[d,p]=(0,i.useState)(null),u=(0,i.useRef)(null),{events:h}=(0,F.G)();(0,i.useEffect)(()=>{l&&u.current&&(u.current.scrollTop=u.current.scrollHeight)},[a,l]);let g=(0,i.useCallback)(()=>{if(!u.current)return;let{scrollTop:e,scrollHeight:t,clientHeight:a}=u.current;t-e-a<40?o(!0):o(!1)},[]);(0,i.useEffect)(()=>{"expanded"===e&&T.F.getLogs(50).then(e=>{var t;n((null!=(t=e.lines)?t:[]).map(L.w)),p(null)}).catch(e=>{p(e instanceof Error?e.message:"Failed to load logs")})},[e]),(0,i.useEffect)(()=>{if("hidden"===e||0===h.length)return;let t=h[h.length-1];if("log"===t.event&&"object"==typeof t.payload&&null!==t.payload){let e=t.payload,a=e.line||e.message||JSON.stringify(t.payload),r=(0,L.w)(a,Date.now());n(e=>[...e,r].slice(-500))}},[h,e]);let x=(0,i.useCallback)(()=>{t("hidden")},[]),f=(0,i.useCallback)(async()=>{let e=a.map(M).join("\n");await navigator.clipboard.writeText(e),c(!0),setTimeout(()=>c(!1),1500)},[a]);return((0,i.useEffect)(()=>{function e(){t("expanded")}return window.addEventListener(H,e),()=>window.removeEventListener(H,e)},[]),"hidden"===e)?null:"collapsed"===e?(0,r.jsxs)("button",{onClick:()=>t("expanded"),className:"focus-ring flex items-center",style:{position:"fixed",bottom:20,right:20,zIndex:50,padding:"8px 14px",borderRadius:"var(--radius-pill)",border:"1px solid var(--separator)",background:"var(--material-regular)",backdropFilter:"blur(40px) saturate(180%)",WebkitBackdropFilter:"blur(40px) saturate(180%)",cursor:"pointer",gap:8,boxShadow:"0 4px 24px rgba(0,0,0,0.25)"},children:[(0,r.jsx)("span",{style:{width:8,height:8,borderRadius:"50%",background:"var(--system-green)",animation:"lsw-pulse 2s ease-in-out infinite",flexShrink:0}}),(0,r.jsx)("span",{style:{fontSize:"var(--text-caption1)",color:"var(--text-secondary)",fontWeight:"var(--weight-medium)"},children:"Live Stream"}),a.length>0&&(0,r.jsx)("span",{style:{fontSize:"var(--text-caption2)",color:"var(--text-tertiary)",background:"var(--fill-secondary)",padding:"1px 6px",borderRadius:"var(--radius-sm)"},children:a.length}),(0,r.jsx)("style",{children:"@keyframes lsw-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }"})]}):(0,r.jsxs)("div",{className:"panel-slide-in",style:{position:"fixed",bottom:20,right:20,zIndex:50,width:440,height:400,borderRadius:"var(--radius-lg)",border:"1px solid var(--separator)",background:"var(--material-regular)",backdropFilter:"blur(40px) saturate(180%)",WebkitBackdropFilter:"blur(40px) saturate(180%)",boxShadow:"0 8px 40px rgba(0,0,0,0.35)",display:"flex",flexDirection:"column",overflow:"hidden"},children:[(0,r.jsxs)("div",{className:"flex items-center flex-shrink-0",style:{padding:"10px 14px",borderBottom:"1px solid var(--separator)",gap:8},children:[(0,r.jsx)("span",{style:{width:8,height:8,borderRadius:"50%",background:"var(--system-green)",animation:"lsw-pulse 2s ease-in-out infinite",flexShrink:0}}),(0,r.jsx)("span",{style:{fontSize:"var(--text-footnote)",fontWeight:"var(--weight-semibold)",color:"var(--text-primary)"},children:"Live Stream"}),a.length>0&&(0,r.jsxs)("span",{style:{fontSize:"var(--text-caption2)",color:"var(--text-tertiary)"},children:[a.length," line",1!==a.length?"s":""]}),(0,r.jsxs)("div",{style:{marginLeft:"auto",display:"flex",gap:4},children:[(0,r.jsx)("button",{onClick:f,className:"focus-ring",title:"Copy all logs",disabled:0===a.length,style:{width:28,height:28,display:"flex",alignItems:"center",justifyContent:"center",borderRadius:"var(--radius-sm)",border:"none",background:s?"var(--accent-fill)":"transparent",color:s?"var(--accent)":"var(--text-tertiary)",cursor:0===a.length?"default":"pointer",opacity:0===a.length?.3:1,transition:"all 150ms var(--ease-smooth)"},children:(0,r.jsx)(D.A,{size:14})}),(0,r.jsx)("button",{onClick:()=>t("collapsed"),className:"focus-ring",title:"Minimize",style:{width:28,height:28,display:"flex",alignItems:"center",justifyContent:"center",borderRadius:"var(--radius-sm)",border:"none",background:"transparent",color:"var(--text-tertiary)",cursor:"pointer",transition:"color 150ms var(--ease-smooth)"},children:(0,r.jsx)(B.A,{size:14})}),(0,r.jsx)("button",{onClick:x,className:"focus-ring",title:"Close",style:{width:28,height:28,display:"flex",alignItems:"center",justifyContent:"center",borderRadius:"var(--radius-sm)",border:"none",background:"transparent",color:"var(--text-tertiary)",cursor:"pointer",transition:"color 150ms var(--ease-smooth)"},children:(0,r.jsx)(P.A,{size:14})})]})]}),d&&(0,r.jsx)("div",{style:{padding:"6px 14px",background:"rgba(255,69,58,0.06)",borderBottom:"1px solid rgba(255,69,58,0.15)",fontSize:"var(--text-caption2)",color:"var(--system-red)",flexShrink:0},children:d}),(0,r.jsx)("div",{ref:u,onScroll:g,style:{flex:1,minHeight:0,overflowY:"auto",overflowX:"hidden"},children:0===a.length?(0,r.jsxs)("div",{className:"flex flex-col items-center justify-center",style:{height:"100%",color:"var(--text-secondary)",gap:"var(--space-2)",padding:"var(--space-4)"},children:[(0,r.jsx)("svg",{width:"28",height:"28",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round",style:{color:"var(--text-tertiary)"},children:(0,r.jsx)("polyline",{points:"22 12 18 12 15 21 9 3 6 12 2 12"})}),(0,r.jsx)("span",{style:{fontSize:"var(--text-caption1)",fontWeight:"var(--weight-medium)"},children:"Waiting for log data..."})]}):(0,r.jsx)("div",{children:a.map(e=>(0,r.jsx)(q,{entry:e},e.id))})}),(0,r.jsx)("div",{className:"flex items-center flex-shrink-0",style:{padding:"8px 14px",borderTop:"1px solid var(--separator)",gap:8},children:!l&&a.length>0&&(0,r.jsx)("button",{onClick:()=>o(!0),className:"focus-ring",style:{padding:"4px 10px",borderRadius:"var(--radius-sm)",border:"none",cursor:"pointer",fontSize:"var(--text-caption2)",fontWeight:"var(--weight-medium)",background:"var(--fill-secondary)",color:"var(--text-secondary)"},children:"Scroll to bottom"})}),(0,r.jsx)("style",{children:"@keyframes lsw-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }"})]})}var G=a(4430),Y=a(1509),U=a(8146),_=a(2407),V=a(5136);let Q=[{label:"Red",value:"#EF4444"},{label:"Orange",value:"#F97316"},{label:"Amber",value:"#F59E0B"},{label:"Yellow",value:"#EAB308"},{label:"Lime",value:"#84CC16"},{label:"Green",value:"#22C55E"},{label:"Emerald",value:"#10B981"},{label:"Cyan",value:"#06B6D4"},{label:"Blue",value:"#3B82F6"},{label:"Indigo",value:"#6366F1"},{label:"Violet",value:"#8B5CF6"},{label:"Pink",value:"#EC4899"}],X=[{icon:u.A,name:"Chat",desc:"Direct conversations with any employee"},{icon:g.A,name:"Organization",desc:"Visual org chart of your AI team"},{icon:G.A,name:"Kanban",desc:"Task boards for work management"},{icon:f.A,name:"Cron",desc:"Scheduled jobs with status monitoring"},{icon:m.A,name:"Costs",desc:"Token usage and cost tracking"},{icon:v.A,name:"Activity",desc:"Real-time logs and event stream"}];function Z(e){var t;let{forceOpen:a,onClose:n}=e,{settings:l,setPortalName:o,setOperatorName:s,setAccentColor:p,setLanguage:u}=(0,d.t0)(),{theme:h,setTheme:g}=(0,S.D)(),x=(0,c.useRouter)(),[f,m]=(0,i.useState)(!1),[v,y]=(0,i.useState)(0),[b,j]=(0,i.useState)("forward"),[k,w]=(0,i.useState)(""),[N,z]=(0,i.useState)(""),[A,E]=(0,i.useState)(null!=(t=l.language)?t:"English");(0,i.useEffect)(()=>{if(a){var e,t;w(null!=(e=l.portalName)?e:""),z(null!=(t=l.operatorName)?t:""),m(!0);return}localStorage.getItem("jinn-onboarded")||m(!0)},[a]);let I=(0,i.useCallback)(()=>{0===v&&(o(k||null),s(N||null),u(A||"English")),v<3?(j("forward"),y(v+1)):(T.F.completeOnboarding({portalName:k||void 0,operatorName:N||void 0,language:A||void 0}).catch(()=>{}),a||localStorage.setItem("jinn-onboarded","true"),m(!1),null==n||n(),x.push("/chat"))},[v,k,N,a,n,o,s,x]),R=(0,i.useCallback)(()=>{v>0&&(j("back"),y(v-1))},[v]);return f?(0,r.jsx)("div",{style:{position:"fixed",inset:0,zIndex:50,display:"flex",alignItems:"center",justifyContent:"center",background:"rgba(0,0,0,0.6)",backdropFilter:"blur(12px)",WebkitBackdropFilter:"blur(12px)"},children:(0,r.jsxs)("div",{className:"animate-fade-in",style:{width:"100%",maxWidth:520,margin:"0 var(--space-4)",background:"var(--material-regular)",borderRadius:"var(--radius-lg)",border:"1px solid var(--separator)",boxShadow:"0 24px 48px rgba(0,0,0,0.3)",overflow:"hidden",display:"flex",flexDirection:"column",maxHeight:"90vh"},children:[(0,r.jsx)("div",{style:{display:"flex",justifyContent:"center",gap:8,padding:"var(--space-4) var(--space-4) 0"},children:Array.from({length:4}).map((e,t)=>(0,r.jsx)("div",{style:{width:t===v?24:8,height:8,borderRadius:4,background:t===v||t<v?"var(--accent)":"var(--fill-tertiary)",opacity:t<v?.5:1,transition:"all 200ms var(--ease-smooth)"}},t))}),(0,r.jsxs)("div",{style:{padding:"var(--space-5) var(--space-5) var(--space-4)",overflowY:"auto",flex:1},children:[0===v&&(0,r.jsxs)("div",{className:"animate-fade-in",style:{textAlign:"center"},children:[(0,r.jsx)("div",{style:{fontSize:56,marginBottom:"var(--space-3)",lineHeight:1},children:"\ud83e\udd16"}),(0,r.jsxs)("h2",{style:{fontSize:"var(--text-large-title)",fontWeight:"var(--weight-bold)",letterSpacing:"var(--tracking-tight)",color:"var(--text-primary)",marginBottom:"var(--space-2)"},children:["Welcome to ",k||"Jinn"]}),(0,r.jsx)("p",{style:{fontSize:"var(--text-body)",color:"var(--text-secondary)",lineHeight:"var(--leading-relaxed)",maxWidth:400,margin:"0 auto var(--space-5)"},children:"Your AI team management portal. Let's get you set up."}),(0,r.jsxs)("div",{style:{display:"flex",flexDirection:"column",gap:"var(--space-3)",textAlign:"left"},children:[(0,r.jsxs)("div",{children:[(0,r.jsx)("label",{style:{display:"block",fontSize:"var(--text-caption1)",color:"var(--text-tertiary)",marginBottom:"var(--space-1)"},children:"Portal Name"}),(0,r.jsx)("input",{type:"text",className:"apple-input",placeholder:"Jinn",value:k,onChange:e=>w(e.target.value),autoFocus:!0,style:{width:"100%",background:"var(--bg-secondary)",border:"1px solid var(--separator)",borderRadius:"var(--radius-sm)",padding:"8px 12px",fontSize:"var(--text-body)",color:"var(--text-primary)"}})]}),(0,r.jsxs)("div",{children:[(0,r.jsx)("label",{style:{display:"block",fontSize:"var(--text-caption1)",color:"var(--text-tertiary)",marginBottom:"var(--space-1)"},children:"What should we call you?"}),(0,r.jsx)("input",{type:"text",className:"apple-input",placeholder:"Your Name",value:N,onChange:e=>z(e.target.value),style:{width:"100%",background:"var(--bg-secondary)",border:"1px solid var(--separator)",borderRadius:"var(--radius-sm)",padding:"8px 12px",fontSize:"var(--text-body)",color:"var(--text-primary)"}})]}),(0,r.jsxs)("div",{children:[(0,r.jsx)("label",{style:{display:"block",fontSize:"var(--text-caption1)",color:"var(--text-tertiary)",marginBottom:"var(--space-1)"},children:"Preferred Language"}),(0,r.jsxs)("select",{value:A,onChange:e=>E(e.target.value),style:{width:"100%",background:"var(--bg-secondary)",border:"1px solid var(--separator)",borderRadius:"var(--radius-sm)",padding:"8px 12px",fontSize:"var(--text-body)",color:"var(--text-primary)",cursor:"pointer"},children:[(0,r.jsx)("option",{value:"English",children:"English"}),(0,r.jsx)("option",{value:"Spanish",children:"Spanish"}),(0,r.jsx)("option",{value:"French",children:"French"}),(0,r.jsx)("option",{value:"German",children:"German"}),(0,r.jsx)("option",{value:"Portuguese",children:"Portuguese"}),(0,r.jsx)("option",{value:"Italian",children:"Italian"}),(0,r.jsx)("option",{value:"Dutch",children:"Dutch"}),(0,r.jsx)("option",{value:"Russian",children:"Russian"}),(0,r.jsx)("option",{value:"Chinese",children:"Chinese"}),(0,r.jsx)("option",{value:"Japanese",children:"Japanese"}),(0,r.jsx)("option",{value:"Korean",children:"Korean"}),(0,r.jsx)("option",{value:"Arabic",children:"Arabic"}),(0,r.jsx)("option",{value:"Hindi",children:"Hindi"}),(0,r.jsx)("option",{value:"Bulgarian",children:"Bulgarian"})]})]})]})]},"step-0"),1===v&&(0,r.jsxs)("div",{className:"animate-fade-in",children:[(0,r.jsx)("h2",{style:{fontSize:"var(--text-title1)",fontWeight:"var(--weight-bold)",letterSpacing:"var(--tracking-tight)",color:"var(--text-primary)",marginBottom:"var(--space-1)"},children:"Choose your theme"}),(0,r.jsx)("p",{style:{fontSize:"var(--text-subheadline)",color:"var(--text-tertiary)",marginBottom:"var(--space-4)"},children:"Pick the look that suits you. This applies live."}),(0,r.jsx)("div",{style:{display:"grid",gridTemplateColumns:"repeat(auto-fill, minmax(130px, 1fr))",gap:"var(--space-3)"},children:C.z.map(e=>{let t=h===e.id;return(0,r.jsxs)("button",{onClick:()=>g(e.id),style:{display:"flex",flexDirection:"column",alignItems:"center",gap:"var(--space-2)",padding:"var(--space-4) var(--space-3)",borderRadius:"var(--radius-md)",background:"var(--fill-quaternary)",border:t?"2px solid var(--accent)":"2px solid var(--separator)",cursor:"pointer",transition:"all 150ms var(--ease-smooth)"},children:[(0,r.jsx)("span",{style:{fontSize:28},children:e.emoji}),(0,r.jsx)("span",{style:{fontSize:"var(--text-footnote)",fontWeight:t?"var(--weight-semibold)":"var(--weight-medium)",color:t?"var(--accent)":"var(--text-secondary)"},children:e.label})]},e.id)})})]},"step-1"),2===v&&(0,r.jsxs)("div",{className:"animate-fade-in",children:[(0,r.jsx)("h2",{style:{fontSize:"var(--text-title1)",fontWeight:"var(--weight-bold)",letterSpacing:"var(--tracking-tight)",color:"var(--text-primary)",marginBottom:"var(--space-1)"},children:"Pick an accent color"}),(0,r.jsx)("p",{style:{fontSize:"var(--text-subheadline)",color:"var(--text-tertiary)",marginBottom:"var(--space-4)"},children:"Personalize with your favorite color."}),(0,r.jsx)("div",{style:{display:"grid",gridTemplateColumns:"repeat(6, 1fr)",gap:"var(--space-3)",justifyItems:"center"},children:Q.map(e=>{let t=l.accentColor===e.value;return(0,r.jsx)("button",{onClick:()=>p(e.value),"aria-label":e.label,title:e.label,style:{width:40,height:40,borderRadius:"50%",background:e.value,border:"none",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",outline:t?"3px solid ".concat(e.value):"none",outlineOffset:3,transition:"all 100ms var(--ease-smooth)"},children:t&&(0,r.jsx)(Y.A,{size:18,color:"#fff",strokeWidth:3})},e.value)})})]},"step-2"),3===v&&(0,r.jsxs)("div",{className:"animate-fade-in",children:[(0,r.jsx)("h2",{style:{fontSize:"var(--text-title1)",fontWeight:"var(--weight-bold)",letterSpacing:"var(--tracking-tight)",color:"var(--text-primary)",marginBottom:"var(--space-1)"},children:"You're all set!"}),(0,r.jsx)("p",{style:{fontSize:"var(--text-subheadline)",color:"var(--text-tertiary)",marginBottom:"var(--space-4)"},children:"Here's what you can do."}),(0,r.jsx)("div",{style:{display:"flex",flexDirection:"column",gap:"var(--space-2)"},children:X.map(e=>{let t=e.icon;return(0,r.jsxs)("div",{style:{display:"flex",alignItems:"center",gap:"var(--space-3)",padding:"var(--space-3)",borderRadius:"var(--radius-md)",background:"var(--fill-quaternary)",border:"1px solid var(--separator)"},children:[(0,r.jsx)("div",{style:{width:36,height:36,borderRadius:8,background:"var(--accent-fill)",display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0},children:(0,r.jsx)(t,{size:18,style:{color:"var(--accent)"}})}),(0,r.jsxs)("div",{style:{minWidth:0},children:[(0,r.jsx)("div",{style:{fontSize:"var(--text-subheadline)",fontWeight:"var(--weight-semibold)",color:"var(--text-primary)"},children:e.name}),(0,r.jsx)("div",{style:{fontSize:"var(--text-caption1)",color:"var(--text-tertiary)"},children:e.desc})]})]},e.name)})})]},"step-3")]}),(0,r.jsxs)("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",padding:"var(--space-3) var(--space-5) var(--space-5)",gap:"var(--space-3)"},children:[v>0?(0,r.jsxs)("button",{onClick:R,style:{padding:"var(--space-2) var(--space-4)",borderRadius:"var(--radius-md)",background:"var(--fill-tertiary)",color:"var(--text-secondary)",border:"none",cursor:"pointer",fontSize:"var(--text-subheadline)",fontWeight:"var(--weight-medium)",transition:"all 150ms var(--ease-smooth)",display:"inline-flex",alignItems:"center",gap:6},children:[(0,r.jsx)(U.A,{size:16}),"Back"]}):(0,r.jsx)("div",{}),(0,r.jsxs)("button",{onClick:I,style:{padding:"var(--space-2) var(--space-6)",borderRadius:"var(--radius-md)",background:"var(--accent)",color:"var(--accent-contrast)",border:"none",cursor:"pointer",fontSize:"var(--text-subheadline)",fontWeight:"var(--weight-semibold)",transition:"all 150ms var(--ease-smooth)",display:"inline-flex",alignItems:"center",gap:6},children:[0===v?"Next":3===v?"Get Started":"Next",3===v?(0,r.jsx)(_.A,{size:16}):(0,r.jsx)(V.A,{size:16})]})]})]})}):null}var $=a(7836);let ee=[{href:"/",label:"Home",icon:p.A},{href:"/chat",label:"Chat",icon:u.A},{href:"/sessions",label:"Sessions",icon:h.A},{href:"/org",label:"Organization",icon:g.A},{href:"/kanban",label:"Kanban",icon:x.A},{href:"/cron",label:"Cron",icon:f.A},{href:"/costs",label:"Costs",icon:m.A},{href:"/logs",label:"Activity",icon:v.A},{href:"/skills",label:"Skills",icon:y.A},{href:"/settings",label:"Settings",icon:b.A}];function et(){var e,t;let[a,n]=(0,i.useState)(!1),o=(0,c.usePathname)(),{settings:p}=(0,d.t0)(),u=null!=(e=p.portalEmoji)?e:"\uD83E\uDD16",h=null!=(t=p.portalName)?t:"Jinn";return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsxs)("div",{style:{height:48,display:"flex",alignItems:"center",padding:"0 12px",borderBottom:"1px solid var(--separator)",background:"var(--material-thick)",flexShrink:0,position:"relative",zIndex:60},className:"jsx-906cbf20b7aa1777 lg:hidden",children:[(0,r.jsx)("button",{onClick:()=>n(!0),"aria-label":"Open menu",style:{width:36,height:36,display:"flex",alignItems:"center",justifyContent:"center",background:"transparent",border:"none",cursor:"pointer",color:"var(--text-primary)"},className:"jsx-906cbf20b7aa1777",children:(0,r.jsx)($.A,{size:20})}),(0,r.jsxs)("div",{style:{flex:1,textAlign:"center"},className:"jsx-906cbf20b7aa1777",children:[(0,r.jsx)("span",{style:{fontSize:18,marginRight:6},className:"jsx-906cbf20b7aa1777",children:u}),(0,r.jsx)("span",{style:{fontSize:15,fontWeight:600,color:"var(--text-primary)"},className:"jsx-906cbf20b7aa1777",children:h})]}),(0,r.jsx)("div",{style:{width:36},className:"jsx-906cbf20b7aa1777"})]}),a&&(0,r.jsxs)("div",{style:{position:"fixed",inset:0,zIndex:100},className:"jsx-906cbf20b7aa1777 lg:hidden",children:[(0,r.jsx)("div",{style:{position:"absolute",inset:0,background:"rgba(0,0,0,0.5)"},onClick:()=>n(!1),className:"jsx-906cbf20b7aa1777"}),(0,r.jsxs)("nav",{style:{position:"absolute",top:0,left:0,bottom:0,width:260,background:"var(--bg-secondary)",borderRight:"1px solid var(--separator)",display:"flex",flexDirection:"column",animation:"slideInLeft 200ms ease"},className:"jsx-906cbf20b7aa1777",children:[(0,r.jsxs)("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",padding:"12px 14px",borderBottom:"1px solid var(--separator)"},className:"jsx-906cbf20b7aa1777",children:[(0,r.jsxs)("div",{style:{display:"flex",alignItems:"center",gap:8},className:"jsx-906cbf20b7aa1777",children:[(0,r.jsx)("span",{style:{fontSize:22},className:"jsx-906cbf20b7aa1777",children:u}),(0,r.jsx)("span",{style:{fontSize:16,fontWeight:600,color:"var(--text-primary)"},className:"jsx-906cbf20b7aa1777",children:h})]}),(0,r.jsx)("button",{onClick:()=>n(!1),"aria-label":"Close menu",style:{width:32,height:32,display:"flex",alignItems:"center",justifyContent:"center",background:"transparent",border:"none",cursor:"pointer",color:"var(--text-secondary)"},className:"jsx-906cbf20b7aa1777",children:(0,r.jsx)(P.A,{size:18})})]}),(0,r.jsx)("div",{style:{flex:1,padding:"8px",display:"flex",flexDirection:"column",gap:2},className:"jsx-906cbf20b7aa1777",children:ee.map(e=>{let t="/"===e.href?"/"===o:o.startsWith(e.href),a=e.icon;return(0,r.jsxs)(s(),{href:e.href,onClick:()=>n(!1),style:{display:"flex",alignItems:"center",gap:12,height:44,padding:"0 14px",borderRadius:10,textDecoration:"none",color:t?"var(--accent)":"var(--text-secondary)",background:t?"var(--accent-fill)":"transparent",fontWeight:t?600:400,fontSize:15},children:[(0,r.jsx)(a,{size:18,style:{flexShrink:0},className:"jsx-906cbf20b7aa1777"}),e.label]},e.href)})})]})]}),(0,r.jsx)(l(),{id:"906cbf20b7aa1777",children:"@keyframes slideInLeft{from{transform:translatex(-100%)}to{transform:translatex(0)}}"})]})}function ea(e){let{children:t}=e;return(0,r.jsxs)("div",{className:"flex h-dvh overflow-hidden",style:{background:"var(--bg)"},children:[(0,r.jsx)(A,{}),(0,r.jsx)(O,{}),(0,r.jsxs)("main",{className:"flex-1 overflow-hidden lg:ml-[56px]",children:[(0,r.jsx)(et,{}),t]}),(0,r.jsx)(K,{}),(0,r.jsx)(Z,{})]})}},3176:(e,t,a)=>{a.d(t,{F:()=>s});let r=window.location.origin;async function n(e){let t=await fetch("".concat(r).concat(e));if(!t.ok)throw Error("API error: ".concat(t.status));return t.json()}async function l(e,t){let a=await fetch("".concat(r).concat(e),{method:"POST",headers:{"Content-Type":"application/json"},body:t?JSON.stringify(t):void 0});if(!a.ok)throw Error("API error: ".concat(a.status));return a.json()}async function i(e){let t=await fetch("".concat(r).concat(e),{method:"DELETE"});if(!t.ok)throw Error("API error: ".concat(t.status));return t.json()}async function o(e,t){let a=await fetch("".concat(r).concat(e),{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(t)});if(!a.ok)throw Error("API error: ".concat(a.status));return a.json()}let s={getStatus:()=>n("/api/status"),getSessions:()=>n("/api/sessions"),getSession:e=>n("/api/sessions/".concat(e)),getSessionChildren:e=>n("/api/sessions/".concat(e,"/children")),deleteSession:e=>i("/api/sessions/".concat(e)),bulkDeleteSessions:e=>l("/api/sessions/bulk-delete",{ids:e}),createSession:e=>l("/api/sessions",e),createStubSession:e=>l("/api/sessions/stub",e),sendMessage:(e,t)=>l("/api/sessions/".concat(e,"/message"),t),getCronJobs:()=>n("/api/cron"),getCronRuns:e=>n("/api/cron/".concat(e,"/runs")),updateCronJob:(e,t)=>o("/api/cron/".concat(e),t),triggerCronJob:e=>l("/api/cron/".concat(e,"/trigger"),{}),getOrg:()=>n("/api/org"),getEmployee:e=>n("/api/org/employees/".concat(e)),getDepartmentBoard:e=>n("/api/org/departments/".concat(e,"/board")),getSkills:()=>n("/api/skills"),getSkill:e=>n("/api/skills/".concat(e)),getConfig:()=>n("/api/config"),updateConfig:e=>o("/api/config",e),getLogs:e=>n("/api/logs".concat(e?"?n=".concat(e):"")),getOnboarding:()=>n("/api/onboarding"),completeOnboarding:e=>l("/api/onboarding",e),getActivity:()=>n("/api/activity"),updateDepartmentBoard:(e,t)=>o("/api/org/departments/".concat(e,"/board"),t),sttStatus:()=>n("/api/stt/status"),sttDownload:()=>l("/api/stt/download",{}),sttTranscribe:async(e,t)=>{let a=t?"?language=".concat(encodeURIComponent(t)):"",n=new AbortController,l=setTimeout(()=>n.abort(),3e5);try{let t=await fetch("".concat(r,"/api/stt/transcribe").concat(a),{method:"POST",headers:{"Content-Type":e.type||"audio/webm"},body:e,signal:n.signal});if(!t.ok)throw Error("API error: ".concat(t.status));return t.json()}catch(e){if(e instanceof DOMException&&"AbortError"===e.name)throw Error("Transcription timed out (5 min)");throw e}finally{clearTimeout(l)}},sttUpdateConfig:e=>o("/api/stt/config",{languages:e})}},4263:(e,t,a)=>{a.d(t,{G:()=>o});var r=a(5271),n=a(1298),l=a(2755);function i(e,t){"Notification"in window&&"granted"===Notification.permission&&document.hidden&&new Notification(e,{body:t,icon:"/favicon.ico",tag:"jinn-session"})}function o(){var e;let{settings:t}=(0,l.t0)(),a=null!=(e=t.portalName)?e:"Jinn",[o,s]=(0,r.useState)([]),[c,d]=(0,r.useState)(!1),[p,u]=(0,r.useState)(0),[h,g]=(0,r.useState)(0),x=(0,r.useRef)(!1),f=(0,r.useRef)(a);return f.current=a,(0,r.useEffect)(()=>{!x.current&&(x.current=!0,"Notification"in window&&"default"===Notification.permission&&Notification.requestPermission());let e=(0,n.E)((e,t)=>{if(s(a=>[...a.slice(-99),{event:e,payload:t}]),"skills:changed"===e&&g(e=>e+1),"session:completed"===e){let e=t.employee||f.current,a=t.error;a?i("".concat(e," - Error"),a.slice(0,100)):i("".concat(e," - Done"),"Session completed successfully")}},{onOpen:()=>{d(!0),u(e=>e+1)},onClose:()=>{d(!1)}});return()=>e.close()},[]),{events:o,connected:c,connectionSeq:p,skillsVersion:h}}},5310:(e,t,a)=>{a.d(t,{b:()=>c,w:()=>s});var r=a(8111),n=a(5271);let l={info:"var(--system-green)",warn:"var(--system-orange)",error:"var(--system-red)",debug:"var(--text-tertiary)"},i={info:"rgba(48,209,88,0.12)",warn:"rgba(255,159,10,0.12)",error:"rgba(255,69,58,0.12)",debug:"var(--fill-secondary)"},o=[{key:"all",label:"All"},{key:"info",label:"Info"},{key:"warn",label:"Warn"},{key:"error",label:"Errors"}];function s(e,t){let a=e.match(/^(\d{4}-\d{2}-\d{2}\s+\d{2}:\d{2}:\d{2})\s+\[(\w+)\]\s*(.*)$/);return a?{id:"log-".concat(t),timestamp:a[1],level:a[2].toLowerCase(),message:a[3]}:{id:"log-".concat(t),timestamp:"",level:"info",message:e}}function c(e){let{lines:t}=e,[a,c]=(0,n.useState)("all"),[d,p]=(0,n.useState)(""),[u,h]=(0,n.useState)(null),g=t.map(s),x=g.filter(e=>("all"===a||e.level===a)&&(!d||!!e.message.toLowerCase().includes(d.toLowerCase()))),f={all:g.length,info:g.filter(e=>"info"===e.level).length,warn:g.filter(e=>"warn"===e.level).length,error:g.filter(e=>"error"===e.level).length};return(0,r.jsxs)("div",{children:[(0,r.jsxs)("div",{className:"flex items-center flex-wrap",style:{gap:"var(--space-2)",marginBottom:"var(--space-3)"},children:[o.map(e=>{let t=a===e.key;return(0,r.jsxs)("button",{onClick:()=>c(e.key),className:"focus-ring flex items-center flex-shrink-0",style:{borderRadius:20,padding:"6px 14px",fontSize:"var(--text-footnote)",fontWeight:"var(--weight-medium)",border:"none",cursor:"pointer",gap:"var(--space-2)",transition:"all 200ms var(--ease-smooth)",...t?{background:"var(--accent-fill)",color:"var(--accent)",boxShadow:"0 0 0 1px color-mix(in srgb, var(--accent) 40%, transparent)"}:{background:"var(--fill-secondary)",color:"var(--text-primary)"}},children:[(0,r.jsx)("span",{children:e.label}),(0,r.jsx)("span",{style:{fontWeight:"var(--weight-semibold)",color:t?"var(--accent)":"var(--text-secondary)"},children:f[e.key]})]},e.key)}),(0,r.jsx)("input",{type:"text",placeholder:"Search logs...",value:d,onChange:e=>p(e.target.value),className:"focus-ring",style:{marginLeft:"auto",padding:"6px 12px",fontSize:"var(--text-footnote)",borderRadius:"var(--radius-sm)",border:"1px solid var(--separator)",background:"var(--fill-secondary)",color:"var(--text-primary)",outline:"none",minWidth:160,maxWidth:240}})]}),0===x.length?(0,r.jsxs)("div",{className:"flex flex-col items-center justify-center",style:{height:200,color:"var(--text-secondary)",gap:"var(--space-2)"},children:[(0,r.jsx)("span",{style:{fontSize:"var(--text-subheadline)",fontWeight:"var(--weight-medium)"},children:0===g.length?"No log entries found":"No entries match this filter"}),(0,r.jsx)("span",{style:{fontSize:"var(--text-footnote)",color:"var(--text-tertiary)"},children:0===g.length?"Log entries will appear here when available":"Try adjusting your filter or search"})]}):(0,r.jsx)("div",{style:{borderRadius:"var(--radius-md)",overflow:"hidden",background:"var(--material-regular)",backdropFilter:"blur(20px)",WebkitBackdropFilter:"blur(20px)"},children:x.map((e,t)=>{var a,n;let o=u===e.id,s=null!=(a=l[e.level])?a:"var(--text-tertiary)",c=e.message.length>120;return(0,r.jsxs)("div",{children:[t>0&&(0,r.jsx)("div",{style:{height:1,background:"var(--separator)",marginLeft:"var(--space-4)",marginRight:"var(--space-4)"}}),(0,r.jsxs)("div",{role:"button",tabIndex:0,"aria-expanded":c?o:void 0,onClick:()=>c&&h(o?null:e.id),onKeyDown:t=>{c&&("Enter"===t.key||" "===t.key)&&(t.preventDefault(),h(o?null:e.id))},className:"flex items-center hover-bg focus-ring",style:{minHeight:44,padding:"0 var(--space-4)",cursor:c?"pointer":"default",background:"error"===e.level?"rgba(255,69,58,0.06)":void 0},children:[(0,r.jsx)("span",{className:"flex-shrink-0 rounded-full",style:{width:8,height:8,background:s}}),e.timestamp&&(0,r.jsx)("span",{className:"flex-shrink-0 font-mono",style:{fontSize:"var(--text-caption1)",color:"var(--text-tertiary)",marginLeft:"var(--space-3)",minWidth:130},children:e.timestamp}),(0,r.jsx)("span",{className:"flex-shrink-0",style:{fontSize:"var(--text-caption2)",fontWeight:"var(--weight-semibold)",padding:"1px 6px",borderRadius:4,background:null!=(n=i[e.level])?n:"var(--fill-secondary)",color:s,marginLeft:"var(--space-2)",letterSpacing:"0.04em",textTransform:"uppercase"},children:e.level}),(0,r.jsx)("span",{className:"truncate",style:{fontSize:"var(--text-footnote)",color:"var(--text-primary)",marginLeft:"var(--space-3)",flex:1,minWidth:0},children:c&&!o?e.message.slice(0,117)+"...":e.message}),c&&(0,r.jsx)("span",{"aria-hidden":"true",style:{fontSize:"var(--text-footnote)",color:"var(--text-tertiary)",transition:"transform 200ms var(--ease-smooth)",transform:o?"rotate(90deg)":"rotate(0deg)",display:"inline-block",marginLeft:"var(--space-2)"},children:"›"})]}),o&&c&&(0,r.jsx)("div",{className:"animate-slide-down",style:{padding:"0 var(--space-4) var(--space-4) var(--space-4)"},children:(0,r.jsx)("div",{style:{borderRadius:"var(--radius-sm)",background:"var(--fill-secondary)",padding:"var(--space-3)",marginTop:"var(--space-2)"},children:(0,r.jsx)("pre",{className:"font-mono",style:{fontSize:"var(--text-caption2)",color:"var(--text-secondary)",whiteSpace:"pre-wrap",wordBreak:"break-word",margin:0,maxHeight:300,overflow:"auto",lineHeight:"var(--leading-relaxed)"},children:e.message})})})]},e.id)})})]})}},7460:(e,t,a)=>{a.d(t,{D:()=>o,N:()=>i});var r=a(8111),n=a(5271);let l=(0,n.createContext)({theme:"dark",setTheme:()=>{}});function i(e){let{children:t}=e,[a,i]=(0,n.useState)("dark"),o=(0,n.useCallback)(e=>{i(e),localStorage.setItem("jinn-theme",e);let t=document.documentElement;if(t.removeAttribute("data-theme"),"system"===e){let e=window.matchMedia("(prefers-color-scheme: dark)").matches;t.setAttribute("data-theme",e?"dark":"light")}else t.setAttribute("data-theme",e)},[]);return(0,n.useEffect)(()=>{let e=localStorage.getItem("jinn-theme");e&&o(e)},[o]),(0,r.jsx)(l.Provider,{value:{theme:a,setTheme:o},children:t})}function o(){return(0,n.useContext)(l)}},9834:(e,t,a)=>{a.d(t,{z:()=>r});let r=[{id:"dark",label:"Dark",emoji:"\uD83C\uDF11"},{id:"glass",label:"Glass",emoji:"\uD83E\uDE9F"},{id:"color",label:"Color",emoji:"\uD83C\uDFA8"},{id:"light",label:"Light",emoji:"☀️"},{id:"system",label:"System",emoji:"⚙️"}]}}]);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[492],{1898:(e,t,l)=>{"use strict";Object.defineProperty(t,"__esModule",{value:!0}),Object.defineProperty(t,"HTTPAccessErrorFallback",{enumerable:!0,get:function(){return o}});let r=l(8111),n=l(4733);function o(e){let{status:t,message:l}=e;return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)("title",{children:t+": "+l}),(0,r.jsx)("div",{style:n.styles.error,children:(0,r.jsxs)("div",{children:[(0,r.jsx)("style",{dangerouslySetInnerHTML:{__html:"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}"}}),(0,r.jsx)("h1",{className:"next-error-h1",style:n.styles.h1,children:t}),(0,r.jsx)("div",{style:n.styles.desc,children:(0,r.jsx)("h2",{style:n.styles.h2,children:l})})]})})]})}("function"==typeof t.default||"object"==typeof t.default&&null!==t.default)&&void 0===t.default.__esModule&&(Object.defineProperty(t.default,"__esModule",{value:!0}),Object.assign(t.default,t),e.exports=t.default)},4733:(e,t)=>{"use strict";Object.defineProperty(t,"__esModule",{value:!0}),Object.defineProperty(t,"styles",{enumerable:!0,get:function(){return l}});let l={error:{fontFamily:'system-ui,"Segoe UI",Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji"',height:"100vh",textAlign:"center",display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center"},desc:{display:"inline-block"},h1:{display:"inline-block",margin:"0 20px 0 0",padding:"0 23px 0 0",fontSize:24,fontWeight:500,verticalAlign:"top",lineHeight:"49px"},h2:{fontSize:14,fontWeight:400,lineHeight:"49px",margin:0}};("function"==typeof t.default||"object"==typeof t.default&&null!==t.default)&&void 0===t.default.__esModule&&(Object.defineProperty(t.default,"__esModule",{value:!0}),Object.assign(t.default,t),e.exports=t.default)},5455:(e,t,l)=>{"use strict";Object.defineProperty(t,"__esModule",{value:!0}),Object.defineProperty(t,"default",{enumerable:!0,get:function(){return o}});let r=l(8111),n=l(1898),o=function(){return(0,r.jsx)("html",{children:(0,r.jsx)("body",{children:(0,r.jsx)(n.HTTPAccessErrorFallback,{status:404,message:"This page could not be found."})})})};("function"==typeof t.default||"object"==typeof t.default&&null!==t.default)&&void 0===t.default.__esModule&&(Object.defineProperty(t.default,"__esModule",{value:!0}),Object.assign(t.default,t),e.exports=t.default)},
|
|
1
|
+
(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[492],{1898:(e,t,l)=>{"use strict";Object.defineProperty(t,"__esModule",{value:!0}),Object.defineProperty(t,"HTTPAccessErrorFallback",{enumerable:!0,get:function(){return o}});let r=l(8111),n=l(4733);function o(e){let{status:t,message:l}=e;return(0,r.jsxs)(r.Fragment,{children:[(0,r.jsx)("title",{children:t+": "+l}),(0,r.jsx)("div",{style:n.styles.error,children:(0,r.jsxs)("div",{children:[(0,r.jsx)("style",{dangerouslySetInnerHTML:{__html:"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}"}}),(0,r.jsx)("h1",{className:"next-error-h1",style:n.styles.h1,children:t}),(0,r.jsx)("div",{style:n.styles.desc,children:(0,r.jsx)("h2",{style:n.styles.h2,children:l})})]})})]})}("function"==typeof t.default||"object"==typeof t.default&&null!==t.default)&&void 0===t.default.__esModule&&(Object.defineProperty(t.default,"__esModule",{value:!0}),Object.assign(t.default,t),e.exports=t.default)},4733:(e,t)=>{"use strict";Object.defineProperty(t,"__esModule",{value:!0}),Object.defineProperty(t,"styles",{enumerable:!0,get:function(){return l}});let l={error:{fontFamily:'system-ui,"Segoe UI",Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji"',height:"100vh",textAlign:"center",display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center"},desc:{display:"inline-block"},h1:{display:"inline-block",margin:"0 20px 0 0",padding:"0 23px 0 0",fontSize:24,fontWeight:500,verticalAlign:"top",lineHeight:"49px"},h2:{fontSize:14,fontWeight:400,lineHeight:"49px",margin:0}};("function"==typeof t.default||"object"==typeof t.default&&null!==t.default)&&void 0===t.default.__esModule&&(Object.defineProperty(t.default,"__esModule",{value:!0}),Object.assign(t.default,t),e.exports=t.default)},5455:(e,t,l)=>{"use strict";Object.defineProperty(t,"__esModule",{value:!0}),Object.defineProperty(t,"default",{enumerable:!0,get:function(){return o}});let r=l(8111),n=l(1898),o=function(){return(0,r.jsx)("html",{children:(0,r.jsx)("body",{children:(0,r.jsx)(n.HTTPAccessErrorFallback,{status:404,message:"This page could not be found."})})})};("function"==typeof t.default||"object"==typeof t.default&&null!==t.default)&&void 0===t.default.__esModule&&(Object.defineProperty(t.default,"__esModule",{value:!0}),Object.assign(t.default,t),e.exports=t.default)},7409:(e,t,l)=>{(window.__NEXT_P=window.__NEXT_P||[]).push(["/_not-found/page",function(){return l(5455)}])}},e=>{e.O(0,[814,743,358],()=>e(e.s=7409)),_N_E=e.O()}]);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[457],{3095:(e,t,r)=>{"use strict";r.r(t),r.d(t,{default:()=>N});var n=r(8111),a=r(5271),i=r(4736),s=r(3176),o=r(4263),l=r(3073),d=r(2755);let c="jinn-sidebar-collapsed",u="jinn-pinned-sessions";function p(){try{let e=localStorage.getItem("jinn-read-sessions");return e?new Set(JSON.parse(e)):new Set}catch(e){return new Set}}function h(e){try{localStorage.setItem(u,JSON.stringify(Array.from(e)))}catch(e){}}function g(e){return"cron"===e.source||(e.sourceRef||"").startsWith("cron:")}function v(e,t){let r=(e,t)=>{let r=e.lastActivity||e.createdAt||"";return(t.lastActivity||t.createdAt||"").localeCompare(r)};return[...e.filter(e=>t.has(e.id)).sort(r),...e.filter(e=>!t.has(e.id)).sort(r)]}function x(e){var t;let{selectedId:r,onSelect:i,onNewChat:o,onDelete:l,refreshKey:x,connectionSeq:m,onSessionsLoaded:f,events:y}=e,{settings:b}=(0,d.t0)(),j=null!=(t=b.portalName)?t:"Jinn",k=j.toLowerCase(),[w,S]=(0,a.useState)([]),[C,I]=(0,a.useState)(!0),[R,L]=(0,a.useState)(""),[W,z]=(0,a.useState)(null),[D,T]=(0,a.useState)(null),[M,B]=(0,a.useState)(null),[E,A]=(0,a.useState)(null),[U,N]=(0,a.useState)(new Set),[F,H]=(0,a.useState)(new Set),[O,P]=(0,a.useState)(new Set),[V,q]=(0,a.useState)(new Map),J=(0,a.useRef)(null);(0,a.useEffect)(()=>{N(p()),H(function(){try{let e=localStorage.getItem(u);return e?new Set(JSON.parse(e)):new Set}catch(e){return new Set}}()),P(function(){try{let e=localStorage.getItem(c);return e?new Set(JSON.parse(e)):new Set}catch(e){return new Set}}()),s.F.getOrg().then(async e=>{let t=new Map;await Promise.all(e.employees.map(async e=>{try{let r=await s.F.getEmployee(e);r.emoji&&t.set(e,r.emoji)}catch(e){}})),q(t)}).catch(()=>{})},[]),(0,a.useEffect)(()=>{if(r){let e=p();e.add(r);let t=Array.from(e);t.length>500&&t.splice(0,t.length-500),localStorage.setItem("jinn-read-sessions",JSON.stringify(t)),N(e=>{let t=new Set(e);return t.add(r),t})}},[r]);let _=(0,a.useCallback)(()=>{s.F.getSessions().then(e=>{let t=e.filter(e=>"web"===e.source||"cron"===e.source||!e.source);t.sort((e,t)=>{let r=e.lastActivity||e.createdAt||"";return(t.lastActivity||t.createdAt||"").localeCompare(r)}),S(t),null==f||f(t)}).catch(()=>S([])).finally(()=>I(!1))},[f]);(0,a.useEffect)(()=>{I(!0),_()},[x,_]),(0,a.useEffect)(()=>{m&&_()},[m,_]),(0,a.useEffect)(()=>{if(!y||0===y.length)return;let e=y[y.length-1],t="".concat(e.event,":").concat(JSON.stringify(e.payload));t!==J.current&&(J.current=t,("session:started"===e.event||"session:completed"===e.event||"session:deleted"===e.event||"session:error"===e.event)&&_())},[y,_]);let K=(0,a.useCallback)(e=>{P(t=>{let r=new Set(t);r.has(e)?r.delete(e):r.add(e);try{localStorage.setItem(c,JSON.stringify(Array.from(r)))}catch(e){}return r})},[]),Y=(0,a.useCallback)(e=>{H(t=>{let r=new Set(t);return r.has(e)?r.delete(e):r.add(e),h(r),r})},[]);async function X(e){let t=e.sessions.map(e=>e.id);try{await s.F.bulkDeleteSessions(t),S(e=>e.filter(e=>!t.includes(e.id))),H(e=>{let r=new Set(e);for(let e of t)r.delete(e);return h(r),r}),r&&t.includes(r)&&o()}catch(e){}T(null)}async function G(e){try{await s.F.deleteSession(e),S(t=>t.filter(t=>t.id!==e)),H(t=>{if(!t.has(e))return t;let r=new Set(t);return r.delete(e),h(r),r}),l?l(e):r===e&&o()}catch(e){}z(null)}let $=function(e,t,r,n){let a=[],i=[],s=new Map;for(let t of e)if(g(t))i.push(t);else if(g(t)||t.employee&&t.employee!==r){let e=t.employee;s.has(e)||s.set(e,[]),s.get(e).push(t)}else a.push(t);let o=[];for(let e of(a.length>0&&o.push({key:"direct",label:"Direct",emoji:"\uD83D\uDCAC",sessions:v(a,n),sortOrder:0}),Array.from(s.keys()).sort())){let r=s.get(e);o.push({key:"emp:".concat(e),label:e,emoji:t.get(e)||"\uD83E\uDD16",sessions:v(r,n),sortOrder:1})}return i.length>0&&o.push({key:"cron",label:"Cron",emoji:"⏰",sessions:v(i,n),sortOrder:2}),o}(R.trim()?w.filter(e=>{let t=R.toLowerCase();return e.id.toLowerCase().includes(t)||e.employee&&e.employee.toLowerCase().includes(t)||e.title&&e.title.toLowerCase().includes(t)}):w,V,k,F);return(0,n.jsxs)("div",{style:{display:"flex",flexDirection:"column",height:"100%",background:"var(--sidebar-bg)",borderRight:"1px solid var(--separator)"},children:[(0,n.jsxs)("div",{style:{padding:"var(--space-4) var(--space-4) var(--space-3)",borderBottom:"1px solid var(--separator)",background:"var(--material-thick)",flexShrink:0},children:[(0,n.jsxs)("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",marginBottom:"var(--space-3)"},children:[(0,n.jsx)("h2",{style:{fontSize:"var(--text-title3)",fontWeight:"var(--weight-bold)",letterSpacing:"-0.5px",color:"var(--text-primary)",margin:0},children:"Chats"}),(0,n.jsxs)("button",{onClick:o,"aria-label":"New chat",style:{padding:"var(--space-1) var(--space-3)",fontSize:"var(--text-footnote)",fontWeight:"var(--weight-semibold)",color:"var(--accent-contrast)",background:"var(--accent)",border:"none",borderRadius:"var(--radius-md)",cursor:"pointer",display:"flex",alignItems:"center",gap:"var(--space-1)"},children:[(0,n.jsxs)("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",children:[(0,n.jsx)("line",{x1:"12",y1:"5",x2:"12",y2:"19"}),(0,n.jsx)("line",{x1:"5",y1:"12",x2:"19",y2:"12"})]}),"New"]})]}),(0,n.jsxs)("div",{style:{background:"var(--fill-tertiary)",borderRadius:"var(--radius-md)",padding:"7px var(--space-3)",display:"flex",alignItems:"center",gap:"var(--space-2)"},children:[(0,n.jsxs)("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"none",stroke:"var(--text-tertiary)",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",style:{flexShrink:0},"aria-hidden":"true",children:[(0,n.jsx)("circle",{cx:"11",cy:"11",r:"8"}),(0,n.jsx)("line",{x1:"21",y1:"21",x2:"16.65",y2:"16.65"})]}),(0,n.jsx)("input",{type:"text",value:R,onChange:e=>L(e.target.value),placeholder:"Search sessions...","aria-label":"Search sessions",style:{flex:1,fontSize:"var(--text-footnote)",color:"var(--text-primary)",background:"transparent",border:"none",outline:"none",padding:0,margin:0,lineHeight:1.4}}),R.trim()&&(0,n.jsx)("button",{onClick:()=>L(""),"aria-label":"Clear search",style:{padding:2,borderRadius:"50%",display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0,background:"transparent",border:"none",cursor:"pointer",color:"var(--text-tertiary)"},children:(0,n.jsxs)("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",children:[(0,n.jsx)("line",{x1:"18",y1:"6",x2:"6",y2:"18"}),(0,n.jsx)("line",{x1:"6",y1:"6",x2:"18",y2:"18"})]})})]})]}),(0,n.jsx)("div",{style:{flex:1,overflowY:"auto",padding:"var(--space-1) 0"},children:C?(0,n.jsx)("div",{style:{padding:"var(--space-8) var(--space-4)",textAlign:"center"},children:(0,n.jsx)("span",{style:{fontSize:"var(--text-caption1)",color:"var(--text-quaternary)"},children:"Loading sessions..."})}):0===$.length?(0,n.jsx)("div",{style:{padding:"var(--space-8) var(--space-4)",textAlign:"center"},children:(0,n.jsx)("span",{style:{fontSize:"var(--text-caption1)",color:"var(--text-quaternary)"},children:R.trim()?"No matching sessions":"No conversations yet"})}):$.map(e=>{let t=O.has(e.key);return(0,n.jsxs)("div",{children:[(0,n.jsxs)("div",{onMouseEnter:()=>A(e.key),onMouseLeave:()=>A(null),style:{display:"flex",alignItems:"center",marginTop:"var(--space-1)"},children:[(0,n.jsxs)("button",{onClick:()=>K(e.key),style:{flex:1,display:"flex",alignItems:"center",gap:"var(--space-2)",padding:"var(--space-2) var(--space-4)",paddingRight:"var(--space-1)",background:"transparent",border:"none",cursor:"pointer",textAlign:"left"},children:[(0,n.jsx)("span",{style:{fontSize:"var(--text-caption1)"},children:e.emoji}),(0,n.jsx)("span",{style:{fontSize:"var(--text-caption1)",fontWeight:"var(--weight-semibold)",color:"var(--text-secondary)",letterSpacing:"0.3px",textTransform:"uppercase",flex:1},children:e.label}),(0,n.jsx)("span",{style:{fontSize:"var(--text-caption2)",color:"var(--text-tertiary)",background:"var(--fill-tertiary)",borderRadius:"var(--radius-sm)",padding:"0 5px",lineHeight:"18px",minWidth:18,textAlign:"center"},children:e.sessions.length}),(0,n.jsx)("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"var(--text-tertiary)",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round",style:{flexShrink:0,transition:"transform 150ms ease",transform:t?"rotate(-90deg)":"rotate(0deg)"},children:(0,n.jsx)("polyline",{points:"6 9 12 15 18 9"})})]}),E===e.key&&(0,n.jsx)("button",{onClick:t=>{t.stopPropagation(),T(e)},"aria-label":"Delete all sessions in ".concat(e.label),style:{padding:4,marginRight:"var(--space-3)",borderRadius:"var(--radius-sm)",background:"transparent",border:"none",cursor:"pointer",color:"var(--text-tertiary)",display:"flex",alignItems:"center",flexShrink:0,transition:"color 150ms ease"},onMouseEnter:e=>e.currentTarget.style.color="var(--system-red)",onMouseLeave:e=>e.currentTarget.style.color="var(--text-tertiary)",children:(0,n.jsxs)("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,n.jsx)("polyline",{points:"3 6 5 6 21 6"}),(0,n.jsx)("path",{d:"M19 6v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6m3 0V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2"})]})})]}),!t&&e.sessions.map(e=>{var t,a;let s,o=e.id===r,l=e.id===M,d="running"===e.status,c=U.has(e.id),u="error"===e.status,p=F.has(e.id),h=function(e){if(!e)return"";let t=new Date(e),r=Date.now()-t.getTime();return r<6e4?"now":r<36e5?"".concat(Math.floor(r/6e4),"m"):r<864e5?new Date(e).toLocaleTimeString("en-US",{hour:"numeric",minute:"2-digit",hour12:!0}):new Date(e).toLocaleDateString("en-US",{month:"short",day:"numeric"})}(e.lastActivity||e.createdAt);return s=d?"var(--system-blue)":u?"var(--system-red)":c?"var(--text-quaternary)":"var(--system-green)",(0,n.jsxs)("button",{onClick:()=>i(e.id),onMouseEnter:()=>B(e.id),onMouseLeave:()=>B(null),style:{width:"100%",display:"flex",alignItems:"center",gap:"var(--space-3)",padding:"var(--space-3) var(--space-4)",paddingLeft:"calc(var(--space-4) + 8px)",background:o?"var(--fill-secondary)":"transparent",border:"none",cursor:"pointer",textAlign:"left",borderLeft:o?"2px solid var(--accent)":"2px solid transparent",position:"relative"},children:[(0,n.jsx)("div",{style:{width:8,height:8,borderRadius:"50%",background:s,flexShrink:0,animation:d?"sidebar-pulse 2s ease-in-out infinite":"none",boxShadow:d?"0 0 6px ".concat(s):"none"}}),(0,n.jsxs)("div",{style:{flex:1,minWidth:0},children:[(0,n.jsxs)("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"baseline",marginBottom:2},children:[(0,n.jsx)("span",{style:{fontSize:"var(--text-footnote)",fontWeight:c&&!o?"var(--weight-medium)":"var(--weight-semibold)",color:"var(--text-primary)",letterSpacing:"-0.2px",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap",flex:1,minWidth:0},children:(t=e.title,a=e.employee,t?"Jinn"!==j&&t.startsWith("Jinn - ")?j+t.slice(4):t:a||j)}),(0,n.jsx)("span",{style:{fontSize:"var(--text-caption2)",color:"var(--text-tertiary)",flexShrink:0,marginLeft:"var(--space-1)"},children:h})]}),(0,n.jsx)("div",{style:{fontSize:"var(--text-caption1)",color:"var(--text-tertiary)",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:e.employee||j})]}),p&&!l&&(0,n.jsx)("span",{style:{fontSize:11,flexShrink:0,opacity:.5},children:"\uD83D\uDCCC"}),l&&(0,n.jsxs)(n.Fragment,{children:[(0,n.jsx)("button",{onClick:t=>{t.stopPropagation(),Y(e.id)},"aria-label":p?"Unpin session":"Pin session",style:{padding:4,borderRadius:"var(--radius-sm)",background:"transparent",border:"none",cursor:"pointer",color:p?"var(--accent)":"var(--text-tertiary)",display:"flex",alignItems:"center",flexShrink:0,transition:"color 150ms ease"},onMouseEnter:e=>{p||(e.currentTarget.style.color="var(--accent)")},onMouseLeave:e=>{p||(e.currentTarget.style.color="var(--text-tertiary)")},children:(0,n.jsxs)("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:p?"currentColor":"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,n.jsx)("path",{d:"M12 17v5"}),(0,n.jsx)("path",{d:"M9 2h6l-1 7h4l-2 4H8l-2-4h4L9 2z"})]})}),(0,n.jsx)("button",{onClick:t=>{t.stopPropagation(),z(e.id)},"aria-label":"Delete session",style:{padding:4,borderRadius:"var(--radius-sm)",background:"transparent",border:"none",cursor:"pointer",color:"var(--text-tertiary)",display:"flex",alignItems:"center",flexShrink:0,transition:"color 150ms ease"},onMouseEnter:e=>e.currentTarget.style.color="var(--system-red)",onMouseLeave:e=>e.currentTarget.style.color="var(--text-tertiary)",children:(0,n.jsxs)("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,n.jsx)("polyline",{points:"3 6 5 6 21 6"}),(0,n.jsx)("path",{d:"M19 6v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6m3 0V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2"})]})})]})]},e.id)})]},e.key)})}),W&&(0,n.jsx)("div",{style:{position:"fixed",top:0,left:0,right:0,bottom:0,background:"rgba(0,0,0,0.5)",zIndex:60,display:"flex",alignItems:"center",justifyContent:"center"},onClick:()=>z(null),children:(0,n.jsxs)("div",{style:{background:"var(--bg)",borderRadius:"var(--radius-lg)",padding:"var(--space-6)",maxWidth:400,width:"90%",boxShadow:"var(--shadow-overlay)"},onClick:e=>e.stopPropagation(),children:[(0,n.jsx)("h3",{style:{fontSize:"var(--text-headline)",fontWeight:"var(--weight-bold)",color:"var(--text-primary)",marginBottom:"var(--space-2)"},children:"Delete Session?"}),(0,n.jsx)("p",{style:{fontSize:"var(--text-body)",color:"var(--text-secondary)",marginBottom:"var(--space-5)"},children:"This will permanently delete the session and all its messages."}),(0,n.jsxs)("div",{style:{display:"flex",gap:"var(--space-3)",justifyContent:"flex-end"},children:[(0,n.jsx)("button",{onClick:()=>z(null),style:{padding:"var(--space-2) var(--space-4)",borderRadius:"var(--radius-md)",background:"var(--fill-tertiary)",color:"var(--text-primary)",border:"none",cursor:"pointer",fontSize:"var(--text-body)"},children:"Cancel"}),(0,n.jsx)("button",{onClick:()=>G(W),style:{padding:"var(--space-2) var(--space-4)",borderRadius:"var(--radius-md)",background:"var(--system-red)",color:"#fff",border:"none",cursor:"pointer",fontSize:"var(--text-body)",fontWeight:"var(--weight-semibold)"},children:"Delete"})]})]})}),D&&(0,n.jsx)("div",{style:{position:"fixed",top:0,left:0,right:0,bottom:0,background:"rgba(0,0,0,0.5)",zIndex:60,display:"flex",alignItems:"center",justifyContent:"center"},onClick:()=>T(null),children:(0,n.jsxs)("div",{style:{background:"var(--bg)",borderRadius:"var(--radius-lg)",padding:"var(--space-6)",maxWidth:400,width:"90%",boxShadow:"var(--shadow-overlay)"},onClick:e=>e.stopPropagation(),children:[(0,n.jsx)("h3",{style:{fontSize:"var(--text-headline)",fontWeight:"var(--weight-bold)",color:"var(--text-primary)",marginBottom:"var(--space-2)"},children:"Delete Group?"}),(0,n.jsxs)("p",{style:{fontSize:"var(--text-body)",color:"var(--text-secondary)",marginBottom:"var(--space-5)"},children:["Delete all ",D.sessions.length," chats in “",D.label,"”? This cannot be undone."]}),(0,n.jsxs)("div",{style:{display:"flex",gap:"var(--space-3)",justifyContent:"flex-end"},children:[(0,n.jsx)("button",{onClick:()=>T(null),style:{padding:"var(--space-2) var(--space-4)",borderRadius:"var(--radius-md)",background:"var(--fill-tertiary)",color:"var(--text-primary)",border:"none",cursor:"pointer",fontSize:"var(--text-body)"},children:"Cancel"}),(0,n.jsxs)("button",{onClick:()=>X(D),style:{padding:"var(--space-2) var(--space-4)",borderRadius:"var(--radius-md)",background:"var(--system-red)",color:"#fff",border:"none",cursor:"pointer",fontSize:"var(--text-body)",fontWeight:"var(--weight-semibold)"},children:["Delete ",D.sessions.length," Chats"]})]})]})}),(0,n.jsx)("style",{children:"\n @keyframes sidebar-pulse {\n 0%, 100% { opacity: 1; transform: scale(1); }\n 50% { opacity: 0.5; transform: scale(0.85); }\n }\n "})]})}let m="jinn-intermediate-";function f(e){try{localStorage.removeItem("".concat(m).concat(e))}catch(e){}}function y(e){let{name:t,size:r,mimeType:a,url:i,isUser:s}=e;return(0,n.jsxs)("div",{style:{display:"flex",alignItems:"center",gap:"var(--space-3)",padding:"var(--space-3) var(--space-4)",borderRadius:"var(--radius-lg)",background:s?"var(--accent)":"var(--material-thin)",border:s?"none":"1px solid var(--separator)",maxWidth:280,minWidth:180},children:[(0,n.jsx)("div",{style:{width:36,height:36,borderRadius:"var(--radius-sm)",background:s?"rgba(0,0,0,0.15)":"var(--fill-tertiary)",display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0,color:s?"#000":"var(--text-secondary)"},children:function(e,t){var r;let a=(null==t||null==(r=t.split(".").pop())?void 0:r.toLowerCase())||"",i="application/pdf"===e||"pdf"===a,s=["doc","docx"].includes(a)||(null==e?void 0:e.includes("wordprocessingml")),o=["txt","csv","json","md"].includes(a)||(null==e?void 0:e.startsWith("text/")),l=["zip","tar","gz","rar","7z"].includes(a);return i?(0,n.jsxs)("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,n.jsx)("path",{d:"M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"}),(0,n.jsx)("polyline",{points:"14 2 14 8 20 8"}),(0,n.jsx)("line",{x1:"9",y1:"15",x2:"15",y2:"15"})]}):s?(0,n.jsxs)("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,n.jsx)("path",{d:"M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"}),(0,n.jsx)("polyline",{points:"14 2 14 8 20 8"}),(0,n.jsx)("line",{x1:"16",y1:"13",x2:"8",y2:"13"}),(0,n.jsx)("line",{x1:"16",y1:"17",x2:"8",y2:"17"}),(0,n.jsx)("polyline",{points:"10 9 9 9 8 9"})]}):o?(0,n.jsxs)("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,n.jsx)("path",{d:"M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z"}),(0,n.jsx)("polyline",{points:"14 2 14 8 20 8"})]}):l?(0,n.jsxs)("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,n.jsx)("path",{d:"M21 8v13H3V8"}),(0,n.jsx)("path",{d:"M1 3h22v5H1z"}),(0,n.jsx)("path",{d:"M10 12h4"})]}):(0,n.jsxs)("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,n.jsx)("path",{d:"M13 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V9z"}),(0,n.jsx)("polyline",{points:"13 2 13 9 20 9"})]})}(a,t)}),(0,n.jsxs)("div",{style:{flex:1,minWidth:0},children:[(0,n.jsx)("div",{style:{fontSize:"var(--text-footnote)",fontWeight:"var(--weight-medium)",color:s?"#000":"var(--text-primary)",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:t}),null!=r&&(0,n.jsx)("div",{style:{fontSize:"var(--text-caption2)",color:s?"rgba(0,0,0,0.5)":"var(--text-tertiary)",marginTop:1},children:r<1024?"".concat(r," B"):r<1048576?"".concat((r/1024).toFixed(0)," KB"):"".concat((r/1048576).toFixed(1)," MB")})]}),(0,n.jsx)("a",{href:i,download:t,"aria-label":"Download ".concat(t),style:{width:28,height:28,borderRadius:"50%",background:s?"rgba(0,0,0,0.15)":"var(--fill-secondary)",display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0,color:s?"#000":"var(--text-secondary)",textDecoration:"none"},children:(0,n.jsxs)("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,n.jsx)("path",{d:"M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4"}),(0,n.jsx)("polyline",{points:"7 10 12 15 17 10"}),(0,n.jsx)("line",{x1:"12",y1:"15",x2:"12",y2:"3"})]})})]})}function b(e){let{src:t,duration:r,waveform:i,isUser:s}=e,o=(0,a.useRef)(null),[l,d]=(0,a.useState)(!1),[c,u]=(0,a.useState)(0),[p,h]=(0,a.useState)(0);(0,a.useEffect)(()=>{let e=new Audio(t);return o.current=e,e.addEventListener("timeupdate",()=>{e.duration&&isFinite(e.duration)&&(u(e.currentTime/e.duration),h(e.currentTime))}),e.addEventListener("ended",()=>{d(!1),u(0),h(0)}),e.addEventListener("pause",()=>d(!1)),e.addEventListener("play",()=>d(!0)),()=>{e.pause(),e.src=""}},[t]);let g=(0,a.useCallback)(()=>{let e=o.current;e&&(l?e.pause():e.play().catch(()=>{}))},[l]),v=i.length>0?i:Array(50).fill(.1),x=l?p:r;return(0,n.jsxs)("div",{style:{display:"flex",alignItems:"center",gap:"var(--space-3)",padding:"var(--space-3) var(--space-4)",borderRadius:"var(--radius-lg)",background:s?"var(--accent)":"var(--material-thin)",border:s?"none":"1px solid var(--separator)",maxWidth:280,minWidth:200},children:[(0,n.jsx)("button",{onClick:g,"aria-label":l?"Pause":"Play",style:{width:28,height:28,borderRadius:"50%",background:s?"rgba(0,0,0,0.2)":"var(--fill-secondary)",border:"none",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0,color:s?"#000":"var(--text-primary)"},children:l?(0,n.jsxs)("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"currentColor",children:[(0,n.jsx)("rect",{x:"6",y:"4",width:"4",height:"16",rx:"1"}),(0,n.jsx)("rect",{x:"14",y:"4",width:"4",height:"16",rx:"1"})]}):(0,n.jsx)("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"currentColor",children:(0,n.jsx)("polygon",{points:"6,4 20,12 6,20"})})}),(0,n.jsx)("div",{style:{flex:1,display:"flex",alignItems:"center",gap:2,height:28},children:v.map((e,t)=>{let r=t/v.length<=c;return(0,n.jsx)("div",{style:{width:3,borderRadius:1.5,height:"".concat(Math.max(4,24*e),"px"),background:s?r?"rgba(0,0,0,0.7)":"rgba(0,0,0,0.25)":r?"var(--accent)":"var(--fill-primary)",transition:"background 100ms ease",flexShrink:0}},t)})}),(0,n.jsx)("span",{style:{fontSize:"var(--text-caption2)",color:s?"rgba(0,0,0,0.6)":"var(--text-tertiary)",fontVariantNumeric:"tabular-nums",flexShrink:0,minWidth:28,textAlign:"right"},children:function(e){let t=Math.floor(e/60),r=Math.floor(e%60);return"".concat(t,":").concat(r.toString().padStart(2,"0"))}(x)})]})}function j(e){let{msgs:t,isActive:r}=e,[i,s]=(0,a.useState)(!1),o=t.every(e=>e.content.startsWith("Used ")),l=r&&!o?"".concat(t.length," tool").concat(1!==t.length?"s":""," running…"):"".concat(t.length," tool").concat(1!==t.length?"s":""," used");return(0,n.jsxs)("div",{style:{padding:"0 var(--space-4)",marginBottom:"var(--space-1)"},children:[(0,n.jsxs)("button",{onClick:()=>s(e=>!e),style:{display:"flex",alignItems:"center",gap:"var(--space-2)",padding:"5px var(--space-3)",borderRadius:"var(--radius-full, 999px)",background:"var(--fill-secondary)",border:"1px solid var(--separator)",fontSize:"var(--text-caption1)",color:"var(--text-secondary)",cursor:"pointer",transition:"background 150ms ease"},onMouseEnter:e=>e.currentTarget.style.background="var(--fill-tertiary)",onMouseLeave:e=>e.currentTarget.style.background="var(--fill-secondary)",children:[(0,n.jsx)("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",style:{opacity:.6},children:(0,n.jsx)("path",{d:"M14.7 6.3a1 1 0 0 0 0 1.4l1.6 1.6a1 1 0 0 0 1.4 0l3.77-3.77a6 6 0 0 1-7.94 7.94l-6.91 6.91a2.12 2.12 0 0 1-3-3l6.91-6.91a6 6 0 0 1 7.94-7.94l-3.76 3.76z"})}),l,r&&!o&&(0,n.jsx)("span",{style:{width:6,height:6,borderRadius:"50%",background:"var(--system-blue)",animation:"jinn-pulse 1.4s infinite"}}),(0,n.jsx)("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round",style:{transform:i?"rotate(180deg)":"rotate(0deg)",transition:"transform 150ms ease",opacity:.5},children:(0,n.jsx)("polyline",{points:"6 9 12 15 18 9"})})]}),i&&(0,n.jsx)("div",{style:{display:"flex",flexWrap:"wrap",gap:"var(--space-1)",marginTop:"var(--space-1)",paddingLeft:"var(--space-1)"},children:t.map(e=>(0,n.jsx)("span",{style:{display:"inline-flex",alignItems:"center",gap:4,padding:"2px 8px",borderRadius:"var(--radius-full, 999px)",background:"var(--fill-tertiary)",border:"1px solid var(--separator)",fontSize:"var(--text-caption2)",color:"var(--text-tertiary)"},children:e.toolCall},e.id))})]})}function k(e){let t,r=[],a=/(https?:\/\/[^\s<]+[^\s<.,;:!?)}\]'"])|(\*\*(.+?)\*\*)|(`([^`]+)`)|\*([^*]+)\*/g,i=0;for(;null!==(t=a.exec(e));)t.index>i&&r.push(e.slice(i,t.index)),t[1]?r.push((0,n.jsx)("a",{href:t[1],target:"_blank",rel:"noopener noreferrer",style:{color:"var(--system-blue)",textDecoration:"underline",textUnderlineOffset:2},children:t[1]},t.index)):t[2]?r.push((0,n.jsx)("strong",{style:{fontWeight:"var(--weight-bold)"},children:t[3]},t.index)):t[4]?r.push((0,n.jsx)("code",{style:{background:"var(--fill-secondary)",border:"1px solid var(--separator)",borderRadius:5,padding:"1px 5px",fontSize:"0.88em",fontFamily:'"SF Mono", Menlo, monospace',color:"var(--accent)"},children:t[5]},t.index)):t[6]&&r.push((0,n.jsx)("em",{style:{fontStyle:"italic",opacity:.85},children:t[6]},t.index)),i=t.index+t[0].length;return i<e.length&&r.push(e.slice(i)),1===r.length?r[0]:(0,n.jsx)(n.Fragment,{children:r})}function w(e){let{code:t,keyProp:r}=e,[i,s]=(0,a.useState)(!1);return(0,n.jsxs)("div",{style:{position:"relative",margin:"8px 0"},children:[(0,n.jsx)("button",{onClick:function(){navigator.clipboard.writeText(t).then(()=>{s(!0),setTimeout(()=>s(!1),1500)})},"aria-label":"Copy code",style:{position:"absolute",top:8,right:8,padding:"2px 8px",fontSize:11,borderRadius:"var(--radius-sm)",background:"var(--fill-secondary)",color:"var(--text-secondary)",border:"1px solid var(--separator)",cursor:"pointer"},children:i?"Copied!":"Copy"}),(0,n.jsx)("pre",{className:"code-block",style:{background:"var(--fill-tertiary)",border:"1px solid var(--separator)",borderRadius:"var(--radius-md)",padding:"var(--space-3) var(--space-4)",overflowX:"auto",fontSize:13,lineHeight:1.5,fontFamily:'"SF Mono", Menlo, monospace',color:"var(--text-primary)"},children:(0,n.jsx)("code",{children:t})})]},r)}function S(e){return/^\|[\s:|-]+\|$/.test(e.trim())}function C(e){return e.trim().replace(/^\|/,"").replace(/\|$/,"").split("|").map(e=>e.trim())}function I(e){let{headerLine:t,rows:r,keyProp:a}=e,i=C(t),s=r.map(C);return(0,n.jsx)("div",{style:{margin:"10px 0",borderRadius:10,border:"1px solid var(--separator)",overflow:"hidden"},children:(0,n.jsx)("div",{style:{overflowX:"auto",WebkitOverflowScrolling:"touch"},children:(0,n.jsxs)("table",{style:{borderCollapse:"collapse",fontSize:"var(--text-footnote)",lineHeight:1.6,width:"100%",minWidth:"max-content"},children:[(0,n.jsx)("thead",{children:(0,n.jsx)("tr",{style:{background:"var(--fill-tertiary)"},children:i.map((e,t)=>(0,n.jsx)("th",{style:{textAlign:"left",padding:"10px 16px",fontWeight:600,color:"var(--text-primary)",borderBottom:"1px solid var(--separator)",maxWidth:280,wordBreak:"break-word"},children:k(e)},t))})}),(0,n.jsx)("tbody",{children:s.map((e,t)=>(0,n.jsx)("tr",{style:{background:t%2==1?"var(--fill-quaternary, transparent)":"transparent"},children:e.map((e,r)=>(0,n.jsx)("td",{style:{padding:"10px 16px",borderBottom:t<s.length-1?"1px solid var(--separator)":"none",color:"var(--text-primary)",maxWidth:280,wordBreak:"break-word"},children:k(e)},r))},t))})]})})},a)}function R(e){if(!e)return null;let t=e.split("\n"),r=[],a=!1,i=[];for(let e=0;e<t.length;e++){let o=t[e];if(o.startsWith("```")){a?(a=!1,r.push((0,n.jsx)(w,{keyProp:e,code:i.join("\n")},e))):a=!0,i=[];continue}if(a){i.push(o);continue}if(o.trim().startsWith("|")&&o.trim().endsWith("|")&&e+1<t.length&&S(t[e+1])){e++;let a=[];for(;e+1<t.length&&t[e+1].trim().startsWith("|")&&t[e+1].trim().endsWith("|")&&!S(t[e+1]);)e++,a.push(t[e]);r.push((0,n.jsx)(I,{keyProp:e,headerLine:o,rows:a},"table-".concat(e)));continue}if(""===o.trim()){r.push((0,n.jsx)("div",{style:{height:6}},"space-".concat(e)));continue}if(o.match(/^[-*] /)){r.push((0,n.jsxs)("div",{style:{display:"flex",gap:"var(--space-2)",marginBottom:2},children:[(0,n.jsx)("span",{style:{color:"var(--accent)",flexShrink:0,marginTop:1},children:"•"}),(0,n.jsx)("span",{children:k(o.slice(2))})]},e));continue}if(o.match(/^\d+\. /)){var s;let t=null==(s=o.match(/^(\d+)\. /))?void 0:s[1];r.push((0,n.jsxs)("div",{style:{display:"flex",gap:"var(--space-2)",marginBottom:2},children:[(0,n.jsxs)("span",{style:{color:"var(--accent)",flexShrink:0,fontWeight:"var(--weight-semibold)",minWidth:16},children:[t,"."]}),(0,n.jsx)("span",{children:k(o.replace(/^\d+\. /,""))})]},e));continue}if(o.startsWith("### ")){r.push((0,n.jsx)("div",{style:{fontWeight:"var(--weight-semibold)",fontSize:"var(--text-footnote)",marginTop:"var(--space-2)",marginBottom:2},children:k(o.slice(4))},e));continue}if(o.startsWith("## ")){r.push((0,n.jsx)("div",{style:{fontWeight:"var(--weight-bold)",fontSize:"var(--text-subheadline)",marginTop:"var(--space-3)",marginBottom:3},children:k(o.slice(3))},e));continue}if(o.startsWith("# ")){r.push((0,n.jsx)("div",{style:{fontWeight:"var(--weight-bold)",fontSize:"var(--text-body)",marginTop:"var(--space-3)",marginBottom:"var(--space-1)"},children:k(o.slice(2))},e));continue}r.push((0,n.jsx)("div",{style:{marginBottom:1},children:k(o)},e))}return a&&i.length>0&&r.push((0,n.jsx)(w,{keyProp:999,code:i.join("\n")},"trailing-code")),(0,n.jsx)(n.Fragment,{children:r})}function L(e){let t=new Date,r=new Date(e),n=t.toDateString()===r.toDateString(),a=new Date(t);a.setDate(a.getDate()-1);let i=a.toDateString()===r.toDateString(),s=r.toLocaleTimeString("en-US",{hour:"numeric",minute:"2-digit",hour12:!0});return n?"Today ".concat(s):i?"Yesterday ".concat(s):r.toLocaleDateString("en-US",{month:"short",day:"numeric"})+" ".concat(s)}function W(e,t){return 0===t||e[t].timestamp-e[t-1].timestamp>3e5}function z(e,t){let r=e.filter(e=>"image"===e.type),a=e.filter(e=>"audio"===e.type),i=e.filter(e=>"file"===e.type);return(0,n.jsxs)(n.Fragment,{children:[r.map((e,t)=>(0,n.jsx)("div",{style:{marginTop:"var(--space-2)",borderRadius:"var(--radius-lg)",overflow:"hidden",maxWidth:280},children:(0,n.jsx)("img",{src:e.url,alt:e.name||"Image",style:{width:"100%",display:"block",borderRadius:"var(--radius-lg)",cursor:"pointer"},onClick:()=>window.open(e.url,"_blank")})},"img-".concat(t))),a.map((e,r)=>(0,n.jsx)("div",{style:{marginTop:"var(--space-2)"},children:(0,n.jsx)(b,{src:e.url,duration:e.duration||0,waveform:e.waveform||[],isUser:t})},"audio-".concat(r))),i.map((e,r)=>(0,n.jsx)("div",{style:{marginTop:"var(--space-2)"},children:(0,n.jsx)(y,{name:e.name||"File",size:e.size,mimeType:e.mimeType,url:e.url,isUser:t})},"file-".concat(r)))]})}function D(e){var t,r;let{messages:i,loading:s,streamingText:o}=e,l=(0,a.useRef)(null),d=(0,a.useRef)(0);return((0,a.useEffect)(()=>{var e;let t=0===d.current&&i.length>0;null==(e=l.current)||e.scrollIntoView({behavior:t?"instant":"smooth"}),d.current=i.length},[i,s]),0!==i.length||s)?(0,n.jsxs)("div",{className:"chat-messages-scroll",style:{flex:1,overflowY:"auto",overflowX:"hidden",padding:"var(--space-3) 0 var(--space-6) 0",background:"var(--bg)",minHeight:0},children:[(function(e){let t=[],r=0;for(;r<e.length;)if("assistant"===e[r].role&&e[r].toolCall){let n=[],a=r;for(;r<e.length&&"assistant"===e[r].role&&e[r].toolCall;)n.push(e[r]),r++;t.push({kind:"tool-group",msgs:n,startIndex:a})}else t.push({kind:"message",msg:e[r],index:r}),r++;return t})(i).map(e=>{if("tool-group"===e.kind){let t=e.msgs[0],r=W(i,e.startIndex),a=e.startIndex>0?i[e.startIndex-1]:null,o=s&&e.startIndex+e.msgs.length===i.length;return(0,n.jsxs)("div",{children:[r&&(0,n.jsx)("div",{style:{textAlign:"center",padding:"var(--space-3) 0",fontSize:"var(--text-caption2)",color:"var(--text-tertiary)"},children:L(t.timestamp)}),!r&&a&&(0,n.jsx)("div",{style:{height:"assistant"!==a.role?"var(--space-4)":"var(--space-1)"}}),(0,n.jsx)(j,{msgs:e.msgs,isActive:o})]},"tg-".concat(e.startIndex))}let{msg:t,index:r}=e,a="user"===t.role,o=W(i,r),l=t.media||function(e){let t,r=[],n=/!\[([^\]]*)\]\((https?:\/\/[^)]+\.(jpg|jpeg|png|gif|webp|svg)(\?[^)]*)?)\)/gi;for(;null!==(t=n.exec(e));)r.push({type:"image",url:t[2],name:t[1]||"Image"});let a=RegExp("(?<!\\]\\()https?:\\/\\/\\S+\\.(jpg|jpeg|png|gif|webp)(\\?\\S*)?\\b","gi");for(;null!==(t=a.exec(e));){let e=t[0];r.find(t=>t.url===e)||r.push({type:"image",url:e})}let i=/https?:\/\/\S+\.(mp3|wav|ogg|m4a|aac)(\?\S*)?\b/gi;for(;null!==(t=i.exec(e));)r.push({type:"audio",url:t[0],name:t[0].split("/").pop()});return r}(t.content),d=t.content;return l.length>0&&!t.media&&(l.forEach(e=>{d=(d=d.replace(e.url,"")).replace(/!\[[^\]]*\]\([^)]+\)/g,"")}),d=d.trim()),t.media&&t.media.length>0&&d.startsWith("[")&&d.endsWith("]")&&(d=""),(0,n.jsxs)("div",{children:[o&&(0,n.jsx)("div",{style:{textAlign:"center",padding:"var(--space-3) 0",fontSize:"var(--text-caption2)",color:"var(--text-tertiary)"},children:L(t.timestamp)}),!o&&r>0&&(0,n.jsx)("div",{style:{height:i[r-1].role!==t.role?"var(--space-4)":"var(--space-1)"}}),a&&(0,n.jsxs)("div",{style:{display:"flex",flexDirection:"column",alignItems:"flex-end",padding:"0 var(--space-4)",marginBottom:"var(--space-1)"},children:[d&&(0,n.jsx)("div",{className:"user-msg-bubble",style:{padding:"var(--space-3) var(--space-4)",borderRadius:"var(--radius-lg) var(--radius-lg) var(--radius-sm) var(--radius-lg)",background:"var(--accent)",color:"var(--accent-contrast)",fontSize:"var(--text-subheadline)",lineHeight:"var(--leading-relaxed)",fontWeight:"var(--weight-medium)",boxShadow:"var(--shadow-subtle)"},children:R(d)}),l.length>0&&(0,n.jsx)("div",{className:"user-msg-bubble",children:z(l,!0)})]}),!a&&(0,n.jsx)("div",{className:"assistant-msg-row",style:{display:"flex",justifyContent:"flex-start",padding:"0 var(--space-4)",marginBottom:"var(--space-1)"},children:(0,n.jsxs)("div",{className:"assistant-msg-bubble",style:{display:"flex",flexDirection:"column"},children:[d&&(0,n.jsx)("div",{style:{padding:"var(--space-3) var(--space-4)",borderRadius:"var(--radius-sm) var(--radius-lg) var(--radius-lg) var(--radius-lg)",background:"var(--material-thin)",border:"1px solid var(--separator)",color:"var(--text-primary)",fontSize:"var(--text-subheadline)",lineHeight:"var(--leading-relaxed)"},children:R(d)}),l.length>0&&z(l,!1)]})})]},t.id||r)}),o&&(0,n.jsx)("div",{style:{display:"flex",justifyContent:"flex-start",padding:"0 var(--space-4)",marginBottom:"var(--space-1)"},className:"assistant-msg-row",children:(0,n.jsx)("div",{className:"assistant-msg-bubble",style:{display:"flex",flexDirection:"column"},children:(0,n.jsx)("div",{style:{padding:"var(--space-3) var(--space-4)",borderRadius:"var(--radius-sm) var(--radius-lg) var(--radius-lg) var(--radius-lg)",background:"var(--material-thin)",border:"1px solid var(--separator)",color:"var(--text-primary)",fontSize:"var(--text-subheadline)",lineHeight:"var(--leading-relaxed)"},children:R(function(e){let t=e,r=(t.match(/```/g)||[]).length;if(r%2!=0&&(t+="\n```"),r%2==0){let e=t.replace(/```[\s\S]*?```/g,"");(e.match(/`/g)||[]).length%2!=0&&(t+="`"),(e.match(/\*\*/g)||[]).length%2!=0&&(t+="**")}return t}(o))})})}),s&&!o&&i.length>0&&((null==(t=i[i.length-1])?void 0:t.role)==="user"||(null==(r=i[i.length-1])?void 0:r.toolCall))&&(0,n.jsx)("div",{style:{display:"flex",justifyContent:"flex-start",padding:"0 var(--space-4)",marginTop:"var(--space-2)"},children:(0,n.jsx)("div",{style:{padding:"var(--space-3) var(--space-4)",borderRadius:"var(--radius-sm) var(--radius-lg) var(--radius-lg) var(--radius-lg)",background:"var(--material-thin)",border:"1px solid var(--separator)"},children:(0,n.jsxs)("div",{style:{display:"flex",gap:4,alignItems:"center",height:16},children:[(0,n.jsx)("span",{style:{width:6,height:6,borderRadius:"50%",background:"var(--text-quaternary)",animation:"jinn-pulse 1.4s infinite",animationDelay:"0ms"}}),(0,n.jsx)("span",{style:{width:6,height:6,borderRadius:"50%",background:"var(--text-quaternary)",animation:"jinn-pulse 1.4s infinite",animationDelay:"200ms"}}),(0,n.jsx)("span",{style:{width:6,height:6,borderRadius:"50%",background:"var(--text-quaternary)",animation:"jinn-pulse 1.4s infinite",animationDelay:"400ms"}})]})})}),(0,n.jsx)("div",{ref:l}),(0,n.jsx)("style",{children:"\n @keyframes jinn-pulse {\n 0%, 80%, 100% { opacity: 0.3; transform: scale(0.8); }\n 40% { opacity: 1; transform: scale(1); }\n }\n .assistant-msg-bubble { max-width: 100%; overflow-wrap: break-word; word-break: break-word; }\n .user-msg-bubble { max-width: 90%; overflow-wrap: break-word; word-break: break-word; }\n .assistant-msg-row { padding: 0 var(--space-2) !important; }\n @media (min-width: 1024px) {\n .assistant-msg-bubble { max-width: 75%; }\n .user-msg-bubble { max-width: 75%; }\n .assistant-msg-row { padding: 0 var(--space-4) !important; }\n }\n /* User message contrast fixes — ensure all child elements are visible on accent background */\n .user-msg-bubble code {\n background: rgba(255,255,255,0.2) !important;\n border-color: rgba(255,255,255,0.3) !important;\n color: inherit !important;\n }\n .user-msg-bubble .code-block,\n .user-msg-bubble pre {\n background: rgba(0,0,0,0.2) !important;\n border-color: rgba(255,255,255,0.15) !important;\n color: rgba(255,255,255,0.95) !important;\n }\n .user-msg-bubble a {\n color: inherit !important;\n text-decoration-color: rgba(255,255,255,0.6) !important;\n }\n .user-msg-bubble strong { color: inherit !important; }\n .user-msg-bubble em { color: inherit !important; opacity: 0.9; }\n .user-msg-bubble span { color: inherit !important; }\n .user-msg-bubble div { color: inherit !important; }\n .user-msg-bubble th, .user-msg-bubble td { color: inherit !important; }\n .user-msg-bubble table { border-color: rgba(255,255,255,0.2) !important; }\n .user-msg-bubble th { border-color: rgba(255,255,255,0.2) !important; }\n .user-msg-bubble td { border-color: rgba(255,255,255,0.15) !important; }\n .user-msg-bubble tr { background: transparent !important; }\n .user-msg-bubble thead tr { background: rgba(255,255,255,0.1) !important; }\n /* Selection visibility for user messages */\n .user-msg-bubble ::selection {\n background: rgba(255,255,255,0.35);\n color: inherit;\n }\n .user-msg-bubble ::-moz-selection {\n background: rgba(255,255,255,0.35);\n color: inherit;\n }\n "})]}):(0,n.jsx)("div",{style:{flex:1,display:"flex",alignItems:"center",justifyContent:"center"},children:(0,n.jsxs)("div",{style:{textAlign:"center"},children:[(0,n.jsx)("div",{style:{fontSize:"var(--text-title3)",fontWeight:"var(--weight-semibold)",color:"var(--text-tertiary)"},children:"Start a conversation"}),(0,n.jsx)("div",{style:{fontSize:"var(--text-footnote)",color:"var(--text-quaternary)",marginTop:"var(--space-2)"},children:"Send a message or use /new to begin"})]})})}function T(e){let{attachments:t,onRemove:r}=e;return 0===t.length?null:(0,n.jsx)("div",{style:{display:"flex",gap:"var(--space-2)",padding:"var(--space-2) var(--space-3)",overflowX:"auto",overflowY:"hidden"},children:t.map((e,t)=>{var a,i;return(0,n.jsxs)("div",{style:{position:"relative",width:56,height:56,flexShrink:0,borderRadius:"var(--radius-sm)",overflow:"hidden",background:"var(--fill-tertiary)",border:"1px solid var(--separator)"},children:["image"===e.type?(0,n.jsx)("img",{src:e.url,alt:e.name||"Preview",style:{width:"100%",height:"100%",objectFit:"cover"}}):(0,n.jsxs)("div",{style:{width:"100%",height:"100%",display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",gap:2,padding:4},children:["audio"===e.type?(0,n.jsxs)("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"var(--text-tertiary)",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,n.jsx)("path",{d:"M9 18V5l12-2v13"}),(0,n.jsx)("circle",{cx:"6",cy:"18",r:"3"}),(0,n.jsx)("circle",{cx:"18",cy:"16",r:"3"})]}):(0,n.jsxs)("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"var(--text-tertiary)",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,n.jsx)("path",{d:"M13 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V9z"}),(0,n.jsx)("polyline",{points:"13 2 13 9 20 9"})]}),(0,n.jsx)("span",{style:{fontSize:8,color:"var(--text-quaternary)",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap",maxWidth:"100%",textAlign:"center"},children:(null==(i=e.name)||null==(a=i.split(".").pop())?void 0:a.toUpperCase())||e.type.toUpperCase()})]}),(0,n.jsx)("button",{onClick:()=>r(t),"aria-label":"Remove attachment",style:{position:"absolute",top:2,right:2,width:18,height:18,borderRadius:"50%",background:"rgba(0,0,0,0.6)",border:"none",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",color:"#fff",fontSize:11,lineHeight:1,padding:0},children:(0,n.jsxs)("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"3",strokeLinecap:"round",children:[(0,n.jsx)("line",{x1:"18",y1:"6",x2:"6",y2:"18"}),(0,n.jsx)("line",{x1:"6",y1:"6",x2:"18",y2:"18"})]})})]},t)})})}function M(e){let{open:t,progress:r,onDownload:a,onCancel:i}=e;if(!t)return null;let s=null!==r;return(0,n.jsx)("div",{style:{position:"fixed",top:0,left:0,right:0,bottom:0,background:"rgba(0,0,0,0.5)",zIndex:60,display:"flex",alignItems:"center",justifyContent:"center"},onClick:s?void 0:i,children:(0,n.jsxs)("div",{style:{background:"var(--bg)",borderRadius:"var(--radius-lg)",padding:"var(--space-6)",maxWidth:400,width:"90%",boxShadow:"var(--shadow-overlay)"},onClick:e=>e.stopPropagation(),children:[(0,n.jsx)("div",{style:{width:48,height:48,borderRadius:"var(--radius-md)",background:"var(--fill-secondary)",display:"flex",alignItems:"center",justifyContent:"center",marginBottom:"var(--space-4)"},children:(0,n.jsxs)("svg",{width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"var(--text-secondary)",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,n.jsx)("path",{d:"M12 1a3 3 0 0 0-3 3v8a3 3 0 0 0 6 0V4a3 3 0 0 0-3-3z"}),(0,n.jsx)("path",{d:"M19 10v2a7 7 0 0 1-14 0v-2"}),(0,n.jsx)("line",{x1:"12",y1:"19",x2:"12",y2:"23"}),(0,n.jsx)("line",{x1:"8",y1:"23",x2:"16",y2:"23"})]})}),(0,n.jsx)("h3",{style:{fontSize:"var(--text-headline)",fontWeight:"var(--weight-bold)",color:"var(--text-primary)",marginBottom:"var(--space-2)"},children:"Enable voice input?"}),(0,n.jsx)("p",{style:{fontSize:"var(--text-body)",color:"var(--text-secondary)",marginBottom:"var(--space-5)",lineHeight:"var(--leading-relaxed)"},children:"This will download a speech recognition model (~500MB). Transcription runs locally on your server — no data leaves your network."}),s&&(0,n.jsxs)("div",{style:{marginBottom:"var(--space-5)"},children:[(0,n.jsxs)("div",{style:{display:"flex",justifyContent:"space-between",marginBottom:"var(--space-2)",fontSize:"var(--text-footnote)",color:"var(--text-tertiary)"},children:[(0,n.jsx)("span",{children:"Downloading model…"}),(0,n.jsxs)("span",{children:[r,"%"]})]}),(0,n.jsx)("div",{style:{height:6,borderRadius:3,background:"var(--fill-tertiary)",overflow:"hidden"},children:(0,n.jsx)("div",{style:{height:"100%",width:"".concat(r,"%"),borderRadius:3,background:"var(--accent)",transition:"width 300ms ease"}})})]}),(0,n.jsxs)("div",{style:{display:"flex",gap:"var(--space-3)",justifyContent:"flex-end"},children:[!s&&(0,n.jsx)("button",{onClick:i,style:{padding:"var(--space-2) var(--space-4)",borderRadius:"var(--radius-md)",background:"var(--fill-tertiary)",color:"var(--text-primary)",border:"none",cursor:"pointer",fontSize:"var(--text-body)"},children:"Cancel"}),(0,n.jsx)("button",{onClick:a,disabled:s,style:{padding:"var(--space-2) var(--space-4)",borderRadius:"var(--radius-md)",background:s?"var(--fill-tertiary)":"var(--accent)",color:s?"var(--text-tertiary)":"#000",border:"none",cursor:s?"default":"pointer",fontSize:"var(--text-body)",fontWeight:"var(--weight-semibold)"},children:s?"Downloading…":"Download"})]})]})})}function B(e){let{analyser:t,width:r=64,height:i=32,color:s="var(--system-red)"}=e,o=(0,a.useRef)(null),l=(0,a.useRef)(0);return(0,a.useEffect)(()=>{let e=o.current;if(!e||!t)return;let n=e.getContext("2d");if(!n)return;let a=t.frequencyBinCount,d=new Uint8Array(a),c=(r-22)/12;return!function e(){l.current=requestAnimationFrame(e),t.getByteFrequencyData(d),n.clearRect(0,0,r,i);for(let e=0;e<12;e++){let t=Math.max(3,d[Math.floor(e/12*(.6*a))]/255*i),r=e*(c+2),o=(i-t)/2;n.fillStyle=s,n.beginPath(),n.roundRect(r,o,c,t,1.5),n.fill()}}(),()=>{cancelAnimationFrame(l.current)}},[t,r,i,s]),(0,n.jsx)("canvas",{ref:o,width:r,height:i,style:{width:r,height:i,display:"block"}})}let E=[{name:"new",description:"Start a new chat session"},{name:"status",description:"Show current session info"}];async function A(e){let t,r=e.type.startsWith("image/"),n=e.type.startsWith("audio/");if(r)t=await new Promise((t,r)=>{let n=new Image,a=URL.createObjectURL(e);n.onload=()=>{URL.revokeObjectURL(a);let{width:i,height:s}=n;if(i>1200||s>1200){let e=1200/Math.max(i,s);i=Math.round(i*e),s=Math.round(s*e)}let o=document.createElement("canvas");o.width=i,o.height=s;let l=o.getContext("2d");if(!l)return void r(Error("no canvas context"));l.drawImage(n,0,0,i,s);let d=e.size>5e4?"image/jpeg":"image/png";t(o.toDataURL(d,"image/jpeg"===d?.85:void 0))},n.onerror=()=>{URL.revokeObjectURL(a),r(Error("image load failed"))},n.src=a});else t=await new Promise((t,r)=>{let n=new FileReader;n.onloadend=()=>t(n.result),n.onerror=r,n.readAsDataURL(e)});return{type:r?"image":n?"audio":"file",url:t,name:e.name,mimeType:e.type,size:t.length}}function U(e){let{disabled:t,loading:r,onSend:i,onInterrupt:o,onNewSession:l,onStatusRequest:d,skillsVersion:c,events:u}=e,[p,h]=(0,a.useState)(""),[g,v]=(0,a.useState)([]),[x,m]=(0,a.useState)(!1),[f,y]=(0,a.useState)(""),[b,j]=(0,a.useState)(0),[k,w]=(0,a.useState)(E),[S,C]=(0,a.useState)(!1),[I,R]=(0,a.useState)(""),[L,W]=(0,a.useState)(0),[z,D]=(0,a.useState)([]),U=(0,a.useRef)(null),N=(0,a.useRef)(null),F=(0,a.useRef)(new Map),H=function(e,t){let[r,n]=(0,a.useState)("idle"),[i,o]=(0,a.useState)(null),[l,d]=(0,a.useState)(null),[c,u]=(0,a.useState)(null),[p,h]=(0,a.useState)(["en"]),[g,v]=(0,a.useState)(null),[x,m]=(0,a.useState)(()=>localStorage.getItem("stt-language")||"en"),f=(0,a.useRef)(x);f.current=x;let y=(0,a.useRef)(null),b=(0,a.useRef)(null),j=(0,a.useRef)(null),k=(0,a.useRef)([]),w=(0,a.useRef)(null),S=(0,a.useRef)(null),C=(0,a.useRef)(t);C.current=t,(0,a.useEffect)(()=>{if(!e||0===e.length)return;let t=e[e.length-1];if(!t.event.startsWith("stt:"))return;let r=t.payload;"stt:download:progress"===t.event&&d(Number(r.progress)||0),"stt:download:complete"===t.event&&(d(null),o(!0),n("idle")),"stt:download:error"===t.event&&(d(null),n("idle"))},[e]);let I=(0,a.useCallback)(()=>{var e,t;null==(e=j.current)||e.getTracks().forEach(e=>e.stop()),j.current=null,null==(t=b.current)||t.close().catch(()=>{}),b.current=null,u(null),y.current=null},[]);(0,a.useEffect)(()=>()=>{var e,t,r;w.current&&clearTimeout(w.current),(null==(e=y.current)?void 0:e.state)==="recording"&&y.current.stop(),null==(t=j.current)||t.getTracks().forEach(e=>e.stop()),null==(r=b.current)||r.close().catch(()=>{})},[]);let R=(0,a.useCallback)(async()=>{try{var e;let t=await s.F.sttStatus();return o(t.available),t.downloading&&d(t.progress),(null==(e=t.languages)?void 0:e.length)>0&&(h(t.languages),m(e=>{if(!t.languages.includes(e)){let e=t.languages[0];return localStorage.setItem("stt-language",e),e}return e})),t.available}catch(e){return o(!1),!1}},[]),L=(0,a.useCallback)(async()=>{try{let e=await navigator.mediaDevices.getUserMedia({audio:!0});j.current=e;let t=new AudioContext;b.current=t;let r=t.createMediaStreamSource(e),a=t.createAnalyser();a.fftSize=128,r.connect(a),u(a);let i=MediaRecorder.isTypeSupported("audio/webm;codecs=opus")?"audio/webm;codecs=opus":MediaRecorder.isTypeSupported("audio/mp4")?"audio/mp4":"",o=new MediaRecorder(e,i?{mimeType:i}:void 0);y.current=o,k.current=[],o.ondataavailable=e=>{e.data.size>0&&k.current.push(e.data)},o.onstop=async()=>{I(),n("transcribing");let e=new Blob(k.current,{type:o.mimeType||"audio/webm"});if(k.current=[],0===e.size){var t;n("idle"),null==(t=S.current)||t.call(S,null),S.current=null;return}try{let t=(await s.F.sttTranscribe(e,f.current)).text||null;n("idle"),v(null),S.current?(S.current(t),S.current=null):t&&C.current&&C.current(t)}catch(t){let e=t instanceof Error?t.message:"Transcription failed";v(e),n("error"),S.current&&(S.current(null),S.current=null)}},o.start(5e3),n("recording"),w.current=setTimeout(()=>{var e;(null==(e=y.current)?void 0:e.state)==="recording"&&y.current.stop()},18e5)}catch(e){I(),n("idle")}},[I]),W=(0,a.useCallback)(async()=>{"recording"!==r&&"transcribing"!==r&&("error"===r&&(v(null),n("idle")),await R()?await L():n("no-model"))},[r,R,L]),z=(0,a.useCallback)(async()=>{await L()},[L]),D=(0,a.useCallback)(async()=>y.current&&"inactive"!==y.current.state?(w.current&&(clearTimeout(w.current),w.current=null),new Promise(e=>{var t;S.current=e,(null==(t=y.current)?void 0:t.state)==="recording"?y.current.stop():(I(),n("idle"),S.current=null,e(null))})):(n("idle"),null),[I]),T=(0,a.useCallback)(()=>{var e;w.current&&(clearTimeout(w.current),w.current=null),(null==(e=y.current)?void 0:e.state)==="recording"&&y.current.stop(),I(),k.current=[],n("idle")},[I]),M=(0,a.useCallback)(()=>{d(0),s.F.sttDownload().catch(()=>{d(null)})},[]),B=(0,a.useCallback)(()=>{n("idle"),d(null)},[]),E=(0,a.useCallback)(()=>{n("idle"),v(null)},[]),A=(0,a.useCallback)(()=>{m(e=>{let t=p.indexOf(e),r=p[(t+1)%p.length];return localStorage.setItem("stt-language",r),r})},[p]);return{state:r,available:i,downloadProgress:l,analyser:c,languages:p,selectedLanguage:x,error:g,cycleLanguage:A,handleMicClick:W,startRecording:z,stopRecording:D,cancelRecording:T,startDownload:M,dismissDownload:B,dismissError:E}}(u,e=>{e&&h(t=>t?t+" "+e:e)});(0,a.useEffect)(()=>{s.F.getOrg().then(async e=>{let t=e.employees;Array.isArray(t)&&v(await Promise.all(t.map(async e=>{try{let t=await s.F.getEmployee(e);return{name:t.name,displayName:t.displayName,department:t.department,rank:t.rank,engine:t.engine}}catch(t){return{name:e}}})))}).catch(()=>{})},[]),(0,a.useEffect)(()=>{s.F.getSkills().then(e=>{if(!Array.isArray(e))return;let t=e.filter(e=>!E.some(t=>t.name===e.name)).map(e=>({name:e.name,description:e.description||"",needsEmployee:"sync"===e.name}));w([...E,...t])}).catch(()=>{})},[c]);let O=(0,a.useCallback)(e=>{var t;let r=p.lastIndexOf("@");-1!==r&&h(p.slice(0,r)+"@"+e+" "),m(!1),null==(t=U.current)||t.focus()},[p]),P=(0,a.useCallback)(e=>{var t;e.needsEmployee?(h("/"+e.name+" @"),C(!1),y(""),j(0),m(!0)):(h("/"+e.name),C(!1)),null==(t=U.current)||t.focus()},[]);function V(){let e=p.trim(),r=z.length>0;if(!e&&!r||t)return;if("/new"===e){h(""),l();return}if("/status"===e){h(""),d();return}let n=r?[...z]:void 0;h(""),D([]),m(!1),C(!1),U.current&&(U.current.style.height="auto"),i(e,n,!1)}async function q(e){let t=e.target.files;if(!t||0===t.length)return;let r=[];for(let e=0;e<t.length;e++)r.push(await A(t[e]));D(e=>[...e,...r]),e.target.value=""}async function J(e){var t;let r=null==(t=e.clipboardData)?void 0:t.items;if(r){for(let t=0;t<r.length;t++)if(r[t].type.startsWith("image/")){e.preventDefault();let n=r[t].getAsFile();if(n){let e=await A(n);D(t=>[...t,e])}return}}}let _=(0,a.useCallback)(e=>{e&&h(t=>t?t+" "+e:e)},[]);async function K(){if("recording"===H.state){var e;let t=await H.stopRecording();_(null!=t?t:""),null==(e=U.current)||e.focus()}else"transcribing"===H.state||H.handleMicClick()}(0,a.useEffect)(()=>{U.current&&(U.current.style.height="auto",U.current.style.height=Math.min(U.current.scrollHeight,120)+"px")},[p]);let Y=k.filter(e=>e.name.toLowerCase().startsWith(I)),X=g.filter(e=>e.name.toLowerCase().includes(f)),G=p.trim().length>0||z.length>0;return(0,n.jsxs)("div",{className:"px-3 sm:px-4",style:{paddingTop:"var(--space-3)",paddingBottom:"var(--space-3)",borderTop:"1px solid var(--separator)",background:"var(--material-regular)",flexShrink:0,position:"relative"},children:[S&&Y.length>0&&(0,n.jsx)("div",{style:{position:"absolute",bottom:"100%",left:"var(--space-4)",right:"var(--space-4)",marginBottom:4,background:"var(--bg)",border:"1px solid var(--separator)",borderRadius:"var(--radius-md)",boxShadow:"var(--shadow-lg)",maxHeight:240,overflowY:"auto",zIndex:10},children:Y.map((e,t)=>{let r=t===L;return(0,n.jsxs)("button",{ref:e=>{r&&e&&e.scrollIntoView({block:"nearest"})},onClick:()=>P(e),style:{width:"100%",textAlign:"left",padding:"var(--space-2) var(--space-3)",fontSize:"var(--text-footnote)",background:r?"var(--fill-secondary)":"transparent",border:"none",cursor:"pointer",display:"flex",alignItems:"center",gap:"var(--space-2)",color:"var(--text-primary)"},children:[(0,n.jsxs)("span",{style:{fontFamily:"var(--font-mono)",fontWeight:"var(--weight-semibold)",color:"var(--accent)",fontSize:"var(--text-footnote)"},children:["/",e.name]}),(0,n.jsx)("span",{style:{color:"var(--text-tertiary)",fontSize:"var(--text-caption1)"},children:e.description})]},e.name)})}),x&&X.length>0&&(0,n.jsx)("div",{style:{position:"absolute",bottom:"100%",left:"var(--space-4)",right:"var(--space-4)",marginBottom:4,background:"var(--bg)",border:"1px solid var(--separator)",borderRadius:"var(--radius-md)",boxShadow:"var(--shadow-lg)",maxHeight:160,overflowY:"auto",zIndex:10},children:X.slice(0,8).map((e,t)=>{let r=t===b;return(0,n.jsxs)("button",{ref:e=>{e?F.current.set(t,e):F.current.delete(t),r&&e&&e.scrollIntoView({block:"nearest"})},onClick:()=>O(e.name),style:{width:"100%",textAlign:"left",padding:"var(--space-2) var(--space-3)",fontSize:"var(--text-footnote)",background:r?"var(--fill-secondary)":"transparent",border:"none",cursor:"pointer",display:"flex",alignItems:"center",gap:"var(--space-2)",color:"var(--text-primary)"},children:[(0,n.jsx)("span",{style:{fontSize:16,lineHeight:1},children:{executive:"\uD83C\uDFAF",manager:"\uD83D\uDCCB",senior:"⭐",employee:"\uD83D\uDC64"}[e.rank||"employee"]||"\uD83D\uDC64"}),(0,n.jsxs)("div",{style:{flex:1,minWidth:0},children:[(0,n.jsxs)("div",{style:{display:"flex",alignItems:"center",gap:"var(--space-2)"},children:[(0,n.jsx)("span",{style:{fontWeight:"var(--weight-semibold)"},children:e.displayName||e.name}),(0,n.jsxs)("span",{style:{fontFamily:"var(--font-mono)",fontSize:"var(--text-caption2)",color:"var(--text-tertiary)"},children:["@",e.name]})]}),e.department&&(0,n.jsxs)("div",{style:{fontSize:"var(--text-caption2)",color:"var(--text-quaternary)",display:"flex",gap:"var(--space-2)",marginTop:1},children:[(0,n.jsx)("span",{children:e.department}),e.engine&&(0,n.jsx)("span",{style:{color:"var(--accent)",fontWeight:"var(--weight-medium)"},children:e.engine})]})]})]},e.name)})}),z.length>0&&(0,n.jsx)("div",{style:{marginBottom:"var(--space-2)"},children:(0,n.jsx)(T,{attachments:z,onRemove:function(e){D(t=>t.filter((t,r)=>r!==e))}})}),(0,n.jsxs)("div",{style:{display:"flex",alignItems:"center",gap:"var(--space-2)",background:"var(--fill-secondary)",borderRadius:"var(--radius-lg)",padding:"6px var(--space-3)",border:r?"1px solid var(--accent)":"1px solid var(--separator)",minHeight:44,transition:"border-color 200ms ease"},children:[(0,n.jsx)("button",{"aria-label":"Attach file",onClick:()=>{var e;return null==(e=N.current)?void 0:e.click()},style:{width:32,height:32,flexShrink:0,borderRadius:"var(--radius-sm)",display:"flex",alignItems:"center",justifyContent:"center",background:"transparent",border:"none",cursor:"pointer",color:"var(--text-secondary)",marginBottom:0},children:(0,n.jsx)("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:(0,n.jsx)("path",{d:"M21.44 11.05l-9.19 9.19a6 6 0 0 1-8.49-8.49l9.19-9.19a4 4 0 0 1 5.66 5.66l-9.2 9.19a2 2 0 0 1-2.83-2.83l8.49-8.48"})})}),(0,n.jsx)("input",{ref:N,type:"file",accept:"image/*,audio/*,.pdf,.doc,.docx,.txt,.csv,.json,.zip",multiple:!0,style:{display:"none"},onChange:q}),(0,n.jsx)("textarea",{ref:U,value:p,onChange:function(e){let t=e.target.value;if(h(t),t.startsWith("/")&&!t.includes(" ")){R(t.slice(1).toLowerCase()),W(0),C(!0),m(!1);return}C(!1);let r=t.lastIndexOf("@");if(-1!==r){let e=t.slice(r+1);if(!e.includes(" ")&&!e.includes("\n")){y(e.toLowerCase()),j(0),m(!0);return}}m(!1)},onKeyDown:function(e){if(S&&Y.length>0){let t=Y.length;if("ArrowDown"===e.key){e.preventDefault(),W(e=>(e+1)%t);return}if("ArrowUp"===e.key){e.preventDefault(),W(e=>(e-1+t)%t);return}if("Tab"===e.key||"Enter"===e.key){e.preventDefault(),P(Y[L]);return}if("Escape"===e.key){e.preventDefault(),C(!1);return}}if(x&&X.length>0){let t=Math.min(X.length,8);if("ArrowDown"===e.key){e.preventDefault(),j(e=>(e+1)%t);return}if("ArrowUp"===e.key){e.preventDefault(),j(e=>(e-1+t)%t);return}if("Tab"===e.key||"Enter"===e.key){e.preventDefault(),O(X[b].name);return}if("Escape"===e.key){e.preventDefault(),m(!1);return}}"Enter"!==e.key||e.shiftKey||(e.preventDefault(),V())},onPaste:J,placeholder:t?"Waiting for response...":"Type a message...",rows:1,disabled:t,style:{flex:1,background:"transparent",border:"none",outline:"none",resize:"none",color:"var(--text-primary)",fontSize:"var(--text-subheadline)",lineHeight:"20px",maxHeight:120,minHeight:20,height:20,padding:0,margin:0,opacity:t?.5:1},onInput:e=>{let t=e.target;t.style.height="auto",t.style.height=Math.min(t.scrollHeight,120)+"px"}}),H.languages.length>1&&(0,n.jsx)("button",{"aria-label":"STT language: ".concat(H.selectedLanguage.toUpperCase(),". Click to switch."),onClick:H.cycleLanguage,style:{height:24,padding:"0 6px",flexShrink:0,borderRadius:"var(--radius-sm)",display:"flex",alignItems:"center",justifyContent:"center",background:"var(--fill-tertiary)",border:"none",cursor:"pointer",color:"var(--text-secondary)",fontSize:11,fontWeight:600,fontFamily:"var(--font-mono)",letterSpacing:"0.5px",textTransform:"uppercase",transition:"all 150ms ease"},title:"Transcription language: ".concat(H.selectedLanguage.toUpperCase(),". Click to cycle."),children:H.selectedLanguage}),(0,n.jsx)("button",{"aria-label":"recording"===H.state?"Stop recording":"transcribing"===H.state?"Transcribing…":"Voice input",onClick:K,disabled:"transcribing"===H.state,style:{width:32,height:32,flexShrink:0,borderRadius:"recording"===H.state?"999px":"var(--radius-sm)",display:"flex",alignItems:"center",justifyContent:"center",background:"recording"===H.state?"var(--system-red)":"transparent",border:"none",cursor:"transcribing"===H.state?"wait":"pointer",color:"recording"===H.state?"#fff":"var(--text-secondary)",transition:"all 150ms ease"},title:"recording"===H.state?"Stop recording":"transcribing"===H.state?"Transcribing…":"Voice input",children:"transcribing"===H.state?(0,n.jsx)("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",style:{animation:"stt-spin 1s linear infinite"},children:(0,n.jsx)("path",{d:"M12 2a10 10 0 0 1 10 10"})}):(0,n.jsxs)("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,n.jsx)("path",{d:"M12 1a3 3 0 0 0-3 3v8a3 3 0 0 0 6 0V4a3 3 0 0 0-3-3z"}),(0,n.jsx)("path",{d:"M19 10v2a7 7 0 0 1-14 0v-2"}),(0,n.jsx)("line",{x1:"12",y1:"19",x2:"12",y2:"23"}),(0,n.jsx)("line",{x1:"8",y1:"23",x2:"16",y2:"23"})]})}),"recording"===H.state&&H.analyser&&(0,n.jsx)(B,{analyser:H.analyser,width:64,height:28}),r&&o&&(0,n.jsx)("button",{onClick:o,"aria-label":"Stop",style:{width:32,height:32,borderRadius:"50%",background:"var(--system-red)",color:"#fff",border:"none",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0,transition:"all 150ms ease"},children:(0,n.jsx)("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"currentColor",children:(0,n.jsx)("rect",{x:"4",y:"4",width:"16",height:"16",rx:"2"})})}),(0,n.jsx)("button",{onClick:V,disabled:!G||t,"aria-label":"Send message",style:{width:32,height:32,borderRadius:"50%",background:G?"var(--accent)":"var(--fill-tertiary)",color:G?"#000":"var(--text-quaternary)",border:"none",cursor:G?"pointer":"default",display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0,transition:"all 150ms ease"},children:(0,n.jsxs)("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,n.jsx)("line",{x1:"12",y1:"19",x2:"12",y2:"5"}),(0,n.jsx)("polyline",{points:"5 12 12 5 19 12"})]})})]}),(0,n.jsxs)("div",{className:"hidden sm:flex",style:{fontSize:"var(--text-caption2)",color:"var(--text-quaternary)",textAlign:"center",marginTop:"var(--space-1)",justifyContent:"center",gap:"var(--space-3)"},children:[(0,n.jsx)("span",{children:"Enter to send"}),(0,n.jsx)("span",{children:"/ - commands"}),(0,n.jsx)("span",{children:"@name - mention"})]}),"error"===H.state&&H.error&&(0,n.jsxs)("div",{style:{display:"flex",alignItems:"center",gap:"var(--space-2)",marginTop:"var(--space-2)",padding:"var(--space-2) var(--space-3)",background:"color-mix(in srgb, var(--system-red) 12%, transparent)",borderRadius:"var(--radius-sm)",fontSize:"var(--text-caption1)",color:"var(--system-red)"},children:[(0,n.jsxs)("span",{style:{flex:1},children:["Voice input error: ",H.error]}),(0,n.jsx)("button",{onClick:H.dismissError,style:{background:"none",border:"none",cursor:"pointer",color:"var(--system-red)",fontSize:"var(--text-caption1)",fontWeight:600,padding:"2px 6px"},children:"Dismiss"})]}),(0,n.jsx)(M,{open:"no-model"===H.state,progress:H.downloadProgress,onDownload:H.startDownload,onCancel:H.dismissDownload}),(0,n.jsx)("style",{children:"\n @keyframes stt-spin {\n from { transform: rotate(0deg); }\n to { transform: rotate(360deg); }\n }\n "})]})}function N(){return(0,n.jsx)(a.Suspense,{fallback:(0,n.jsx)(l.M,{children:(0,n.jsx)("div",{style:{display:"flex",alignItems:"center",justifyContent:"center",height:"100%",color:"var(--text-tertiary)"},children:"Loading..."})}),children:(0,n.jsx)(F,{})})}function F(){var e;let{settings:t}=(0,d.t0)(),r=null!=(e=t.portalName)?e:"Jinn",[c,u]=(0,a.useState)(null),[p,h]=(0,a.useState)([]),[g,v]=(0,a.useState)(!1),[y,b]=(0,a.useState)(0),[j,k]=(0,a.useState)("sidebar"),[w,S]=(0,a.useState)(null),C=(0,a.useRef)(""),[I,R]=(0,a.useState)(""),L=(0,a.useRef)(-1),W=(0,a.useRef)(!1),[z,T]=(0,a.useState)(!1),[M,B]=(0,a.useState)(null),[E,A]=(0,a.useState)(!1),N=(0,a.useRef)(null),{events:F,connectionSeq:H,skillsVersion:O}=(0,o.G)(),P=(0,i.useSearchParams)(),V=(0,a.useRef)(!1),q=(0,a.useRef)(!1);(0,a.useEffect)(()=>{if(z)return document.addEventListener("mousedown",e),()=>document.removeEventListener("mousedown",e);function e(e){N.current&&!N.current.contains(e.target)&&T(!1)}},[z]);let J=(0,a.useCallback)((e,t)=>{navigator.clipboard.writeText(e),B(t),T(!1),setTimeout(()=>B(null),1500)},[]);function _(){s.F.createStubSession({greeting:"Hey! \uD83D\uDC4B Say hi when you're ready to get started.",title:"Welcome"}).then(e=>{let t=String(e.id);q.current=!0,u(t),b(e=>e+1)}).catch(()=>{})}(0,a.useEffect)(()=>{V.current||("1"===P.get("onboarding")?(V.current=!0,_()):s.F.getOnboarding().then(e=>{e.needed&&!V.current&&(V.current=!0,_())}).catch(()=>{}))},[P]);let K=(0,a.useCallback)((e,t)=>{if(!t)return;let r=L.current;if(r<0)return;let n=e.slice(r);n.length>0&&function(e,t){try{localStorage.setItem("".concat(m).concat(e),JSON.stringify(t))}catch(e){}}(t,n)},[]);(0,a.useEffect)(()=>{if(0===F.length)return;let e=F[F.length-1],t=e.payload;if(c&&t.sessionId===c){if("session:delta"===e.event){let e=String(t.type||"text");if("text"===e){let e=String(t.content||"");C.current+=e,R(C.current)}else if("tool_use"===e){if(C.current){let e=C.current;C.current="",R(""),h(r=>{L.current<0&&(L.current=r.length);let n=[...r,{id:crypto.randomUUID(),role:"assistant",content:e,timestamp:Date.now()}];return K(n,c||t.sessionId),n})}let e=String(t.toolName||"tool");h(r=>{L.current<0&&(L.current=r.length);let n=[...r,{id:crypto.randomUUID(),role:"assistant",content:"Using ".concat(e),timestamp:Date.now(),toolCall:e}];return K(n,c||t.sessionId),n})}else"tool_result"===e&&h(e=>{let r=[...e],n=r[r.length-1];return n&&"assistant"===n.role&&n.toolCall&&(r[r.length-1]={...n,content:"Used ".concat(n.toolCall)}),K(r,c||t.sessionId),r})}if("session:interrupted"===e.event&&(C.current="",R("")),"session:completed"===e.event){C.current="",R(""),v(!1),L.current=-1;let e=c||(t.sessionId?String(t.sessionId):null);e&&f(e),t.result&&h(e=>{let r=[...e],n=r[r.length-1];return n&&"assistant"===n.role&&!n.toolCall&&r.pop(),[...r,{id:crypto.randomUUID(),role:"assistant",content:String(t.result),timestamp:Date.now()}]}),t.error&&!t.result&&h(e=>[...e,{id:crypto.randomUUID(),role:"assistant",content:"Error: ".concat(t.error),timestamp:Date.now()}]),b(e=>e+1)}}},[F,c,K]);let Y=(0,a.useCallback)(async e=>{try{let t=await s.F.getSession(e);S({engine:t.engine?String(t.engine):void 0,engineSessionId:t.engineSessionId?String(t.engineSessionId):void 0,model:t.model?String(t.model):void 0,title:t.title?String(t.title):void 0,employee:t.employee?String(t.employee):void 0});let r=t.messages||t.history||[],n=Array.isArray(r)?r.map(e=>({id:crypto.randomUUID(),role:e.role||"assistant",content:String(e.content||e.text||""),timestamp:e.timestamp?Number(e.timestamp):Date.now()})):[];if("error"===t.status&&t.lastError){let e=n[n.length-1],r="Error: ".concat(String(t.lastError));e&&"assistant"===e.role&&e.content===r||n.push({id:crypto.randomUUID(),role:"assistant",content:r,timestamp:Date.now()})}if("running"===t.status){let t=function(e){try{let t=localStorage.getItem("".concat(m).concat(e));return t?JSON.parse(t):[]}catch(e){return[]}}(e);t.length>0?(L.current=n.length,h([...n,...t])):(L.current=n.length,h(n)),v(!0)}else f(e),L.current=-1,h(n)}catch(e){h([]),S(null),L.current=-1}},[]);(0,a.useEffect)(()=>{H&&c&&Y(c)},[H,c,Y]),(0,a.useEffect)(()=>{if(!c||!g)return;let e=setInterval(async()=>{try{let e=await s.F.getSession(c);"running"!==e.status&&(await Y(c),v(!1))}catch(e){}},5e3);return()=>clearInterval(e)},[c,g,Y]);let X=(0,a.useCallback)(e=>{W.current=!1,u(e),h([]),v(!1),k("chat"),Y(e)},[Y]),G=(0,a.useCallback)(()=>{W.current=!0,u(null),h([]),v(!1),S(null),k("chat"),L.current=-1},[]),$=(0,a.useCallback)(e=>{c||V.current||W.current||!(e.length>0)||X(e[0].id)},[c,X]),Q=(0,a.useCallback)(async(e,t,n)=>{let a={id:crypto.randomUUID(),role:"user",content:e,timestamp:Date.now(),media:t};h(e=>(L.current=e.length+1,[...e,a])),v(!0);try{let t=c;if(t&&q.current){q.current=!1;let n="This is your first time being activated. The user just set up ".concat(r," and opened the web dashboard for the first time.\n\nRead your CLAUDE.md instructions and the onboarding skill at ~/.jinn/skills/onboarding/SKILL.md, then follow the onboarding flow:\n- Greet the user warmly and introduce yourself as ").concat(r,"\n- Briefly explain what you can do (manage cron jobs, hire AI employees, connect to Slack, etc.)\n- Ask the user what they'd like to set up first\n\nThe user said: \"").concat(e,'"');await s.F.sendMessage(t,{message:n}),b(e=>e+1)}else if(t)await s.F.sendMessage(t,{message:e,interrupt:n||void 0}),b(e=>e+1);else{let r=await s.F.createSession({source:"web",prompt:e});t=String(r.id),u(t),b(e=>e+1)}}catch(e){v(!1),h(t=>[...t,{id:crypto.randomUUID(),role:"assistant",content:"Error: ".concat(e instanceof Error?e.message:"Failed to send message"),timestamp:Date.now()}])}},[c,r]),Z=(0,a.useCallback)(async e=>{try{await s.F.deleteSession(e),c===e&&(u(null),h([]),v(!1),S(null),C.current="",R(""),L.current=-1),f(e),b(e=>e+1)}catch(e){}A(!1),T(!1)},[c]),ee=(0,a.useCallback)(async()=>{if(!c)return void h(e=>[...e,{id:crypto.randomUUID(),role:"assistant",content:"No active session. Send a message to start one.",timestamp:Date.now()}]);try{let e=await s.F.getSession(c),t=["**Session Info**","ID: `".concat(e.id,"`"),"Status: ".concat(e.status||"unknown"),e.employee?"Employee: ".concat(e.employee):null,e.engine?"Engine: ".concat(e.engine):null,e.model?"Model: ".concat(e.model):null,e.createdAt?"Created: ".concat(e.createdAt):null].filter(Boolean).join("\n");h(e=>[...e,{id:crypto.randomUUID(),role:"assistant",content:t,timestamp:Date.now()}])}catch(e){h(e=>[...e,{id:crypto.randomUUID(),role:"assistant",content:"Failed to fetch session status.",timestamp:Date.now()}])}},[c]);return(0,n.jsxs)(l.M,{children:[(0,n.jsxs)("div",{className:"h-[calc(100%-48px)] lg:h-full",style:{display:"flex",overflow:"hidden"},children:[(0,n.jsx)("div",{className:"hidden lg:block",style:{width:280,flexShrink:0,height:"100%"},children:(0,n.jsx)(x,{selectedId:c,onSelect:X,onNewChat:G,onDelete:Z,refreshKey:y,connectionSeq:H,onSessionsLoaded:$,events:F})}),(0,n.jsx)("div",{className:"sidebar"===j?"block lg:hidden":"hidden",style:{width:"100%",height:"100%"},children:(0,n.jsx)(x,{selectedId:c,onSelect:X,onNewChat:G,onDelete:Z,refreshKey:y,connectionSeq:H,onSessionsLoaded:$,events:F})}),(0,n.jsxs)("div",{style:{flex:1,flexDirection:"column",height:"100%",background:"var(--bg)",minWidth:0,overflow:"hidden"},className:"sidebar"===j?"hidden lg:flex":"flex",children:[(0,n.jsxs)("div",{style:{height:52,display:"flex",alignItems:"center",padding:"0 var(--space-4)",borderBottom:"1px solid var(--separator)",background:"var(--material-thick)",flexShrink:0},children:[(0,n.jsxs)("button",{className:"flex lg:hidden",onClick:()=>k("sidebar"),"aria-label":"Back to sessions",style:{padding:"var(--space-1) var(--space-2)",borderRadius:"var(--radius-sm)",marginRight:"var(--space-2)",fontSize:"var(--text-subheadline)",alignItems:"center",gap:"var(--space-1)",background:"transparent",border:"none",cursor:"pointer",color:"var(--accent)"},children:[(0,n.jsx)("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:(0,n.jsx)("polyline",{points:"15 18 9 12 15 6"})}),"Back"]}),(0,n.jsx)("div",{style:{flex:1,minWidth:0},children:(0,n.jsx)("div",{style:{fontSize:"var(--text-subheadline)",fontWeight:"var(--weight-semibold)",color:"var(--text-primary)",letterSpacing:"-0.2px",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:c?(null==w?void 0:w.title)||(null==w?void 0:w.employee)||r:"New Chat"})}),M&&(0,n.jsx)("div",{style:{fontSize:"var(--text-caption1)",color:"var(--accent)",marginRight:"var(--space-2)",whiteSpace:"nowrap"},children:"Copied!"}),c&&(0,n.jsxs)("div",{ref:N,style:{position:"relative"},children:[(0,n.jsx)("button",{onClick:()=>T(e=>!e),"aria-label":"More options",style:{background:"transparent",border:"none",cursor:"pointer",padding:"var(--space-1)",borderRadius:"var(--radius-sm)",color:"var(--text-secondary)",display:"flex",alignItems:"center",transition:"color 150ms ease"},onMouseEnter:e=>e.currentTarget.style.color="var(--text-primary)",onMouseLeave:e=>e.currentTarget.style.color="var(--text-secondary)",children:(0,n.jsxs)("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"currentColor",children:[(0,n.jsx)("circle",{cx:"12",cy:"5",r:"2"}),(0,n.jsx)("circle",{cx:"12",cy:"12",r:"2"}),(0,n.jsx)("circle",{cx:"12",cy:"19",r:"2"})]})}),z&&(0,n.jsxs)("div",{style:{position:"absolute",top:"100%",right:0,marginTop:4,background:"var(--material-thick)",border:"1px solid var(--separator)",borderRadius:"var(--radius-md)",boxShadow:"0 4px 12px rgba(0,0,0,0.15)",zIndex:100,minWidth:200,overflow:"hidden"},children:[(0,n.jsx)("button",{onClick:()=>J(c,"id"),style:{display:"block",width:"100%",padding:"var(--space-2) var(--space-3)",background:"transparent",border:"none",cursor:"pointer",textAlign:"left",fontSize:"var(--text-subheadline)",color:"var(--text-primary)"},onMouseEnter:e=>e.currentTarget.style.background="var(--fill-tertiary)",onMouseLeave:e=>e.currentTarget.style.background="transparent",children:"Copy Session ID"}),(null==w?void 0:w.engineSessionId)&&(0,n.jsx)("button",{onClick:()=>{let e="codex"===w.engine?"codex":"claude";J("".concat(e," --resume ").concat(w.engineSessionId),"cli")},style:{display:"block",width:"100%",padding:"var(--space-2) var(--space-3)",background:"transparent",border:"none",cursor:"pointer",textAlign:"left",fontSize:"var(--text-subheadline)",color:"var(--text-primary)"},onMouseEnter:e=>e.currentTarget.style.background="var(--fill-tertiary)",onMouseLeave:e=>e.currentTarget.style.background="transparent",children:"Copy CLI Resume Command"}),(0,n.jsx)("div",{style:{borderTop:"1px solid var(--separator)",margin:"2px 0"}}),(0,n.jsxs)("button",{onClick:()=>{T(!1),A(!0)},style:{display:"flex",alignItems:"center",gap:"var(--space-2)",width:"100%",padding:"var(--space-2) var(--space-3)",background:"transparent",border:"none",cursor:"pointer",textAlign:"left",fontSize:"var(--text-subheadline)",color:"var(--system-red)"},onMouseEnter:e=>e.currentTarget.style.background="var(--fill-tertiary)",onMouseLeave:e=>e.currentTarget.style.background="transparent",children:[(0,n.jsxs)("svg",{width:"14",height:"14",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[(0,n.jsx)("polyline",{points:"3 6 5 6 21 6"}),(0,n.jsx)("path",{d:"M19 6v14a2 2 0 0 1-2 2H7a2 2 0 0 1-2-2V6m3 0V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2"})]}),"Delete Session"]})]})]})]}),(0,n.jsx)(D,{messages:p,loading:g,streamingText:I}),(0,n.jsx)(U,{disabled:!1,loading:g,onSend:Q,onNewSession:G,onStatusRequest:ee,skillsVersion:O,events:F})]})]}),E&&c&&(0,n.jsx)("div",{style:{position:"fixed",top:0,left:0,right:0,bottom:0,background:"rgba(0,0,0,0.5)",zIndex:60,display:"flex",alignItems:"center",justifyContent:"center"},onClick:()=>A(!1),children:(0,n.jsxs)("div",{style:{background:"var(--bg)",borderRadius:"var(--radius-lg)",padding:"var(--space-6)",maxWidth:400,width:"90%",boxShadow:"var(--shadow-overlay)"},onClick:e=>e.stopPropagation(),children:[(0,n.jsx)("h3",{style:{fontSize:"var(--text-headline)",fontWeight:"var(--weight-bold)",color:"var(--text-primary)",marginBottom:"var(--space-2)"},children:"Delete Session?"}),(0,n.jsx)("p",{style:{fontSize:"var(--text-body)",color:"var(--text-secondary)",marginBottom:"var(--space-5)"},children:"This will permanently delete the session and all its messages."}),(0,n.jsxs)("div",{style:{display:"flex",gap:"var(--space-3)",justifyContent:"flex-end"},children:[(0,n.jsx)("button",{onClick:()=>A(!1),style:{padding:"var(--space-2) var(--space-4)",borderRadius:"var(--radius-md)",background:"var(--fill-tertiary)",color:"var(--text-primary)",border:"none",cursor:"pointer",fontSize:"var(--text-body)"},children:"Cancel"}),(0,n.jsx)("button",{onClick:()=>Z(c),style:{padding:"var(--space-2) var(--space-4)",borderRadius:"var(--radius-md)",background:"var(--system-red)",color:"#fff",border:"none",cursor:"pointer",fontSize:"var(--text-body)",fontWeight:"var(--weight-semibold)"},children:"Delete"})]})]})})]})}},7906:(e,t,r)=>{Promise.resolve().then(r.bind(r,3095))}},e=>{e.O(0,[704,73,814,743,358],()=>e(e.s=7906)),_N_E=e.O()}]);
|