@next-bricks/ai-portal 0.16.2 → 0.16.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/bricks.json CHANGED
@@ -2,12 +2,12 @@
2
2
  "id": "bricks/ai-portal",
3
3
  "bricks": [
4
4
  "ai-portal.cruise-canvas",
5
- "ai-portal.chat-box",
6
5
  "ai-portal.chat-history",
7
- "ai-portal.home-container",
8
6
  "ai-portal.stat-with-mini-chart",
9
7
  "ai-portal.elevo-logo",
10
- "ai-portal.elevo-sidebar"
8
+ "ai-portal.elevo-sidebar",
9
+ "ai-portal.home-container",
10
+ "ai-portal.chat-box"
11
11
  ],
12
12
  "elements": [],
13
13
  "processors": [],
@@ -24,9 +24,6 @@
24
24
  "basic.copy-to-clipboard",
25
25
  "eo-easyops-avatar"
26
26
  ],
27
- "ai-portal.chat-box": [
28
- "eo-icon"
29
- ],
30
27
  "ai-portal.chat-history": [
31
28
  "eo-icon",
32
29
  "eo-link",
@@ -41,7 +38,10 @@
41
38
  "eo-dropdown-actions",
42
39
  "eo-easyops-avatar",
43
40
  "eo-mini-actions"
41
+ ],
42
+ "ai-portal.chat-box": [
43
+ "eo-icon"
44
44
  ]
45
45
  },
46
- "filePath": "bricks/ai-portal/dist/index.9c92ae05.js"
46
+ "filePath": "bricks/ai-portal/dist/index.9b431f90.js"
47
47
  }
@@ -1,3 +1,3 @@
1
- /*! For license information please see 6220.43f2b07b.js.LICENSE.txt */
2
- "use strict";(globalThis.webpackChunk_next_bricks_ai_portal=globalThis.webpackChunk_next_bricks_ai_portal||[]).push([[6220],{24:(e,t,n)=>{n.d(t,{A:()=>o});var i=n(36758),a=n.n(i),s=n(40935),r=n.n(s)()(a());r.push([e.id,':host{display:block;white-space:nowrap}.container{border-radius:var(--elevo-border-radius)}:host([hidden]){display:none}*{box-sizing:border-box}.label{font-weight:500;overflow:hidden;text-overflow:ellipsis}.stat{font-weight:600}.chart{min-width:0}.chart > *{display:block}:host(:not([size="small"])) .container{background:linear-gradient(164deg,rgba(105,153,253,0) 40%,rgba(105,153,253,0.05) 60%,rgba(105,153,253,0.32) 100%),#fff;padding:22px}:host(:not([size="small"])) .label{font-size:14px;height:22px;margin-bottom:16px}:host(:not([size="small"])) .stat-and-chart{display:flex;align-items:center;justify-content:end;position:relative}:host(:not([size="small"])) .stat{font-size:36px;color:#1d212a;position:absolute;left:0}:host(:not([size="small"])) .chart{width:calc(100% - 160px)}:host([size="small"]) .container{padding:11px 15px;display:flex;align-items:center;justify-content:end;position:relative;background:var(--elevo-component-background);-webkit-backdrop-filter:var(--elevo-component-backdrop-filter);backdrop-filter:var(--elevo-component-backdrop-filter)}:host([size="small"]) .label-and-stat{position:absolute;left:15px}:host([size="small"]) .label{font-size:12px;color:#8c8c8c;line-height:17px;height:17px;margin-bottom:7px}:host([size="small"]) .stat{font-size:20px;color:#262626;line-height:24px}:host([size="small"]) .chart{width:calc(100% - 90px)}',""]);const o=r.toString()},21411:(e,t,n)=>{n.d(t,{A:()=>o});var i=n(36758),a=n.n(i),s=n(40935),r=n.n(s)()(a());r.push([e.id,":host{display:block}:host([hidden]){display:none}*{box-sizing:border-box}ul{list-style:none;margin:0;padding:0}.loading{display:flex;justify-content:center;padding:8px}.group + .group{margin-top:15px}.group-title{font-weight:500;font-size:12px;color:#000;padding:8px;height:36px;line-height:20px}.item{display:block}.item::part(link){display:flex;align-items:center;padding:0 8px;height:36px;border-radius:8px;color:#000}.item::part(link):hover{background:rgba(0,0,0,0.04)}.item-title{flex:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.actions{cursor:auto}.item:not(:hover):not(.active) .actions{display:none}.working{width:8px;height:8px;border-radius:8px;background:#2540ff;margin:0 7px}.item:hover .working,\n.item.active .working{display:none}.load-more{display:flex;justify-content:center;align-items:center;height:36px}",""]);const o=r.toString()},26093:(e,t,n)=>{var i,a=n(74635),s=n(70918),r=n(26902),o=n(5536),l=n(86121),c=n(70829),d=n(62740),u=n(18769),h=n.n(u),m=n(7921),p=n(11280),g=n(23081),b=(n(65168),n(90079)),f=n(53373),v=n.n(f),A=n(99126),k=n(67566),x=n(8324),E=n(69445),w=n(2460),y=n(32464),N=n(58231),S=n(36494),T=n(97642),M=n(92773),C=n(59533),R=n(13153),_=n(34999),I=n(27954),Y=n(24388),W=n(56938),O=n(77971),z=n(39295),D=n(39194),U=n(16854),j=n(55805),P=n(85620),L=n(73349),V=n(62601),F=n(57097),H=n(83490);let B,$,q,G,K,X,Q,J,Z,ee,te,ne,ie,ae,se,re,oe,le,ce,de,ue,he,me,pe,ge,be;(0,b.initializeI18n)(w.NS,w.I);const{defineElement:fe,property:ve,event:Ae,method:ke}=(0,m.createDecorators)(),xe=(0,u.memo)(Pe),Ee=(0,u.forwardRef)(je);let we;var ye=new WeakMap,Ne=new WeakMap,Se=new WeakMap,Te=new WeakMap,Me=new WeakMap,Ce=new WeakSet,Re=new WeakMap,_e=new WeakMap,Ie=new WeakMap,Ye=new WeakMap,We=new WeakMap,Oe=new WeakMap,ze=new WeakMap,De=new WeakMap;class Ue extends p.ReactNextElement{constructor(){super(...arguments),(0,a.A)(this,Ce),(0,s.A)(this,ye,(B(this),q(this))),(0,s.A)(this,Ne,(G(this),K(this))),(0,s.A)(this,Se,(X(this),Q(this))),(0,s.A)(this,Te,(J(this),Z(this))),(0,s.A)(this,Me,(ee(this),te(this))),(0,s.A)(this,Re,(ae(this),()=>{(0,o.A)(Ce,this,ne).emit()})),(0,s.A)(this,_e,se(this)),(0,s.A)(this,Ie,(le(this),()=>{(0,o.A)(Ce,this,re).emit()})),(0,s.A)(this,Ye,ce(this)),(0,s.A)(this,We,(he(this),()=>{(0,o.A)(Ce,this,de).emit()})),(0,s.A)(this,Oe,me(this)),(0,s.A)(this,ze,(be(this),()=>{(0,o.A)(Ce,this,pe).emit()})),(0,s.A)(this,De,(0,u.createRef)())}get taskId(){return(0,c.A)(ye,this)}set taskId(e){(0,l.A)(ye,this,e)}get task(){return(0,c.A)(Ne,this)}set task(e){(0,l.A)(Ne,this,e)}get jobs(){return(0,c.A)(Se,this)}set jobs(e){(0,l.A)(Se,this,e)}get replay(){return(0,c.A)(Te,this)}set replay(e){(0,l.A)(Te,this,e)}resumed(){var e;null===(e=(0,c.A)(De,this).current)||void 0===e||e.resumed()}render(){return h().createElement(Ee,{taskId:this.taskId,jobs:this.jobs,task:this.task,replay:this.replay,onShare:(0,c.A)(Re,this),onPause:(0,c.A)(Ie,this),onResume:(0,c.A)(We,this),onCancel:(0,c.A)(ze,this),ref:(0,c.A)(De,this)})}}function je(e,t){var n;let{taskId:i,task:a,jobs:s,replay:r,onShare:o,onPause:l,onResume:c,onCancel:d}=e;const m=(0,u.useRef)(null),{task:p,jobs:b,plan:f,error:A,humanInputRef:w,resumedRef:I}=(0,M.S)(i,r),Y=i?p:a,W=i?b:s,O=i?f:null==a?void 0:a.plan,z=(0,C.B)(Y,W),D=null==z?void 0:z.nodes,B=null==z?void 0:z.edges,$=null==z?void 0:z.nav,q=null==z?void 0:z.views,G=null!==(n=null==Y?void 0:Y.title)&&void 0!==n?n:"",K=null==Y?void 0:Y.state,[X,Q]=(0,u.useState)(null),J=(0,u.useMemo)((()=>{if(X){const[e,t]=X.split(":");if("job"===e||"view"===e)return t}return null}),[X]);(0,u.useImperativeHandle)(t,(()=>({resumed:()=>{var e;return null===(e=I.current)||void 0===e?void 0:e.call(I)}})),[I]);const Z=(0,u.useRef)(!1);(0,u.useEffect)((()=>{const e=setTimeout((()=>{Z.current=!0}),3e3);return()=>{clearTimeout(e)}}),[]),(0,u.useEffect)((()=>{(0,g.getRuntime)().applyPageTitle(G)}),[G]),(0,u.useEffect)((()=>{A&&(0,g.handleHttpError)(A)}),[A]);const ee=(0,u.useCallback)(((e,t)=>{var n;null===(n=w.current)||void 0===n||n.call(w,e,t)}),[w]),[te,ne]=(0,u.useState)(null),ie=(0,u.useCallback)(((e,t)=>{ne((n=>{if(!t){if(!n)return null;const t=new Map(n);return t.delete(e)?t:n}return n?new Map(n).set(e,t):new Map([[e,t]])}))}),[]),{sizeReady:ae,nodes:se,edges:re}=(0,T.g)({rawNodes:D,rawEdges:B,state:K,sizeMap:te}),oe=(0,u.useRef)(!1),le=(0,u.useRef)(!1),[ce,de]=(0,u.useState)(!1),{grabbing:ue,transform:he,transformRef:me,zoomer:pe}=(0,N.f)({rootRef:m,zoomable:ae,scrollable:ae&&!ce,pannable:ae,manualScrolledUpRef:le}),ge=(0,u.useRef)(!1),be=(0,u.useMemo)((()=>{let e=null;const t=n=>{const i=me.current,a="function"==typeof n?n(i):n;if(!a)return;const{transform:s,translateBy:r}=a;let o=(0,k.A)(m.current);var l,c,d,u,h,p;Z.current&&0!==a.duration&&(ge.current=!0,o=o.transition().duration(null!==(l=a.duration)&&void 0!==l?l:300).ease((e=>e*(2-e))).on("end",(()=>{if(ge.current=!1,e){const n=e;e=null,t(n)}}))),s?pe.transform(o,new x.uV(null!==(c=s.k)&&void 0!==c?c:i.k,null!==(d=s.x)&&void 0!==d?d:i.x,null!==(u=s.y)&&void 0!==u?u:i.y)):pe.translateBy(o,null!==(h=r[0])&&void 0!==h?h:0,null!==(p=r[1])&&void 0!==p?p:0)};return n=>{ge.current?e=n:t(n)}}),[me,pe]),{centered:fe,setCentered:ve,reCenterRef:Ae}=(0,S.E)({nodes:se,sizeReady:ae,zoomer:pe,rootRef:m,pushZoomTransition:be}),ke=!U.QB.includes(null!=K?K:"working")&&2===se.length,Ee=(0,u.useMemo)((()=>new Set(re.map((e=>e.source)))),[re]),we=(0,u.useMemo)((()=>{if(!ae)return null;const e=[];for(const t of se)Ee.has(t.id)||e.push(t);return e.length>0?Math.max(...e.map((e=>e.view.y+e.view.height))):null}),[se,Ee,ae]),ye=(0,u.useRef)(null);(0,u.useEffect)((()=>{ye.current=we}),[we]),(0,u.useEffect)((()=>{const e=m.current;!e||null===we||oe.current&&le.current||be((t=>{const{offsetHeight:n}=e,i=we*t.k+t.y,a=n-U.xX-i;return a<0?{transform:{y:t.y+a},duration:a>-100?100:a<-500?300:200}:null}))}),[we,be]),(0,u.useEffect)((()=>{const e=ye.current,t=m.current;if(!t||null===e||ge.current)return;const{offsetHeight:n}=t,i=e*he.k+he.y,a=n-U.xX-i;oe.current=a<0}),[he,pe]);const Ne=(0,u.useCallback)((()=>{Ae.current=!0,ve(!1)}),[Ae,ve]),Se=(0,u.useCallback)((e=>{pe.scaleTo((0,k.A)(m.current),e)}),[pe]),Te=(0,u.useMemo)((()=>ae?(0,E.o)(se.map((e=>e.view))):null),[se,ae]);(0,u.useEffect)((()=>{if(!Te)return;const e=m.current;if(!e)return;const{offsetWidth:t,offsetHeight:n}=e,i=t/he.k,a=n/he.k,s=-(i-20-Te.x),r=i-20+(Te.x+Te.width),o=-(a-20-Te.y),l=a-20+(Te.y+Te.height);pe.translateExtent([[s,o],[r,l]])}),[pe,he.k,Te]);const Me=(0,u.useCallback)((e=>{let{nodeId:t,jobId:n,behavior:i,block:a}=e;const s=m.current,r=se.filter((e=>{var i;return!(t&&e.id!==t||n&&(null===(i=e.job)||void 0===i?void 0:i.id)!==n)}));if(!s||0===r.length)return;const o=(0,E.o)(r.map((e=>e.view))),{x:l,y:c}=(0,V.D)(o,[s.offsetWidth,s.offsetHeight],[U.RV,U.kq,U.xX,U.bL],me.current,a);(l||c)&&be({translateBy:[l,c],duration:"instant"===i?0:void 0})}),[se,be,me]),Ce=(0,u.useCallback)(((e,t)=>{const n=m.current;if(!n||!ae)return;let i,a=0,s=0,r=300;const o="left"===e||"right"===e;if("line"===t)i=40*("up"===e||"left"===e?1:-1),r=150;else if("page"===t)i=(n.offsetHeight-U.xX)*("up"===e?-1:1);else{const{y:t,height:a}=(0,E.o)(se.map((e=>e.view)));if("down"===e){const e=t+a-t+U.xX;i=n.offsetHeight-e-me.current.y}else i=t+U.RV-me.current.y}o?a=i:s=i,(a||s)&&be({translateBy:[a,s],duration:r})}),[se,be,ae,me]),[Re,_e]=(0,u.useState)(null),[Ie,Ye]=(0,u.useState)(null),We=(0,u.useMemo)((()=>({humanInput:ee,onShare:o,onPause:l,onResume:c,onCancel:d,onNodeResize:ie,activeToolCallJobId:Re,setActiveToolCallJobId:_e,setActiveNodeId:Q,hoverOnScrollableContent:ce,setHoverOnScrollableContent:de,activeExpandedViewJobId:Ie,setActiveExpandedViewJobId:Ye})),[Re,ce,Ie,ie,ee,o,l,c,d]),Oe=(0,u.useMemo)((()=>Re?null==W?void 0:W.find((e=>e.id===Re)):null),[Re,W]),ze=(0,u.useCallback)((e=>{for(const t of e.nativeEvent.composedPath()){if(t instanceof HTMLElement&&t.classList.contains(y.A.node))return;if(t===m.current)break}Q(null)}),[]);return(0,u.useEffect)((()=>{const e=m.current;if(!e||Oe||Ie)return;const t=t=>{if(document.activeElement&&document.activeElement!==document.body&&document.activeElement!==e)return;const n=(0,F.l)(t,{activeNodeId:X,nodes:se});if(!n)return;const{action:i,node:a}=n;if("scroll"===i)Ce(n.direction,n.range);else if("enter"===i){var s,r;if("job"!==a.type&&"view"!==a.type)return;const e="ask_human"===(null===(s=a.job.toolCall)||void 0===s?void 0:s.name),t="ask_human_confirming_plan"===(null===(r=a.job.toolCall)||void 0===r?void 0:r.name);if(e||t)return}t.preventDefault(),t.stopPropagation(),"enter"===i?"view"===a.type?Ye(a.job.id):_e(a.job.id):"switch-active-node"===i&&(Q(a.id),"job"===a.type||"view"===a.type?Me({jobId:a.job.id,behavior:"smooth"}):Me({nodeId:a.id,behavior:"smooth"}))};return document.addEventListener("keydown",t),()=>{document.removeEventListener("keydown",t)}}),[X,Oe,Ie,se,Me,Ce]),h().createElement(P.Q.Provider,{value:We},h().createElement("div",{className:v()(y.A.root,{[y.A.loading]:!Y}),ref:m,style:{cursor:ue?"grabbing":"grab"},tabIndex:-1,onClick:ze},!Y&&h().createElement("div",{className:y.A["loading-icon"]},h().createElement(j.Bj,{lib:"antd",theme:"outlined",icon:"loading-3-quarters",spinning:!0})),h().createElement("div",{className:v()(y.A.canvas,{[y.A.ready]:ae&&fe}),style:{transform:`translate3d(${he.x}px, ${he.y}px, 0) scale(${he.k})`}},h().createElement("svg",{className:y.A.edges},re.map((e=>h().createElement("path",{className:y.A.edge,key:`${e.source}-${e.target}`,d:e.points.map(((e,t)=>{let{x:n,y:i}=e;return`${0===t?"M":"L"}${n},${i}`})).join(" ")})))),se.map((e=>{var t,n,i;return h().createElement(xe,{key:e.id,id:e.id,type:e.type,content:e.content,job:e.job,state:e.state,startTime:null==Y?void 0:Y.startTime,taskLoading:ke,instructionLoading:"instruction"===e.type&&!Ee.has(e.id)&&!U.QB.includes(null!==(t=e.state)&&void 0!==t?t:"working")&&!U.X4.includes(null!=K?K:"working"),edges:re,x:null===(n=e.view)||void 0===n?void 0:n.x,y:null===(i=e.view)||void 0===i?void 0:i.y,active:X===e.id})})))),h().createElement("div",{className:y.A.widgets},h().createElement("div",{className:y.A["nav-container"]},h().createElement("ul",{className:y.A.nav},null==$?void 0:$.map((e=>h().createElement("li",{key:e.id,className:v()(y.A["nav-item"],{[y.A.active]:J===e.id})},h().createElement("a",{className:y.A["nav-link"],onClick:()=>{Q(`job:${e.id}`),Me({jobId:e.id,block:"start"})}},h().createElement("span",{className:y.A["nav-link-text"]},e.title))))))),h().createElement(R.r,{plan:O,state:K}),h().createElement(_.l,{scale:he.k,onScaleChange:Se,onReCenter:Ne})),Oe&&h().createElement(L.M,{job:Oe}),Ie&&h().createElement(H.f,{views:q}))}function Pe(e){let{id:t,type:n,state:i,job:a,content:s,startTime:r,taskLoading:o,instructionLoading:l,x:c,y:d,active:m}=e;const p=(0,u.useRef)(null),{onNodeResize:g,setActiveNodeId:b}=(0,u.useContext)(P.Q);(0,u.useEffect)((()=>{const e=p.current;if(!e)return;const n=new A.A((()=>{g(t,[e.offsetWidth,e.offsetHeight])}));return n.observe(e),()=>{n.disconnect(),g(t,null)}}),[t,g]),(0,u.useEffect)((()=>{const e=p.current;if(!e)return;const t=e=>{e.stopPropagation()};return e.addEventListener("mousedown",t),()=>{e.removeEventListener("mousedown",t)}}),[]);const f=(0,u.useCallback)((()=>{"start"!==n&&"instruction"!==n&&b(t)}),[t,b,n]);return h().createElement("div",{className:v()(y.A.node,{[y.A.ready]:null!=c&&null!=d}),ref:p,style:{left:c,top:d},onClick:f},"start"===n?h().createElement(I.H,null):"end"===n?h().createElement(z.s,{active:m}):"requirement"===n?h().createElement(Y.O,{content:s,startTime:r,loading:o,active:m}):"instruction"===n?h().createElement(W.L,{content:a.instruction,loading:l}):"view"===n?h().createElement(D.Y,{job:a,active:m}):h().createElement(O.W,{state:i,job:a,active:m}))}i=Ue,({e:[q,G,K,X,Q,J,Z,ee,te,ne,ie,ae,se,re,oe,le,ce,de,ue,he,me,pe,ge,be,B],c:[we,$]}=(0,d.A)(i,[fe("ai-portal.cruise-canvas",{shadowOptions:!1})],[[ve(),1,"taskId"],[ve({attribute:!1}),1,"task"],[ve({attribute:!1}),1,"jobs"],[ve({type:Number}),1,"replay"],[Ae({type:"share"}),1,"shareEvent",e=>(0,c.A)(Me,e),(e,t)=>(0,l.A)(Me,e,t)],[Ae({type:"pause"}),1,"pauseEvent",e=>(0,c.A)(_e,e),(e,t)=>(0,l.A)(_e,e,t)],[Ae({type:"resume"}),1,"resumeEvent",e=>(0,c.A)(Ye,e),(e,t)=>(0,l.A)(Ye,e,t)],[Ae({type:"cancel"}),1,"cancelEvent",e=>(0,c.A)(Oe,e),(e,t)=>(0,l.A)(Oe,e,t)],[ke(),2,"resumed"]],0,(e=>De.has((0,r.A)(e))),p.ReactNextElement)),$();var Le=n(71451),Ve=n(41030);let Fe=function(e){return e.ASK_ANY_THING="ASK_ANYTHING",e.COMMON_TASKS="COMMON_TASKS",e}({});const He="bricks/ai-portal/chat-box",Be={en:{[Fe.ASK_ANY_THING]:"Ask anything",[Fe.COMMON_TASKS]:"Common tasks"},zh:{[Fe.ASK_ANY_THING]:"询问任何问题",[Fe.COMMON_TASKS]:"常用任务"}},$e=b.i18n.getFixedT(null,He),qe=n.p+"images/af389fa6.svg";var Ge,Ke=n(47008);let Xe,Qe,Je,Ze,et,tt,nt,it,at,st,rt,ot,lt,ct,dt;(0,b.initializeI18n)(He,Be);const ut=(0,p.wrapBrick)("eo-icon"),{defineElement:ht,property:mt,event:pt}=(0,m.createDecorators)();let gt;var bt=new WeakMap,ft=new WeakMap,vt=new WeakMap,At=new WeakMap,kt=new WeakMap,xt=new WeakMap,Et=new WeakSet,wt=new WeakMap;class yt extends p.ReactNextElement{constructor(){super(...arguments),(0,a.A)(this,Et),(0,s.A)(this,bt,Qe(this)),(0,s.A)(this,ft,(Je(this),Ze(this))),(0,s.A)(this,vt,(et(this),tt(this))),(0,s.A)(this,At,(nt(this),it(this))),(0,s.A)(this,kt,(at(this),st(this))),(0,s.A)(this,xt,(rt(this),ot(this))),(0,s.A)(this,wt,(dt(this),e=>{(0,o.A)(Et,this,lt).emit(e)}))}get disabled(){return(0,c.A)(bt,this)}set disabled(e){(0,l.A)(bt,this,e)}get placeholder(){return(0,c.A)(ft,this)}set placeholder(e){(0,l.A)(ft,this,e)}get autoFocus(){return(0,c.A)(vt,this)}set autoFocus(e){(0,l.A)(vt,this,e)}get suggestions(){return(0,c.A)(At,this)}set suggestions(e){(0,l.A)(At,this,e)}get suggestionsLabel(){return(0,c.A)(kt,this)}set suggestionsLabel(e){(0,l.A)(kt,this,e)}render(){return h().createElement(Nt,{disabled:this.disabled,placeholder:this.placeholder,autoFocus:this.autoFocus,suggestions:this.suggestions,suggestionsLabel:this.suggestionsLabel,onSubmit:(0,c.A)(wt,this)})}}function Nt(e){let{disabled:t,placeholder:n,autoFocus:i,suggestions:a,suggestionsLabel:s,onSubmit:r}=e;const o=(0,u.useRef)(null),l=(0,u.useRef)(null),[c,d]=(0,u.useState)(""),m=(0,u.useRef)(""),p=(0,u.useCallback)((e=>{e.currentTarget.value&&(null==r||r(e.currentTarget.value))}),[r]),g=(0,u.useCallback)((e=>{m.current=e.target.value,d(e.target.value)}),[]),b=(0,u.useCallback)((()=>{null==r||r(m.current)}),[r]);(0,u.useEffect)((()=>{i&&Promise.resolve().then((()=>{var e;null===(e=l.current)||void 0===e||e.focus()}))}),[]);const f=(0,u.useMemo)((()=>null!=a&&a.length?(0,Ve.chunk)(a,Math.max(2,Math.ceil(a.length/2))):[]),[a]),v=(0,u.useCallback)((e=>{m.current=e.content,d(e.content),setTimeout((()=>{var e;null===(e=l.current)||void 0===e||e.focus()}))}),[]);return h().createElement("div",{className:"root"},h().createElement("div",{className:"container",ref:o},h().createElement(Le.e,{containerRef:o,ref:l,value:c,minRows:3,paddingSize:62,autoResize:!0,disabled:t,placeholder:null!=n?n:$e(Fe.ASK_ANY_THING),submitWhen:"enter-without-shift",onSubmit:p,onChange:g}),h().createElement("button",{className:"btn-send",disabled:!c,onClick:b},h().createElement(ut,{lib:"fa",prefix:"fas",icon:"arrow-up"}))),!(null==f||!f.length)&&h().createElement("div",{className:"suggestions"},h().createElement("div",{className:"heading"},h().createElement("img",{className:"icon",src:qe,width:16,height:16}),h().createElement("span",null,null!=s?s:$e(Fe.COMMON_TASKS))),f.map(((e,t)=>h().createElement(St,{key:t,suggestions:e,pixelPerSecond:10*(t+2),onSelect:v})))))}function St(e){let{suggestions:t,pixelPerSecond:n,onSelect:i}=e;const a=(0,u.useRef)(null),s=(0,u.useRef)(null),[r,o]=(0,u.useState)(0);return(0,u.useEffect)((()=>{const e=a.current,t=s.current;if(!e||!t)return;let i,r,l,c,d=0;const u=(t.offsetWidth-7)/2+7;function h(e){r=e,void 0===l&&(l=e),void 0!==i&&(d+=e-i,i=void 0),o((e-l-d)/1e3*n%u),c=requestAnimationFrame(h)}c=requestAnimationFrame(h);const m=()=>{cancelAnimationFrame(c),i=r},p=()=>{c=requestAnimationFrame(h)};return e.addEventListener("mouseenter",m),e.addEventListener("mouseleave",p),()=>{cancelAnimationFrame(c),e.removeEventListener("mouseenter",m),e.removeEventListener("mouseleave",p)}}),[t,n]),h().createElement("div",{className:"carousel",ref:a},h().createElement("ul",{className:"list",ref:s,style:{transform:`translateX(${-r}px)`}},[...t,...t].map(((e,t)=>h().createElement("li",{key:t},h().createElement("div",{className:"item",onClick:()=>i(e),title:e.content},h().createElement("div",{className:"title"},e.title),h().createElement("div",{className:"content"},e.content)))))))}Ge=yt,({e:[Qe,Je,Ze,et,tt,nt,it,at,st,rt,ot,lt,ct,dt],c:[gt,Xe]}=(0,d.A)(Ge,[ht("ai-portal.chat-box",{styleTexts:[Ke.A]})],[[mt({type:Boolean}),1,"disabled"],[mt(),1,"placeholder"],[mt({type:Boolean}),1,"autoFocus"],[mt({attribute:!1}),1,"suggestions"],[mt(),1,"suggestionsLabel"],[pt({type:"message.submit"}),1,"messageSubmit",e=>(0,c.A)(xt,e),(e,t)=>(0,l.A)(xt,e,t)]],0,(e=>wt.has((0,r.A)(e))),p.ReactNextElement)),Xe();var Tt,Mt=n(82165);let Ct;const{defineElement:Rt}=(0,m.createDecorators)();let _t;class It extends p.ReactNextElement{render(){return h().createElement(Yt,null)}}function Yt(){return h().createElement("slot",null)}Tt=It,[_t,Ct]=(0,d.A)(Tt,[Rt("ai-portal.home-container",{styleTexts:[Mt.A]})],[],0,void 0,p.ReactNextElement).c,Ct();var Wt=n(21302),Ot=n.n(Wt);let zt=function(e){return e.TODAY="TODAY",e.YESTERDAY="YESTERDAY",e.PREVIOUS_7_DAYS="PREVIOUS_7_DAYS",e.PREVIOUS_30_DAYS="PREVIOUS_30_DAYS",e}({});const Dt="bricks/ai-portal/chat-history",Ut={en:{[zt.TODAY]:"Today",[zt.YESTERDAY]:"Yesterday",[zt.PREVIOUS_7_DAYS]:"Previous 7 days",[zt.PREVIOUS_30_DAYS]:"Previous 30 days"},zh:{[zt.TODAY]:"今天",[zt.YESTERDAY]:"昨天",[zt.PREVIOUS_7_DAYS]:"过去7天",[zt.PREVIOUS_30_DAYS]:"过去30天"}},jt=b.i18n.getFixedT(null,Dt);var Pt,Lt=n(21411);let Vt,Ft,Ht,Bt,$t,qt,Gt,Kt,Xt,Qt,Jt,Zt,en,tn,nn;(0,b.initializeI18n)(Dt,Ut);const an=(0,p.wrapBrick)("eo-icon"),sn=(0,p.wrapBrick)("eo-link"),rn=(0,p.wrapBrick)("eo-mini-actions",{onActionClick:"action.click",onVisibleChange:"visible.change"}),{defineElement:on,property:ln,event:cn}=(0,m.createDecorators)();let dn;var un=new WeakMap,hn=new WeakMap,mn=new WeakMap,pn=new WeakMap,gn=new WeakSet,bn=new WeakMap,fn=new WeakMap,vn=new WeakMap;class An extends p.ReactNextElement{constructor(){super(...arguments),(0,a.A)(this,gn),(0,s.A)(this,un,Ft(this)),(0,s.A)(this,hn,(Ht(this),Bt(this))),(0,s.A)(this,mn,($t(this),qt(this))),(0,s.A)(this,pn,(Gt(this),Kt(this))),(0,s.A)(this,bn,(Jt(this),e=>{(0,o.A)(gn,this,Xt).emit(e)})),(0,s.A)(this,fn,Zt(this)),(0,s.A)(this,vn,(nn(this),e=>{(0,o.A)(gn,this,en).emit({nextToken:e})}))}get list(){return(0,c.A)(un,this)}set list(e){(0,l.A)(un,this,e)}get actions(){return(0,c.A)(hn,this)}set actions(e){(0,l.A)(hn,this,e)}get nextToken(){return(0,c.A)(mn,this)}set nextToken(e){(0,l.A)(mn,this,e)}render(){return h().createElement(kn,{root:this,list:this.list,actions:this.actions,nextToken:this.nextToken,onActionClick:(0,c.A)(bn,this),onLoadMore:(0,c.A)(vn,this)})}}function kn(e){let{root:t,list:n,actions:i,nextToken:a,onActionClick:s,onLoadMore:r}=e;const o=(0,u.useMemo)((()=>{const e=new Map,t=Ot()(),i=t.startOf("day"),a=i.clone().subtract(1,"day"),s=i.clone().subtract(7,"days"),r=i.clone().subtract(30,"days"),o=+i/1e3,l=+a/1e3,c=+s/1e3,d=+r/1e3,u=+t.startOf("year")/1e3;for(const t of null!=n?n:[]){let n;n=t.startTime>=o?jt(zt.TODAY):t.startTime>=l?jt(zt.YESTERDAY):t.startTime>=c?jt(zt.PREVIOUS_7_DAYS):t.startTime>=d?jt(zt.PREVIOUS_30_DAYS):t.startTime>=u?Ot()(1e3*t.startTime).format("MMMM"):Ot()(1e3*t.startTime).format("YYYY");let i=e.get(n);i||e.set(n,i={title:n,items:[]}),i.items.push(t)}return[...e.values()]}),[n]),[l,c]=(0,u.useState)(null),d=(0,u.useRef)(null);return(0,u.useEffect)((()=>{const e=d.current;if(!e||!a)return;const n=new IntersectionObserver((e=>{for(const t of e)t.isIntersecting&&r(a)}),{root:t});return n.observe(e),()=>{n.disconnect()}}),[a,r,t]),n?h().createElement(h().Fragment,null,h().createElement("ul",null,o.map((e=>h().createElement("li",{key:e.title,className:"group"},h().createElement("div",{className:"group-title"},e.title),h().createElement("ul",{className:"items"},e.items.map((e=>h().createElement("li",{key:e.id},h().createElement(sn,{className:v()("item",{active:l===e.id}),url:e.url},h().createElement("div",{className:"item-title",title:e.title},e.title),h().createElement(rn,{className:"actions",actions:i,onActionClick:t=>{s({action:t.detail,item:e})},onVisibleChange:t=>{c(t.detail?e.id:null)}}),!U.QB.includes(e.state)&&h().createElement("div",{className:"working"})))))))))),a&&h().createElement("div",{className:"load-more",ref:d},h().createElement(an,{lib:"antd",icon:"loading-3-quarters",spinning:!0}))):h().createElement("div",{className:"loading"},h().createElement(an,{lib:"antd",theme:"outlined",icon:"loading-3-quarters",spinning:!0}))}Pt=An,({e:[Ft,Ht,Bt,$t,qt,Gt,Kt,Xt,Qt,Jt,Zt,en,tn,nn],c:[dn,Vt]}=(0,d.A)(Pt,[on("ai-portal.chat-history",{styleTexts:[Lt.A]})],[[ln({attribute:!1}),1,"list"],[ln({attribute:!1}),1,"actions"],[ln(),1,"nextToken"],[cn({type:"action.click"}),1,"actionClick",e=>(0,c.A)(pn,e),(e,t)=>(0,l.A)(pn,e,t)],[cn({type:"load.more"}),1,"loadMore",e=>(0,c.A)(fn,e),(e,t)=>(0,l.A)(fn,e,t)]],0,(e=>vn.has((0,r.A)(e))),p.ReactNextElement)),Vt();var xn,En=n(89575),wn=n(24);let yn,Nn,Sn,Tn,Mn,Cn,Rn,_n,In,Yn,Wn,On,zn,Dn,Un,jn,Pn,Ln,Vn,Fn,Hn;const Bn=(0,p.wrapBrick)("eo-mini-line-chart"),{defineElement:$n,property:qn}=(0,m.createDecorators)();let Gn;var Kn=new WeakMap,Xn=new WeakMap,Qn=new WeakMap,Jn=new WeakMap,Zn=new WeakMap,ei=new WeakMap,ti=new WeakMap,ni=new WeakMap,ii=new WeakMap,ai=new WeakMap;class si extends p.ReactNextElement{constructor(){super(...arguments),(0,s.A)(this,Kn,Nn(this)),(0,s.A)(this,Xn,(Sn(this),Tn(this))),(0,s.A)(this,Qn,(Mn(this),Cn(this))),(0,s.A)(this,Jn,(Rn(this),_n(this))),(0,s.A)(this,Zn,(In(this),Yn(this))),(0,s.A)(this,ei,(Wn(this),On(this))),(0,s.A)(this,ti,(zn(this),Dn(this))),(0,s.A)(this,ni,(Un(this),jn(this))),(0,s.A)(this,ii,(Pn(this),Ln(this))),(0,s.A)(this,ai,(Vn(this),Fn(this))),Hn(this)}get label(){return(0,c.A)(Kn,this)}set label(e){(0,l.A)(Kn,this,e)}get value(){return(0,c.A)(Xn,this)}set value(e){(0,l.A)(Xn,this,e)}get size(){return(0,c.A)(Qn,this)}set size(e){(0,l.A)(Qn,this,e)}get lineColor(){return(0,c.A)(Jn,this)}set lineColor(e){(0,l.A)(Jn,this,e)}get showArea(){return(0,c.A)(Zn,this)}set showArea(e){(0,l.A)(Zn,this,e)}get min(){return(0,c.A)(ei,this)}set min(e){(0,l.A)(ei,this,e)}get max(){return(0,c.A)(ti,this)}set max(e){(0,l.A)(ti,this,e)}get xField(){return(0,c.A)(ni,this)}set xField(e){(0,l.A)(ni,this,e)}get yField(){return(0,c.A)(ii,this)}set yField(e){(0,l.A)(ii,this,e)}get data(){return(0,c.A)(ai,this)}set data(e){(0,l.A)(ai,this,e)}render(){return h().createElement(ri,{label:this.label,value:this.value,size:this.size,lineColor:this.lineColor,showArea:this.showArea,min:this.min,max:this.max,xField:this.xField,yField:this.yField,data:this.data})}}function ri(e){let{label:t,value:n,size:i,...a}=e;return"small"===i?h().createElement("div",{className:"container"},h().createElement("div",{className:"label-and-stat"},h().createElement("div",{className:"label"},t),h().createElement("div",{className:"stat"},n)),h().createElement("div",{className:"chart"},h().createElement(Bn,(0,En.A)({},a,{lineWidth:1.5,width:"auto",height:"55"})))):h().createElement("div",{className:"container"},h().createElement("div",{className:"label"},t),h().createElement("div",{className:"stat-and-chart"},h().createElement("div",{className:"chart"},h().createElement(Bn,(0,En.A)({},a,{lineWidth:2,width:"auto",height:"92"}))),h().createElement("div",{className:"stat"},n)))}xn=si,({e:[Nn,Sn,Tn,Mn,Cn,Rn,_n,In,Yn,Wn,On,zn,Dn,Un,jn,Pn,Ln,Vn,Fn,Hn],c:[Gn,yn]}=(0,d.A)(xn,[$n("ai-portal.stat-with-mini-chart",{styleTexts:[wn.A]})],[[qn(),1,"label"],[qn(),1,"value"],[qn(),1,"size"],[qn(),1,"lineColor"],[qn({type:Boolean}),1,"showArea"],[qn({type:Number}),1,"min"],[qn({type:Number}),1,"max"],[qn(),1,"xField"],[qn(),1,"yField"],[qn({attribute:!1}),1,"data"]],0,void 0,p.ReactNextElement)),yn();const oi=n.p+"images/7385e5f5.png";var li,ci=n(31653);let di;const{defineElement:ui}=(0,m.createDecorators)();let hi;class mi extends p.ReactNextElement{render(){return h().createElement(pi,null)}}function pi(){return h().createElement("img",{src:oi,alt:"Elevo",width:95,height:26})}li=mi,[hi,di]=(0,d.A)(li,[ui("ai-portal.elevo-logo",{styleTexts:[ci.A]})],[],0,void 0,p.ReactNextElement).c,di();let gi=function(e){return e.NEW_CHAT="NEW_CHAT",e.LOGOUT="LOGOUT",e.TODAY="TODAY",e.YESTERDAY="YESTERDAY",e.PREVIOUS_7_DAYS="PREVIOUS_7_DAYS",e.PREVIOUS_30_DAYS="PREVIOUS_30_DAYS",e}({});const bi="bricks/ai-portal/elevo-sidebar",fi={en:{[gi.NEW_CHAT]:"New chat",[gi.LOGOUT]:"Logout",[gi.TODAY]:"Today",[gi.YESTERDAY]:"Yesterday",[gi.PREVIOUS_7_DAYS]:"Previous 7 days",[gi.PREVIOUS_30_DAYS]:"Previous 30 days"},zh:{[gi.NEW_CHAT]:"新对话",[gi.LOGOUT]:"登出",[gi.TODAY]:"今天",[gi.YESTERDAY]:"昨天",[gi.PREVIOUS_7_DAYS]:"过去7天",[gi.PREVIOUS_30_DAYS]:"过去30天"}},vi=b.i18n.getFixedT(null,bi);var Ai=n(61408);const ki=(0,p.wrapBrick)("eo-icon"),xi=(0,p.wrapBrick)("eo-link"),Ei=(0,p.wrapBrick)("eo-dropdown-actions",{onActionClick:"action.click",onVisibleChange:"visible.change"}),wi=(0,p.wrapBrick)("eo-easyops-avatar"),yi=(0,p.wrapBrick)("eo-mini-actions",{onActionClick:"action.click",onVisibleChange:"visible.change"});var Ni=n(57372);const Si=async(e,t)=>(await Ni.http.post("api/gateway/logic.llm.aiops_service/api/v1/llm/agent/flow/search",e,t)).data;function Ti(e){let{actions:t=[],urlTemplate:n,onActionClick:i,onHistoryClick:a}=e;const s=(0,u.useRef)(null),[r,o]=(0,u.useState)(null),[l,c]=(0,u.useState)(),[d,m]=(0,u.useState)();(0,u.useEffect)((()=>{Promise.all([Si({next_token:d}),new Promise((e=>setTimeout(e,500)))]).then((e=>{let[t]=e;o((e=>[...null!=e?e:[],...t.data])),c(t.next_token)})).catch((e=>{console.error("Error loading chat history:",e)}))}),[d]);const p=(0,u.useMemo)((()=>{const e=new Map,t=Ot()(),n=t.startOf("day"),i=n.clone().subtract(1,"day"),a=n.clone().subtract(7,"days"),s=n.clone().subtract(30,"days"),o=+n/1e3,l=+i/1e3,c=+a/1e3,d=+s/1e3,u=+t.startOf("year")/1e3;for(const t of null!=r?r:[]){let n;n=t.startTime>=o?vi(gi.TODAY):t.startTime>=l?vi(gi.YESTERDAY):t.startTime>=c?vi(gi.PREVIOUS_7_DAYS):t.startTime>=d?vi(gi.PREVIOUS_30_DAYS):t.startTime>=u?Ot()(1e3*t.startTime).format("MMMM"):Ot()(1e3*t.startTime).format("YYYY");let i=e.get(n);i||e.set(n,i={title:n,items:[]}),i.items.push(t)}return[...e.values()]}),[r]),[g,b]=(0,u.useState)(null),f=(0,u.useRef)(null);return(0,u.useEffect)((()=>{const e=f.current,t=s.current;if(!e||!l||!t)return;const n=new IntersectionObserver((e=>{for(const t of e)t.isIntersecting&&m(l)}),{root:t});return n.observe(e),()=>{n.disconnect()}}),[l]),r?h().createElement("div",{className:"history",ref:s},h().createElement("ul",null,p.map((e=>h().createElement("li",{key:e.title,className:"group"},h().createElement("div",{className:"group-title"},e.title),h().createElement("ul",{className:"items"},e.items.map((e=>{return h().createElement("li",{key:e.id},h().createElement(xi,(0,En.A)({className:v()("item",{active:g===e.id}),onClick:a},n?{url:(s=n,r=e,null==s?void 0:s.replace(/{{(.*?)}}/g,((e,t)=>(0,Ve.get)(r,t))))}:null),h().createElement("div",{className:"item-title",title:e.title},e.title),h().createElement(yi,{className:"actions",actions:t,onActionClick:t=>{i({action:t.detail,item:e})},onVisibleChange:t=>{b(t.detail?e.id:null)}}),!U.QB.includes(e.state)&&h().createElement("div",{className:"working"})));var s,r}))))))),l&&h().createElement("div",{className:"load-more",ref:f},h().createElement(ki,{lib:"antd",icon:"loading-3-quarters",spinning:!0}))):h().createElement("div",{className:"history"},h().createElement("div",{className:"loading"},h().createElement(ki,{lib:"antd",theme:"outlined",icon:"loading-3-quarters",spinning:!0})))}var Mi;let Ci,Ri,_i,Ii,Yi,Wi,Oi,zi,Di,Ui,ji,Pi,Li,Vi,Fi,Hi,Bi,$i,qi,Gi,Ki;(0,b.initializeI18n)(bi,fi);const Xi=[{icon:{lib:"fa",prefix:"fas",icon:"arrow-right-from-bracket"},text:vi(gi.LOGOUT)}],{defineElement:Qi,property:Ji,event:Zi}=(0,m.createDecorators)();let ea;var ta=new WeakMap,na=new WeakMap,ia=new WeakMap,aa=new WeakMap,sa=new WeakMap,ra=new WeakMap,oa=new WeakMap,la=new WeakSet,ca=new WeakMap,da=new WeakMap,ua=new WeakMap;class ha extends p.ReactNextElement{constructor(){super(...arguments),(0,a.A)(this,la),(0,s.A)(this,ta,Ri(this)),(0,s.A)(this,na,(_i(this),Ii(this))),(0,s.A)(this,ia,(Yi(this),Wi(this))),(0,s.A)(this,aa,(Oi(this),zi(this))),(0,s.A)(this,sa,(Di(this),Ui(this))),(0,s.A)(this,ra,(ji(this),Pi(this))),(0,s.A)(this,oa,(Li(this),Vi(this))),(0,s.A)(this,ca,(Bi(this),()=>{(0,o.A)(la,this,Fi).emit()})),(0,s.A)(this,da,$i(this)),(0,s.A)(this,ua,(Ki(this),e=>{(0,o.A)(la,this,qi).emit(e)}))}get userInstanceId(){return(0,c.A)(ta,this)}set userInstanceId(e){(0,l.A)(ta,this,e)}get behavior(){return(0,c.A)(na,this)}set behavior(e){(0,l.A)(na,this,e)}get logoUrl(){return(0,c.A)(ia,this)}set logoUrl(e){(0,l.A)(ia,this,e)}get newChatUrl(){return(0,c.A)(aa,this)}set newChatUrl(e){(0,l.A)(aa,this,e)}get historyUrlTemplate(){return(0,c.A)(sa,this)}set historyUrlTemplate(e){(0,l.A)(sa,this,e)}get historyActions(){return(0,c.A)(ra,this)}set historyActions(e){(0,l.A)(ra,this,e)}render(){return h().createElement(ma,{userInstanceId:this.userInstanceId,behavior:this.behavior,logoUrl:this.logoUrl,newChatUrl:this.newChatUrl,historyUrlTemplate:this.historyUrlTemplate,historyActions:this.historyActions,onLogout:(0,c.A)(ca,this),onActionClick:(0,c.A)(ua,this)})}}function ma(e){let{userInstanceId:t,behavior:n,logoUrl:i,newChatUrl:a,historyUrlTemplate:s,historyActions:r,onLogout:o,onActionClick:l}=e;const[c,d]=(0,u.useState)("drawer"===n),m=(0,u.useCallback)((()=>{d(!0)}),[]),p=(0,u.useCallback)((()=>{d(!1)}),[]);(0,u.useEffect)((()=>{"drawer"===n&&d(!0)}),[n]);const g=(0,u.useCallback)((()=>{d(!0)}),[]),b=(0,u.useCallback)((()=>{"drawer"===n&&d(!0)}),[n]);return h().createElement("div",{className:v()("container",{collapsed:c})},"drawer"===n&&!c&&h().createElement("div",{className:"mask",onClick:g}),h().createElement("div",{className:"sidebar"},h().createElement("div",{className:"logo-bar"},h().createElement(xi,{url:i,className:"logo-link"},h().createElement("img",{className:"logo",alt:"Elevo",src:oi,width:95,height:26})),h().createElement("button",{className:"toggle",onClick:m},h().createElement(ki,{lib:"easyops",icon:"sidebar"}))),h().createElement(xi,{className:"new-chat",url:a},h().createElement(ki,{className:"new-chat-icon",lib:"easyops",icon:"new-chat"}),vi(gi.NEW_CHAT)),h().createElement(Ti,{urlTemplate:s,actions:r,onActionClick:l,onHistoryClick:b}),h().createElement("div",{className:"footer"},h().createElement(Ei,{className:"dropdown",actions:Xi,onActionClick:o},h().createElement("button",{className:"account"},h().createElement(wi,{nameOrInstanceId:t,showName:!0,size:"xs"}))))),h().createElement("div",{className:"alternative"},h().createElement("button",{className:"toggle",onClick:p},h().createElement(ki,{lib:"easyops",icon:"sidebar"})),h().createElement(xi,{className:"new-chat",url:a},h().createElement(ki,{className:"new-chat-icon",lib:"easyops",icon:"new-chat"}),vi(gi.NEW_CHAT))))}Mi=ha,({e:[Ri,_i,Ii,Yi,Wi,Oi,zi,Di,Ui,ji,Pi,Li,Vi,Fi,Hi,Bi,$i,qi,Gi,Ki],c:[ea,Ci]}=(0,d.A)(Mi,[Qi("ai-portal.elevo-sidebar",{styleTexts:[Ai.A]})],[[Ji(),1,"userInstanceId"],[Ji(),1,"behavior"],[Ji(),1,"logoUrl"],[Ji(),1,"newChatUrl"],[Ji(),1,"historyUrlTemplate"],[Ji({attribute:!1}),1,"historyActions"],[Zi({type:"logout"}),1,"logout",e=>(0,c.A)(oa,e),(e,t)=>(0,l.A)(oa,e,t)],[Zi({type:"action.click"}),1,"actionClick",e=>(0,c.A)(da,e),(e,t)=>(0,l.A)(da,e,t)]],0,(e=>ua.has((0,r.A)(e))),p.ReactNextElement)),Ci()},31653:(e,t,n)=>{n.d(t,{A:()=>o});var i=n(36758),a=n.n(i),s=n(40935),r=n.n(s)()(a());r.push([e.id,":host{display:inline-block;padding:3px 0}:host([hidden]){display:none}img{display:block}",""]);const o=r.toString()},32360:(e,t,n)=>{e.exports=n.p+"images/6336f999.png"},47008:(e,t,n)=>{n.d(t,{A:()=>h});var i=n(36758),a=n.n(i),s=n(40935),r=n.n(s),o=n(20062),l=n.n(o),c=new URL(n(91107),n.b),d=r()(a()),u=l()(c);d.push([e.id,`:host{display:block}:host([hidden]){display:none}*{box-sizing:border-box}.root{color:#262626;background-color:#e1e3ec;background-image:url(${u});background-size:694px 144px;background-position:top left;background-repeat:no-repeat;box-shadow:inset 0px 2px 5px 1px rgba(42,46,59,0.1);border-radius:20px;padding:12px}.container{position:relative}textarea{display:block;width:100%;padding:10px 16px 52px;color:var(--antd-input-color);background:rgba(255,255,255,0.8);border-radius:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.5);font-size:14px;line-height:22px;height:130px}textarea::placeholder{color:rgba(0,0,0,0.4)}.btn-send:focus,\ntextarea:focus{outline:none}.btn-send{position:absolute;bottom:14px;right:14px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#2540ff;border:none;border-radius:8px;color:#fff}.btn-send[disabled]{background:rgba(0,0,0,0.15)}.btn-send:not([disabled]){cursor:pointer}.btn-send:not([disabled]):hover{background:#5166ff}.btn-send:not([disabled]):active{background:#1e33cc}.suggestions{margin-top:19px}.heading{display:flex;align-items:center;padding:0 5px;margin-bottom:8px}.icon{margin-right:5px}.carousel{overflow:hidden}.carousel + .carousel{margin-top:7px}.list{display:flex;width:max-content;list-style:none;margin:0;padding:0;font-size:12px}.item{background:rgba(255,255,255,0.4);border-radius:12px;border:1px solid #dcdee6;padding:12px;max-width:330px;cursor:pointer}.item:hover{background:rgba(255,255,255,0.5);border:1px solid rgba(37,64,255,0.3)}.list > li + li{margin-left:7px}.title{margin-bottom:4px}.content{color:rgba(0,0,0,0.45);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tooltip{display:block}`,""]);const h=d.toString()},61408:(e,t,n)=>{n.d(t,{A:()=>o});var i=n(36758),a=n.n(i),s=n(40935),r=n.n(s)()(a());r.push([e.id,':host{display:block}:host([hidden]){display:none}*{box-sizing:border-box}.sidebar{position:relative;width:261px;height:100%;background:#f6f7f9;border-right:1px solid #e3e5eb;padding:26px 16px 0;display:flex;flex-direction:column;transition:transform 0.3s ease-in-out}.logo-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px}.logo-link::part(link){display:block}.logo{vertical-align:middle}.toggle{color:#595959;font-size:18px;width:28px;height:28px;display:flex;align-items:center;justify-content:space-between;background:none;border:none;cursor:pointer;border-radius:8px}.toggle:hover{background:rgba(0,0,0,0.04)}.new-chat::part(link){display:flex;align-items:center;color:var(--elevo-color-brand);font-size:14px;text-align:left;cursor:pointer}.sidebar .new-chat::part(link){background:#f0f4ff;border-radius:8px;border:1px solid #c9d7ff;padding:9px 13px;font-weight:500;margin-bottom:23px}.sidebar .new-chat::part(link):hover{background:rgba(201,215,255,0.5)}.new-chat-icon{font-size:16px;margin-right:5px}.footer{border-top:1px solid rgba(0,0,0,0.04);padding:9px 12px;margin:0 -16px}.dropdown{display:block}.account{background:none;border:none;border-radius:8px;padding:6px 10px;display:block;width:100%;text-align:left;cursor:pointer}.account:hover{background:rgba(0,0,0,0.04)}.alternative{position:fixed;top:14px;left:16px;display:flex;align-items:center;opacity:0;z-index:1;transition:opacity 0.2s ease-in-out}.alternative .new-chat::part(link){padding:4px;margin-left:16px;font-size:12px}.alternative .new-chat::part(link):hover{color:#7891ff}.alternative .new-chat::part(link):active{color:#0911b3}.container{width:261px;height:100%;transition:width 0.3s ease-in-out}.collapsed{width:0;overflow:visible}.collapsed .sidebar{transform:translateX(-100%)}.collapsed .alternative{opacity:1}:host([behavior="drawer"]){z-index:1;width:0}:host(:not([behavior="drawer"])) .alternative .new-chat{display:none}.mask{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--antd-modal-mask-bg)}.history{flex:1;min-height:0;overflow-y:auto;margin:0 -16px;padding:0 12px}.history ul{list-style:none;margin:0;padding:0}.history .loading{display:flex;justify-content:center;padding:8px}.history .group + .group{margin-top:15px}.history .group-title{font-weight:500;font-size:12px;color:#000;padding:8px;height:36px;line-height:20px}.history .item{display:block}.history .item::part(link){display:flex;align-items:center;padding:0 8px;height:36px;border-radius:8px;color:#000}.history .item::part(link):hover{background:rgba(0,0,0,0.04)}.history .item-title{flex:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.history .actions{cursor:auto}.history .item:not(:hover):not(.active) .actions{display:none}.history .working{width:8px;height:8px;border-radius:8px;background:#2540ff;margin:0 7px}.history .item:hover .working,.history .item.active .working{display:none}.history .load-more{display:flex;justify-content:center;align-items:center;height:36px}',""]);const o=r.toString()},82165:(e,t,n)=>{n.d(t,{A:()=>h});var i=n(36758),a=n.n(i),s=n(40935),r=n.n(s),o=n(20062),l=n.n(o),c=new URL(n(32360),n.b),d=r()(a()),u=l()(c);d.push([e.id,`:host{display:block;background-color:#fff;background-image:url(${u});background-position:center;background-size:cover;background-repeat:no-repeat;background-attachment:fixed}:host([hidden]){display:none}`,""]);const h=d.toString()},91107:(e,t,n)=>{e.exports=n.p+"images/eef4f2bd.png"}}]);
3
- //# sourceMappingURL=6220.43f2b07b.js.map
1
+ /*! For license information please see 6220.865493dc.js.LICENSE.txt */
2
+ "use strict";(globalThis.webpackChunk_next_bricks_ai_portal=globalThis.webpackChunk_next_bricks_ai_portal||[]).push([[6220],{24:(e,t,n)=>{n.d(t,{A:()=>o});var i=n(36758),a=n.n(i),s=n(40935),r=n.n(s)()(a());r.push([e.id,':host{display:block;white-space:nowrap}.container{border-radius:var(--elevo-border-radius)}:host([hidden]){display:none}*{box-sizing:border-box}.label{font-weight:500;overflow:hidden;text-overflow:ellipsis}.stat{font-weight:600}.chart{min-width:0}.chart > *{display:block}:host(:not([size="small"])) .container{background:linear-gradient(164deg,rgba(105,153,253,0) 40%,rgba(105,153,253,0.05) 60%,rgba(105,153,253,0.32) 100%),#fff;padding:22px}:host(:not([size="small"])) .label{font-size:14px;height:22px;margin-bottom:16px}:host(:not([size="small"])) .stat-and-chart{display:flex;align-items:center;justify-content:end;position:relative}:host(:not([size="small"])) .stat{font-size:36px;color:#1d212a;position:absolute;left:0}:host(:not([size="small"])) .chart{width:calc(100% - 160px)}:host([size="small"]) .container{padding:11px 15px;display:flex;align-items:center;justify-content:end;position:relative;background:var(--elevo-component-background);-webkit-backdrop-filter:var(--elevo-component-backdrop-filter);backdrop-filter:var(--elevo-component-backdrop-filter)}:host([size="small"]) .label-and-stat{position:absolute;left:15px}:host([size="small"]) .label{font-size:12px;color:#8c8c8c;line-height:17px;height:17px;margin-bottom:7px}:host([size="small"]) .stat{font-size:20px;color:#262626;line-height:24px}:host([size="small"]) .chart{width:calc(100% - 90px)}',""]);const o=r.toString()},21411:(e,t,n)=>{n.d(t,{A:()=>o});var i=n(36758),a=n.n(i),s=n(40935),r=n.n(s)()(a());r.push([e.id,":host{display:block}:host([hidden]){display:none}*{box-sizing:border-box}ul{list-style:none;margin:0;padding:0}.loading{display:flex;justify-content:center;padding:8px}.group + .group{margin-top:15px}.group-title{font-weight:500;font-size:12px;color:#000;padding:8px;height:36px;line-height:20px}.item{display:block}.item::part(link){display:flex;align-items:center;padding:0 8px;height:36px;border-radius:8px;color:#000}.item::part(link):hover{background:rgba(0,0,0,0.04)}.item-title{flex:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.actions{cursor:auto}.item:not(:hover):not(.active) .actions{display:none}.working{width:8px;height:8px;border-radius:8px;background:#2540ff;margin:0 7px}.item:hover .working,\n.item.active .working{display:none}.load-more{display:flex;justify-content:center;align-items:center;height:36px}",""]);const o=r.toString()},26093:(e,t,n)=>{var i,a=n(74635),s=n(70918),r=n(26902),o=n(5536),l=n(86121),c=n(70829),d=n(62740),u=n(18769),h=n.n(u),m=n(7921),p=n(11280),g=n(23081),b=(n(65168),n(90079)),f=n(53373),v=n.n(f),A=n(99126),k=n(67566),x=n(8324),E=n(69445),y=n(2460),w=n(32464),N=n(58231),S=n(36494),T=n(97642),M=n(92773),C=n(59533),R=n(13153),I=n(34999),_=n(27954),W=n(24388),Y=n(56938),O=n(77971),z=n(39295),D=n(39194),U=n(16854),j=n(55805),P=n(85620),L=n(73349),V=n(62601),F=n(57097),H=n(83490);let B,$,q,G,K,X,Q,J,Z,ee,te,ne,ie,ae,se,re,oe,le,ce,de,ue,he,me,pe,ge,be;(0,b.initializeI18n)(y.NS,y.I);const{defineElement:fe,property:ve,event:Ae,method:ke}=(0,m.createDecorators)(),xe=(0,u.memo)(Pe),Ee=(0,u.forwardRef)(je);let ye;var we=new WeakMap,Ne=new WeakMap,Se=new WeakMap,Te=new WeakMap,Me=new WeakMap,Ce=new WeakSet,Re=new WeakMap,Ie=new WeakMap,_e=new WeakMap,We=new WeakMap,Ye=new WeakMap,Oe=new WeakMap,ze=new WeakMap,De=new WeakMap;class Ue extends p.ReactNextElement{constructor(){super(...arguments),(0,a.A)(this,Ce),(0,s.A)(this,we,(B(this),q(this))),(0,s.A)(this,Ne,(G(this),K(this))),(0,s.A)(this,Se,(X(this),Q(this))),(0,s.A)(this,Te,(J(this),Z(this))),(0,s.A)(this,Me,(ee(this),te(this))),(0,s.A)(this,Re,(ae(this),()=>{(0,o.A)(Ce,this,ne).emit()})),(0,s.A)(this,Ie,se(this)),(0,s.A)(this,_e,(le(this),()=>{(0,o.A)(Ce,this,re).emit()})),(0,s.A)(this,We,ce(this)),(0,s.A)(this,Ye,(he(this),()=>{(0,o.A)(Ce,this,de).emit()})),(0,s.A)(this,Oe,me(this)),(0,s.A)(this,ze,(be(this),()=>{(0,o.A)(Ce,this,pe).emit()})),(0,s.A)(this,De,(0,u.createRef)())}get taskId(){return(0,c.A)(we,this)}set taskId(e){(0,l.A)(we,this,e)}get task(){return(0,c.A)(Ne,this)}set task(e){(0,l.A)(Ne,this,e)}get jobs(){return(0,c.A)(Se,this)}set jobs(e){(0,l.A)(Se,this,e)}get replay(){return(0,c.A)(Te,this)}set replay(e){(0,l.A)(Te,this,e)}resumed(){var e;null===(e=(0,c.A)(De,this).current)||void 0===e||e.resumed()}render(){return h().createElement(Ee,{taskId:this.taskId,jobs:this.jobs,task:this.task,replay:this.replay,onShare:(0,c.A)(Re,this),onPause:(0,c.A)(_e,this),onResume:(0,c.A)(Ye,this),onCancel:(0,c.A)(ze,this),ref:(0,c.A)(De,this)})}}function je(e,t){var n;let{taskId:i,task:a,jobs:s,replay:r,onShare:o,onPause:l,onResume:c,onCancel:d}=e;const m=(0,u.useRef)(null),{task:p,jobs:b,plan:f,error:A,humanInputRef:y,resumedRef:_}=(0,M.S)(i,r),W=i?p:a,Y=i?b:s,O=i?f:null==a?void 0:a.plan,z=(0,C.B)(W,Y),D=null==z?void 0:z.nodes,B=null==z?void 0:z.edges,$=null==z?void 0:z.nav,q=null==z?void 0:z.views,G=null!==(n=null==W?void 0:W.title)&&void 0!==n?n:"",K=null==W?void 0:W.state,[X,Q]=(0,u.useState)(null),J=(0,u.useMemo)((()=>{if(X){const[e,t]=X.split(":");if("job"===e||"view"===e)return t}return null}),[X]);(0,u.useImperativeHandle)(t,(()=>({resumed:()=>{var e;return null===(e=_.current)||void 0===e?void 0:e.call(_)}})),[_]);const Z=(0,u.useRef)(!1);(0,u.useEffect)((()=>{const e=setTimeout((()=>{Z.current=!0}),3e3);return()=>{clearTimeout(e)}}),[]),(0,u.useEffect)((()=>{(0,g.getRuntime)().applyPageTitle(G)}),[G]),(0,u.useEffect)((()=>{A&&(0,g.handleHttpError)(A)}),[A]);const ee=(0,u.useCallback)(((e,t)=>{var n;null===(n=y.current)||void 0===n||n.call(y,e,t)}),[y]),[te,ne]=(0,u.useState)(null),ie=(0,u.useCallback)(((e,t)=>{ne((n=>{if(!t){if(!n)return null;const t=new Map(n);return t.delete(e)?t:n}return n?new Map(n).set(e,t):new Map([[e,t]])}))}),[]),{sizeReady:ae,nodes:se,edges:re}=(0,T.g)({rawNodes:D,rawEdges:B,state:K,sizeMap:te}),oe=(0,u.useRef)(!1),le=(0,u.useRef)(!1),[ce,de]=(0,u.useState)(!1),{grabbing:ue,transform:he,transformRef:me,zoomer:pe}=(0,N.f)({rootRef:m,zoomable:ae,scrollable:ae&&!ce,pannable:ae,manualScrolledUpRef:le}),ge=(0,u.useRef)(!1),be=(0,u.useMemo)((()=>{let e=null;const t=n=>{const i=me.current,a="function"==typeof n?n(i):n;if(!a)return;const{transform:s,translateBy:r}=a;let o=(0,k.A)(m.current);var l,c,d,u,h,p;Z.current&&0!==a.duration&&(ge.current=!0,o=o.transition().duration(null!==(l=a.duration)&&void 0!==l?l:300).ease((e=>e*(2-e))).on("end",(()=>{if(ge.current=!1,e){const n=e;e=null,t(n)}}))),s?pe.transform(o,new x.uV(null!==(c=s.k)&&void 0!==c?c:i.k,null!==(d=s.x)&&void 0!==d?d:i.x,null!==(u=s.y)&&void 0!==u?u:i.y)):pe.translateBy(o,null!==(h=r[0])&&void 0!==h?h:0,null!==(p=r[1])&&void 0!==p?p:0)};return n=>{ge.current?e=n:t(n)}}),[me,pe]),{centered:fe,setCentered:ve,reCenterRef:Ae}=(0,S.E)({nodes:se,sizeReady:ae,zoomer:pe,rootRef:m,pushZoomTransition:be}),ke=!U.QB.includes(null!=K?K:"working")&&2===se.length,Ee=(0,u.useMemo)((()=>new Set(re.map((e=>e.source)))),[re]),ye=(0,u.useMemo)((()=>{if(!ae)return null;const e=[];for(const t of se)Ee.has(t.id)||e.push(t);return e.length>0?Math.max(...e.map((e=>e.view.y+e.view.height))):null}),[se,Ee,ae]),we=(0,u.useRef)(null);(0,u.useEffect)((()=>{we.current=ye}),[ye]),(0,u.useEffect)((()=>{const e=m.current;!e||null===ye||oe.current&&le.current||be((t=>{const{offsetHeight:n}=e,i=ye*t.k+t.y,a=n-U.xX-i;return a<0?{transform:{y:t.y+a},duration:a>-100?100:a<-500?300:200}:null}))}),[ye,be]),(0,u.useEffect)((()=>{const e=we.current,t=m.current;if(!t||null===e||ge.current)return;const{offsetHeight:n}=t,i=e*he.k+he.y,a=n-U.xX-i;oe.current=a<0}),[he,pe]);const Ne=(0,u.useCallback)((()=>{Ae.current=!0,ve(!1)}),[Ae,ve]),Se=(0,u.useCallback)((e=>{pe.scaleTo((0,k.A)(m.current),e)}),[pe]),Te=(0,u.useMemo)((()=>ae?(0,E.o)(se.map((e=>e.view))):null),[se,ae]);(0,u.useEffect)((()=>{if(!Te)return;const e=m.current;if(!e)return;const{offsetWidth:t,offsetHeight:n}=e,i=t/he.k,a=n/he.k,s=-(i-20-Te.x),r=i-20+(Te.x+Te.width),o=-(a-20-Te.y),l=a-20+(Te.y+Te.height);pe.translateExtent([[s,o],[r,l]])}),[pe,he.k,Te]);const Me=(0,u.useCallback)((e=>{let{nodeId:t,jobId:n,behavior:i,block:a}=e;const s=m.current,r=se.filter((e=>{var i;return!(t&&e.id!==t||n&&(null===(i=e.job)||void 0===i?void 0:i.id)!==n)}));if(!s||0===r.length)return;const o=(0,E.o)(r.map((e=>e.view))),{x:l,y:c}=(0,V.D)(o,[s.offsetWidth,s.offsetHeight],[U.RV,U.kq,U.xX,U.bL],me.current,a);(l||c)&&be({translateBy:[l,c],duration:"instant"===i?0:void 0})}),[se,be,me]),Ce=(0,u.useCallback)(((e,t)=>{const n=m.current;if(!n||!ae)return;let i,a=0,s=0,r=300;const o="left"===e||"right"===e;if("line"===t)i=40*("up"===e||"left"===e?1:-1),r=150;else if("page"===t)i=(n.offsetHeight-U.xX)*("up"===e?-1:1);else{const{y:t,height:a}=(0,E.o)(se.map((e=>e.view)));if("down"===e){const e=t+a-t+U.xX;i=n.offsetHeight-e-me.current.y}else i=t+U.RV-me.current.y}o?a=i:s=i,(a||s)&&be({translateBy:[a,s],duration:r})}),[se,be,ae,me]),[Re,Ie]=(0,u.useState)(null),[_e,We]=(0,u.useState)(null),Ye=(0,u.useMemo)((()=>({humanInput:ee,onShare:o,onPause:l,onResume:c,onCancel:d,onNodeResize:ie,activeToolCallJobId:Re,setActiveToolCallJobId:Ie,setActiveNodeId:Q,hoverOnScrollableContent:ce,setHoverOnScrollableContent:de,activeExpandedViewJobId:_e,setActiveExpandedViewJobId:We})),[Re,ce,_e,ie,ee,o,l,c,d]),Oe=(0,u.useMemo)((()=>Re?null==Y?void 0:Y.find((e=>e.id===Re)):null),[Re,Y]),ze=(0,u.useCallback)((e=>{for(const t of e.nativeEvent.composedPath()){if(t instanceof HTMLElement&&t.classList.contains(w.A.node))return;if(t===m.current)break}Q(null)}),[]);return(0,u.useEffect)((()=>{const e=m.current;if(!e||Oe||_e)return;const t=t=>{if(document.activeElement&&document.activeElement!==document.body&&document.activeElement!==e)return;const n=(0,F.l)(t,{activeNodeId:X,nodes:se});if(!n)return;const{action:i,node:a}=n;if("scroll"===i)Ce(n.direction,n.range);else if("enter"===i){var s,r;if("job"!==a.type&&"view"!==a.type)return;const e="ask_human"===(null===(s=a.job.toolCall)||void 0===s?void 0:s.name),t="ask_human_confirming_plan"===(null===(r=a.job.toolCall)||void 0===r?void 0:r.name);if(e||t)return}t.preventDefault(),t.stopPropagation(),"enter"===i?"view"===a.type?We(a.job.id):Ie(a.job.id):"switch-active-node"===i&&(Q(a.id),"job"===a.type||"view"===a.type?Me({jobId:a.job.id,behavior:"smooth"}):Me({nodeId:a.id,behavior:"smooth"}))};return document.addEventListener("keydown",t),()=>{document.removeEventListener("keydown",t)}}),[X,Oe,_e,se,Me,Ce]),h().createElement(P.Q.Provider,{value:Ye},h().createElement("div",{className:v()(w.A.root,{[w.A.loading]:!W}),ref:m,style:{cursor:ue?"grabbing":"grab"},tabIndex:-1,onClick:ze},!W&&h().createElement("div",{className:w.A["loading-icon"]},h().createElement(j.Bj,{lib:"antd",theme:"outlined",icon:"loading-3-quarters",spinning:!0})),h().createElement("div",{className:v()(w.A.canvas,{[w.A.ready]:ae&&fe}),style:{transform:`translate3d(${he.x}px, ${he.y}px, 0) scale(${he.k})`}},h().createElement("svg",{className:w.A.edges},re.map((e=>h().createElement("path",{className:w.A.edge,key:`${e.source}-${e.target}`,d:e.points.map(((e,t)=>{let{x:n,y:i}=e;return`${0===t?"M":"L"}${n},${i}`})).join(" ")})))),se.map((e=>{var t,n,i;return h().createElement(xe,{key:e.id,id:e.id,type:e.type,content:e.content,job:e.job,state:e.state,startTime:null==W?void 0:W.startTime,taskLoading:ke,instructionLoading:"instruction"===e.type&&!Ee.has(e.id)&&!U.QB.includes(null!==(t=e.state)&&void 0!==t?t:"working")&&!U.X4.includes(null!=K?K:"working"),edges:re,x:null===(n=e.view)||void 0===n?void 0:n.x,y:null===(i=e.view)||void 0===i?void 0:i.y,active:X===e.id})})))),h().createElement("div",{className:w.A.widgets},h().createElement("div",{className:w.A["nav-container"]},h().createElement("ul",{className:w.A.nav},null==$?void 0:$.map((e=>h().createElement("li",{key:e.id,className:v()(w.A["nav-item"],{[w.A.active]:J===e.id})},h().createElement("a",{className:w.A["nav-link"],onClick:()=>{Q(`job:${e.id}`),Me({jobId:e.id,block:"start"})}},h().createElement("span",{className:w.A["nav-link-text"]},e.title))))))),h().createElement(R.r,{plan:O,state:K}),h().createElement(I.l,{scale:he.k,onScaleChange:Se,onReCenter:Ne})),Oe&&h().createElement(L.M,{job:Oe}),_e&&h().createElement(H.f,{views:q}))}function Pe(e){let{id:t,type:n,state:i,job:a,content:s,startTime:r,taskLoading:o,instructionLoading:l,x:c,y:d,active:m}=e;const p=(0,u.useRef)(null),{onNodeResize:g,setActiveNodeId:b}=(0,u.useContext)(P.Q);(0,u.useEffect)((()=>{const e=p.current;if(!e)return;const n=new A.A((()=>{g(t,[e.offsetWidth,e.offsetHeight])}));return n.observe(e),()=>{n.disconnect(),g(t,null)}}),[t,g]),(0,u.useEffect)((()=>{const e=p.current;if(!e)return;const t=e=>{e.stopPropagation()};return e.addEventListener("mousedown",t),()=>{e.removeEventListener("mousedown",t)}}),[]);const f=(0,u.useCallback)((()=>{"start"!==n&&"instruction"!==n&&b(t)}),[t,b,n]);return h().createElement("div",{className:v()(w.A.node,{[w.A.ready]:null!=c&&null!=d}),ref:p,style:{left:c,top:d},onClick:f},"start"===n?h().createElement(_.H,null):"end"===n?h().createElement(z.s,{active:m}):"requirement"===n?h().createElement(W.O,{content:s,startTime:r,loading:o,active:m}):"instruction"===n?h().createElement(Y.L,{content:a.instruction,loading:l}):"view"===n?h().createElement(D.Y,{job:a,active:m}):h().createElement(O.W,{state:i,job:a,active:m}))}i=Ue,({e:[q,G,K,X,Q,J,Z,ee,te,ne,ie,ae,se,re,oe,le,ce,de,ue,he,me,pe,ge,be,B],c:[ye,$]}=(0,d.A)(i,[fe("ai-portal.cruise-canvas",{shadowOptions:!1})],[[ve(),1,"taskId"],[ve({attribute:!1}),1,"task"],[ve({attribute:!1}),1,"jobs"],[ve({type:Number}),1,"replay"],[Ae({type:"share"}),1,"shareEvent",e=>(0,c.A)(Me,e),(e,t)=>(0,l.A)(Me,e,t)],[Ae({type:"pause"}),1,"pauseEvent",e=>(0,c.A)(Ie,e),(e,t)=>(0,l.A)(Ie,e,t)],[Ae({type:"resume"}),1,"resumeEvent",e=>(0,c.A)(We,e),(e,t)=>(0,l.A)(We,e,t)],[Ae({type:"cancel"}),1,"cancelEvent",e=>(0,c.A)(Oe,e),(e,t)=>(0,l.A)(Oe,e,t)],[ke(),2,"resumed"]],0,(e=>De.has((0,r.A)(e))),p.ReactNextElement)),$();var Le=n(71451),Ve=n(41030);let Fe=function(e){return e.ASK_ANY_THING="ASK_ANYTHING",e.COMMON_TASKS="COMMON_TASKS",e}({});const He="bricks/ai-portal/chat-box",Be={en:{[Fe.ASK_ANY_THING]:"Ask anything",[Fe.COMMON_TASKS]:"Common tasks"},zh:{[Fe.ASK_ANY_THING]:"询问任何问题",[Fe.COMMON_TASKS]:"常用任务"}},$e=b.i18n.getFixedT(null,He),qe=n.p+"images/af389fa6.svg";var Ge,Ke=n(47008);let Xe,Qe,Je,Ze,et,tt,nt,it,at,st,rt,ot,lt,ct,dt;(0,b.initializeI18n)(He,Be);const ut=(0,p.wrapBrick)("eo-icon"),{defineElement:ht,property:mt,event:pt}=(0,m.createDecorators)();let gt;var bt=new WeakMap,ft=new WeakMap,vt=new WeakMap,At=new WeakMap,kt=new WeakMap,xt=new WeakMap,Et=new WeakSet,yt=new WeakMap;class wt extends p.ReactNextElement{constructor(){super(...arguments),(0,a.A)(this,Et),(0,s.A)(this,bt,Qe(this)),(0,s.A)(this,ft,(Je(this),Ze(this))),(0,s.A)(this,vt,(et(this),tt(this))),(0,s.A)(this,At,(nt(this),it(this))),(0,s.A)(this,kt,(at(this),st(this))),(0,s.A)(this,xt,(rt(this),ot(this))),(0,s.A)(this,yt,(dt(this),e=>{(0,o.A)(Et,this,lt).emit(e)}))}get disabled(){return(0,c.A)(bt,this)}set disabled(e){(0,l.A)(bt,this,e)}get placeholder(){return(0,c.A)(ft,this)}set placeholder(e){(0,l.A)(ft,this,e)}get autoFocus(){return(0,c.A)(vt,this)}set autoFocus(e){(0,l.A)(vt,this,e)}get suggestions(){return(0,c.A)(At,this)}set suggestions(e){(0,l.A)(At,this,e)}get suggestionsLabel(){return(0,c.A)(kt,this)}set suggestionsLabel(e){(0,l.A)(kt,this,e)}render(){return h().createElement(Nt,{disabled:this.disabled,placeholder:this.placeholder,autoFocus:this.autoFocus,suggestions:this.suggestions,suggestionsLabel:this.suggestionsLabel,onSubmit:(0,c.A)(yt,this)})}}function Nt(e){let{disabled:t,placeholder:n,autoFocus:i,suggestions:a,suggestionsLabel:s,onSubmit:r}=e;const o=(0,u.useRef)(null),l=(0,u.useRef)(null),[c,d]=(0,u.useState)(""),m=(0,u.useRef)(""),p=(0,u.useCallback)((e=>{e.currentTarget.value&&(null==r||r(e.currentTarget.value))}),[r]),g=(0,u.useCallback)((e=>{m.current=e.target.value,d(e.target.value)}),[]),b=(0,u.useCallback)((()=>{null==r||r(m.current)}),[r]);(0,u.useEffect)((()=>{i&&Promise.resolve().then((()=>{var e;null===(e=l.current)||void 0===e||e.focus()}))}),[]);const f=(0,u.useMemo)((()=>null!=a&&a.length?(0,Ve.chunk)(a,Math.max(2,Math.ceil(a.length/2))):[]),[a]),v=(0,u.useCallback)((e=>{m.current=e.content,d(e.content),setTimeout((()=>{var e;null===(e=l.current)||void 0===e||e.focus()}))}),[]);return h().createElement("div",{className:"root"},h().createElement("div",{className:"container",ref:o},h().createElement(Le.e,{containerRef:o,ref:l,value:c,minRows:3,paddingSize:62,autoResize:!0,disabled:t,placeholder:null!=n?n:$e(Fe.ASK_ANY_THING),submitWhen:"enter-without-shift",onSubmit:p,onChange:g}),h().createElement("button",{className:"btn-send",disabled:!c,onClick:b},h().createElement(ut,{lib:"fa",prefix:"fas",icon:"arrow-up"}))),!(null==f||!f.length)&&h().createElement("div",{className:"suggestions"},h().createElement("div",{className:"heading"},h().createElement("img",{className:"icon",src:qe,width:16,height:16}),h().createElement("span",null,null!=s?s:$e(Fe.COMMON_TASKS))),f.map(((e,t)=>h().createElement(St,{key:t,suggestions:e,pixelPerSecond:10*(t+2),onSelect:v})))))}function St(e){let{suggestions:t,pixelPerSecond:n,onSelect:i}=e;const a=(0,u.useRef)(null),s=(0,u.useRef)(null),[r,o]=(0,u.useState)(0);return(0,u.useEffect)((()=>{const e=a.current,t=s.current;if(!e||!t)return;let i,r,l,c,d=0;const u=(t.offsetWidth-7)/2+7;function h(e){r=e,void 0===l&&(l=e),void 0!==i&&(d+=e-i,i=void 0),o((e-l-d)/1e3*n%u),c=requestAnimationFrame(h)}c=requestAnimationFrame(h);const m=()=>{cancelAnimationFrame(c),i=r},p=()=>{c=requestAnimationFrame(h)};return e.addEventListener("mouseenter",m),e.addEventListener("mouseleave",p),()=>{cancelAnimationFrame(c),e.removeEventListener("mouseenter",m),e.removeEventListener("mouseleave",p)}}),[t,n]),h().createElement("div",{className:"carousel",ref:a},h().createElement("ul",{className:"list",ref:s,style:{transform:`translateX(${-r}px)`}},[...t,...t].map(((e,t)=>h().createElement("li",{key:t},h().createElement("div",{className:"item",onClick:()=>i(e),title:e.content},h().createElement("div",{className:"title"},e.title),h().createElement("div",{className:"content"},e.content)))))))}Ge=wt,({e:[Qe,Je,Ze,et,tt,nt,it,at,st,rt,ot,lt,ct,dt],c:[gt,Xe]}=(0,d.A)(Ge,[ht("ai-portal.chat-box",{styleTexts:[Ke.A]})],[[mt({type:Boolean}),1,"disabled"],[mt(),1,"placeholder"],[mt({type:Boolean}),1,"autoFocus"],[mt({attribute:!1}),1,"suggestions"],[mt(),1,"suggestionsLabel"],[pt({type:"message.submit"}),1,"messageSubmit",e=>(0,c.A)(xt,e),(e,t)=>(0,l.A)(xt,e,t)]],0,(e=>yt.has((0,r.A)(e))),p.ReactNextElement)),Xe();var Tt,Mt=n(82165);let Ct;const{defineElement:Rt}=(0,m.createDecorators)();let It;class _t extends p.ReactNextElement{render(){return h().createElement(Wt,null)}}function Wt(){return h().createElement("slot",null)}Tt=_t,[It,Ct]=(0,d.A)(Tt,[Rt("ai-portal.home-container",{styleTexts:[Mt.A]})],[],0,void 0,p.ReactNextElement).c,Ct();var Yt=n(21302),Ot=n.n(Yt);let zt=function(e){return e.TODAY="TODAY",e.YESTERDAY="YESTERDAY",e.PREVIOUS_7_DAYS="PREVIOUS_7_DAYS",e.PREVIOUS_30_DAYS="PREVIOUS_30_DAYS",e}({});const Dt="bricks/ai-portal/chat-history",Ut={en:{[zt.TODAY]:"Today",[zt.YESTERDAY]:"Yesterday",[zt.PREVIOUS_7_DAYS]:"Previous 7 days",[zt.PREVIOUS_30_DAYS]:"Previous 30 days"},zh:{[zt.TODAY]:"今天",[zt.YESTERDAY]:"昨天",[zt.PREVIOUS_7_DAYS]:"过去7天",[zt.PREVIOUS_30_DAYS]:"过去30天"}},jt=b.i18n.getFixedT(null,Dt);var Pt,Lt=n(21411);let Vt,Ft,Ht,Bt,$t,qt,Gt,Kt,Xt,Qt,Jt,Zt,en,tn,nn;(0,b.initializeI18n)(Dt,Ut);const an=(0,p.wrapBrick)("eo-icon"),sn=(0,p.wrapBrick)("eo-link"),rn=(0,p.wrapBrick)("eo-mini-actions",{onActionClick:"action.click",onVisibleChange:"visible.change"}),{defineElement:on,property:ln,event:cn}=(0,m.createDecorators)();let dn;var un=new WeakMap,hn=new WeakMap,mn=new WeakMap,pn=new WeakMap,gn=new WeakSet,bn=new WeakMap,fn=new WeakMap,vn=new WeakMap;class An extends p.ReactNextElement{constructor(){super(...arguments),(0,a.A)(this,gn),(0,s.A)(this,un,Ft(this)),(0,s.A)(this,hn,(Ht(this),Bt(this))),(0,s.A)(this,mn,($t(this),qt(this))),(0,s.A)(this,pn,(Gt(this),Kt(this))),(0,s.A)(this,bn,(Jt(this),e=>{(0,o.A)(gn,this,Xt).emit(e)})),(0,s.A)(this,fn,Zt(this)),(0,s.A)(this,vn,(nn(this),e=>{(0,o.A)(gn,this,en).emit({nextToken:e})}))}get list(){return(0,c.A)(un,this)}set list(e){(0,l.A)(un,this,e)}get actions(){return(0,c.A)(hn,this)}set actions(e){(0,l.A)(hn,this,e)}get nextToken(){return(0,c.A)(mn,this)}set nextToken(e){(0,l.A)(mn,this,e)}render(){return h().createElement(kn,{root:this,list:this.list,actions:this.actions,nextToken:this.nextToken,onActionClick:(0,c.A)(bn,this),onLoadMore:(0,c.A)(vn,this)})}}function kn(e){let{root:t,list:n,actions:i,nextToken:a,onActionClick:s,onLoadMore:r}=e;const o=(0,u.useMemo)((()=>{const e=new Map,t=Ot()(),i=t.startOf("day"),a=i.clone().subtract(1,"day"),s=i.clone().subtract(7,"days"),r=i.clone().subtract(30,"days"),o=+i/1e3,l=+a/1e3,c=+s/1e3,d=+r/1e3,u=+t.startOf("year")/1e3;for(const t of null!=n?n:[]){let n;n=t.startTime>=o?jt(zt.TODAY):t.startTime>=l?jt(zt.YESTERDAY):t.startTime>=c?jt(zt.PREVIOUS_7_DAYS):t.startTime>=d?jt(zt.PREVIOUS_30_DAYS):t.startTime>=u?Ot()(1e3*t.startTime).format("MMMM"):Ot()(1e3*t.startTime).format("YYYY");let i=e.get(n);i||e.set(n,i={title:n,items:[]}),i.items.push(t)}return[...e.values()]}),[n]),[l,c]=(0,u.useState)(null),d=(0,u.useRef)(null);return(0,u.useEffect)((()=>{const e=d.current;if(!e||!a)return;const n=new IntersectionObserver((e=>{for(const t of e)t.isIntersecting&&r(a)}),{root:t});return n.observe(e),()=>{n.disconnect()}}),[a,r,t]),n?h().createElement(h().Fragment,null,h().createElement("ul",null,o.map((e=>h().createElement("li",{key:e.title,className:"group"},h().createElement("div",{className:"group-title"},e.title),h().createElement("ul",{className:"items"},e.items.map((e=>h().createElement("li",{key:e.id},h().createElement(sn,{className:v()("item",{active:l===e.id}),url:e.url},h().createElement("div",{className:"item-title",title:e.title},e.title),h().createElement(rn,{className:"actions",actions:i,onActionClick:t=>{s({action:t.detail,item:e})},onVisibleChange:t=>{c(t.detail?e.id:null)}}),!U.QB.includes(e.state)&&h().createElement("div",{className:"working"})))))))))),a&&h().createElement("div",{className:"load-more",ref:d},h().createElement(an,{lib:"antd",icon:"loading-3-quarters",spinning:!0}))):h().createElement("div",{className:"loading"},h().createElement(an,{lib:"antd",theme:"outlined",icon:"loading-3-quarters",spinning:!0}))}Pt=An,({e:[Ft,Ht,Bt,$t,qt,Gt,Kt,Xt,Qt,Jt,Zt,en,tn,nn],c:[dn,Vt]}=(0,d.A)(Pt,[on("ai-portal.chat-history",{styleTexts:[Lt.A]})],[[ln({attribute:!1}),1,"list"],[ln({attribute:!1}),1,"actions"],[ln(),1,"nextToken"],[cn({type:"action.click"}),1,"actionClick",e=>(0,c.A)(pn,e),(e,t)=>(0,l.A)(pn,e,t)],[cn({type:"load.more"}),1,"loadMore",e=>(0,c.A)(fn,e),(e,t)=>(0,l.A)(fn,e,t)]],0,(e=>vn.has((0,r.A)(e))),p.ReactNextElement)),Vt();var xn,En=n(89575),yn=n(24);let wn,Nn,Sn,Tn,Mn,Cn,Rn,In,_n,Wn,Yn,On,zn,Dn,Un,jn,Pn,Ln,Vn,Fn,Hn;const Bn=(0,p.wrapBrick)("eo-mini-line-chart"),{defineElement:$n,property:qn}=(0,m.createDecorators)();let Gn;var Kn=new WeakMap,Xn=new WeakMap,Qn=new WeakMap,Jn=new WeakMap,Zn=new WeakMap,ei=new WeakMap,ti=new WeakMap,ni=new WeakMap,ii=new WeakMap,ai=new WeakMap;class si extends p.ReactNextElement{constructor(){super(...arguments),(0,s.A)(this,Kn,Nn(this)),(0,s.A)(this,Xn,(Sn(this),Tn(this))),(0,s.A)(this,Qn,(Mn(this),Cn(this))),(0,s.A)(this,Jn,(Rn(this),In(this))),(0,s.A)(this,Zn,(_n(this),Wn(this))),(0,s.A)(this,ei,(Yn(this),On(this))),(0,s.A)(this,ti,(zn(this),Dn(this))),(0,s.A)(this,ni,(Un(this),jn(this))),(0,s.A)(this,ii,(Pn(this),Ln(this))),(0,s.A)(this,ai,(Vn(this),Fn(this))),Hn(this)}get label(){return(0,c.A)(Kn,this)}set label(e){(0,l.A)(Kn,this,e)}get value(){return(0,c.A)(Xn,this)}set value(e){(0,l.A)(Xn,this,e)}get size(){return(0,c.A)(Qn,this)}set size(e){(0,l.A)(Qn,this,e)}get lineColor(){return(0,c.A)(Jn,this)}set lineColor(e){(0,l.A)(Jn,this,e)}get showArea(){return(0,c.A)(Zn,this)}set showArea(e){(0,l.A)(Zn,this,e)}get min(){return(0,c.A)(ei,this)}set min(e){(0,l.A)(ei,this,e)}get max(){return(0,c.A)(ti,this)}set max(e){(0,l.A)(ti,this,e)}get xField(){return(0,c.A)(ni,this)}set xField(e){(0,l.A)(ni,this,e)}get yField(){return(0,c.A)(ii,this)}set yField(e){(0,l.A)(ii,this,e)}get data(){return(0,c.A)(ai,this)}set data(e){(0,l.A)(ai,this,e)}render(){return h().createElement(ri,{label:this.label,value:this.value,size:this.size,lineColor:this.lineColor,showArea:this.showArea,min:this.min,max:this.max,xField:this.xField,yField:this.yField,data:this.data})}}function ri(e){let{label:t,value:n,size:i,...a}=e;return"small"===i?h().createElement("div",{className:"container"},h().createElement("div",{className:"label-and-stat"},h().createElement("div",{className:"label"},t),h().createElement("div",{className:"stat"},n)),h().createElement("div",{className:"chart"},h().createElement(Bn,(0,En.A)({},a,{lineWidth:1.5,width:"auto",height:"55"})))):h().createElement("div",{className:"container"},h().createElement("div",{className:"label"},t),h().createElement("div",{className:"stat-and-chart"},h().createElement("div",{className:"chart"},h().createElement(Bn,(0,En.A)({},a,{lineWidth:2,width:"auto",height:"92"}))),h().createElement("div",{className:"stat"},n)))}xn=si,({e:[Nn,Sn,Tn,Mn,Cn,Rn,In,_n,Wn,Yn,On,zn,Dn,Un,jn,Pn,Ln,Vn,Fn,Hn],c:[Gn,wn]}=(0,d.A)(xn,[$n("ai-portal.stat-with-mini-chart",{styleTexts:[yn.A]})],[[qn(),1,"label"],[qn(),1,"value"],[qn(),1,"size"],[qn(),1,"lineColor"],[qn({type:Boolean}),1,"showArea"],[qn({type:Number}),1,"min"],[qn({type:Number}),1,"max"],[qn(),1,"xField"],[qn(),1,"yField"],[qn({attribute:!1}),1,"data"]],0,void 0,p.ReactNextElement)),wn();const oi=n.p+"images/7385e5f5.png";var li,ci=n(31653);let di;const{defineElement:ui}=(0,m.createDecorators)();let hi;class mi extends p.ReactNextElement{render(){return h().createElement(pi,null)}}function pi(){return h().createElement("img",{src:oi,alt:"Elevo",width:95,height:26})}li=mi,[hi,di]=(0,d.A)(li,[ui("ai-portal.elevo-logo",{styleTexts:[ci.A]})],[],0,void 0,p.ReactNextElement).c,di();let gi=function(e){return e.NEW_CHAT="NEW_CHAT",e.LOGOUT="LOGOUT",e.TODAY="TODAY",e.YESTERDAY="YESTERDAY",e.PREVIOUS_7_DAYS="PREVIOUS_7_DAYS",e.PREVIOUS_30_DAYS="PREVIOUS_30_DAYS",e}({});const bi="bricks/ai-portal/elevo-sidebar",fi={en:{[gi.NEW_CHAT]:"New chat",[gi.LOGOUT]:"Logout",[gi.TODAY]:"Today",[gi.YESTERDAY]:"Yesterday",[gi.PREVIOUS_7_DAYS]:"Previous 7 days",[gi.PREVIOUS_30_DAYS]:"Previous 30 days"},zh:{[gi.NEW_CHAT]:"新对话",[gi.LOGOUT]:"登出",[gi.TODAY]:"今天",[gi.YESTERDAY]:"昨天",[gi.PREVIOUS_7_DAYS]:"过去7天",[gi.PREVIOUS_30_DAYS]:"过去30天"}},vi=b.i18n.getFixedT(null,bi);var Ai=n(61408);const ki=(0,p.wrapBrick)("eo-icon"),xi=(0,p.wrapBrick)("eo-link"),Ei=(0,p.wrapBrick)("eo-dropdown-actions",{onActionClick:"action.click",onVisibleChange:"visible.change"}),yi=(0,p.wrapBrick)("eo-easyops-avatar"),wi=(0,p.wrapBrick)("eo-mini-actions",{onActionClick:"action.click",onVisibleChange:"visible.change"});var Ni=n(57372);const Si=async(e,t)=>(await Ni.http.post("api/gateway/logic.llm.aiops_service/api/v1/llm/agent/flow/search",e,t)).data;function Ti(e){let{activeId:t,actions:n,urlTemplate:i,onActionClick:a,onHistoryClick:s}=e;const r=(0,u.useRef)(null),[o,l]=(0,u.useState)(null),[c,d]=(0,u.useState)(),[m,p]=(0,u.useState)();(0,u.useEffect)((()=>{Promise.all([Si({next_token:m}),new Promise((e=>setTimeout(e,500)))]).then((e=>{let[t]=e;l((e=>[...null!=e?e:[],...t.data])),d(t.next_token)})).catch((e=>{console.error("Error loading chat history:",e)}))}),[m]);const g=(0,u.useMemo)((()=>{const e=new Map,t=Ot()(),n=t.startOf("day"),i=n.clone().subtract(1,"day"),a=n.clone().subtract(7,"days"),s=n.clone().subtract(30,"days"),r=+n/1e3,l=+i/1e3,c=+a/1e3,d=+s/1e3,u=+t.startOf("year")/1e3;for(const t of null!=o?o:[]){let n;n=t.startTime>=r?vi(gi.TODAY):t.startTime>=l?vi(gi.YESTERDAY):t.startTime>=c?vi(gi.PREVIOUS_7_DAYS):t.startTime>=d?vi(gi.PREVIOUS_30_DAYS):t.startTime>=u?Ot()(1e3*t.startTime).format("MMMM"):Ot()(1e3*t.startTime).format("YYYY");let i=e.get(n);i||e.set(n,i={title:n,items:[]}),i.items.push(t)}return[...e.values()]}),[o]),[b,f]=(0,u.useState)(null),A=(0,u.useRef)(null);return(0,u.useEffect)((()=>{const e=A.current,t=r.current;if(!e||!c||!t)return;const n=new IntersectionObserver((e=>{for(const t of e)t.isIntersecting&&p(c)}),{root:t});return n.observe(e),()=>{n.disconnect()}}),[c]),o?h().createElement("div",{className:"history",ref:r},h().createElement("ul",null,g.map((e=>h().createElement("li",{key:e.title,className:"group"},h().createElement("div",{className:"group-title"},e.title),h().createElement("ul",{className:"items"},e.items.map((e=>{return h().createElement("li",{key:e.id},h().createElement(xi,(0,En.A)({className:v()("item",{"actions-active":e.id===b,active:e.id===t}),onClick:s},i?{url:(r=i,o=e,null==r?void 0:r.replace(/{{(.*?)}}/g,((e,t)=>(0,Ve.get)(o,t))))}:null),h().createElement("div",{className:"item-title",title:e.title},e.title),h().createElement(wi,{className:"actions",actions:n,onActionClick:t=>{a({action:t.detail,item:e})},onVisibleChange:t=>{f(t.detail?e.id:null)}}),!U.QB.includes(e.state)&&h().createElement("div",{className:"working"})));var r,o}))))))),c&&h().createElement("div",{className:"load-more",ref:A},h().createElement(ki,{lib:"antd",icon:"loading-3-quarters",spinning:!0}))):h().createElement("div",{className:"history"},h().createElement("div",{className:"loading"},h().createElement(ki,{lib:"antd",theme:"outlined",icon:"loading-3-quarters",spinning:!0})))}var Mi;let Ci,Ri,Ii,_i,Wi,Yi,Oi,zi,Di,Ui,ji,Pi,Li,Vi,Fi,Hi,Bi,$i,qi,Gi,Ki,Xi,Qi;(0,b.initializeI18n)(bi,fi);const Ji=[{icon:{lib:"fa",prefix:"fas",icon:"arrow-right-from-bracket"},text:vi(gi.LOGOUT)}],{defineElement:Zi,property:ea,event:ta}=(0,m.createDecorators)();let na;var ia=new WeakMap,aa=new WeakMap,sa=new WeakMap,ra=new WeakMap,oa=new WeakMap,la=new WeakMap,ca=new WeakMap,da=new WeakMap,ua=new WeakSet,ha=new WeakMap,ma=new WeakMap,pa=new WeakMap;class ga extends p.ReactNextElement{constructor(){super(...arguments),(0,a.A)(this,ua),(0,s.A)(this,ia,Ri(this)),(0,s.A)(this,aa,(Ii(this),_i(this))),(0,s.A)(this,sa,(Wi(this),Yi(this))),(0,s.A)(this,ra,(Oi(this),zi(this))),(0,s.A)(this,oa,(Di(this),Ui(this))),(0,s.A)(this,la,(ji(this),Pi(this))),(0,s.A)(this,ca,(Li(this),Vi(this))),(0,s.A)(this,da,(Fi(this),Hi(this))),(0,s.A)(this,ha,(qi(this),()=>{(0,o.A)(ua,this,Bi).emit()})),(0,s.A)(this,ma,Gi(this)),(0,s.A)(this,pa,(Qi(this),e=>{(0,o.A)(ua,this,Ki).emit(e)}))}get userInstanceId(){return(0,c.A)(ia,this)}set userInstanceId(e){(0,l.A)(ia,this,e)}get behavior(){return(0,c.A)(aa,this)}set behavior(e){(0,l.A)(aa,this,e)}get logoUrl(){return(0,c.A)(sa,this)}set logoUrl(e){(0,l.A)(sa,this,e)}get newChatUrl(){return(0,c.A)(ra,this)}set newChatUrl(e){(0,l.A)(ra,this,e)}get historyActiveId(){return(0,c.A)(oa,this)}set historyActiveId(e){(0,l.A)(oa,this,e)}get historyUrlTemplate(){return(0,c.A)(la,this)}set historyUrlTemplate(e){(0,l.A)(la,this,e)}get historyActions(){return(0,c.A)(ca,this)}set historyActions(e){(0,l.A)(ca,this,e)}render(){return h().createElement(ba,{userInstanceId:this.userInstanceId,behavior:this.behavior,logoUrl:this.logoUrl,newChatUrl:this.newChatUrl,historyActiveId:this.historyActiveId,historyUrlTemplate:this.historyUrlTemplate,historyActions:this.historyActions,onLogout:(0,c.A)(ha,this),onActionClick:(0,c.A)(pa,this)})}}function ba(e){let{userInstanceId:t,behavior:n,logoUrl:i,newChatUrl:a,historyActiveId:s,historyUrlTemplate:r,historyActions:o,onLogout:l,onActionClick:c}=e;const[d,m]=(0,u.useState)("drawer"===n),p=(0,u.useCallback)((()=>{m(!0)}),[]),g=(0,u.useCallback)((()=>{m(!1)}),[]);(0,u.useEffect)((()=>{"drawer"===n&&m(!0)}),[n]);const b=(0,u.useCallback)((()=>{m(!0)}),[]),f=(0,u.useCallback)((()=>{"drawer"===n&&m(!0)}),[n]);return h().createElement("div",{className:v()("container",{collapsed:d})},"drawer"===n&&!d&&h().createElement("div",{className:"mask",onClick:b}),h().createElement("div",{className:"sidebar"},h().createElement("div",{className:"logo-bar"},h().createElement(xi,{url:i,className:"logo-link"},h().createElement("img",{className:"logo",alt:"Elevo",src:oi,width:95,height:26})),h().createElement("button",{className:"toggle",onClick:p},h().createElement(ki,{lib:"easyops",icon:"sidebar"}))),h().createElement(xi,{className:"new-chat",url:a},h().createElement(ki,{className:"new-chat-icon",lib:"easyops",icon:"new-chat"}),vi(gi.NEW_CHAT)),h().createElement(Ti,{activeId:s,urlTemplate:r,actions:o,onActionClick:c,onHistoryClick:f}),h().createElement("div",{className:"footer"},h().createElement(Ei,{className:"dropdown",actions:Ji,onActionClick:l},h().createElement("button",{className:"account"},h().createElement(yi,{nameOrInstanceId:t,showName:!0,size:"xs"}))))),h().createElement("div",{className:"alternative"},h().createElement("button",{className:"toggle",onClick:g},h().createElement(ki,{lib:"easyops",icon:"sidebar"})),h().createElement(xi,{className:"new-chat",url:a},h().createElement(ki,{className:"new-chat-icon",lib:"easyops",icon:"new-chat"}),vi(gi.NEW_CHAT))))}Mi=ga,({e:[Ri,Ii,_i,Wi,Yi,Oi,zi,Di,Ui,ji,Pi,Li,Vi,Fi,Hi,Bi,$i,qi,Gi,Ki,Xi,Qi],c:[na,Ci]}=(0,d.A)(Mi,[Zi("ai-portal.elevo-sidebar",{styleTexts:[Ai.A]})],[[ea(),1,"userInstanceId"],[ea(),1,"behavior"],[ea(),1,"logoUrl"],[ea(),1,"newChatUrl"],[ea(),1,"historyActiveId"],[ea(),1,"historyUrlTemplate"],[ea({attribute:!1}),1,"historyActions"],[ta({type:"logout"}),1,"logout",e=>(0,c.A)(da,e),(e,t)=>(0,l.A)(da,e,t)],[ta({type:"action.click"}),1,"actionClick",e=>(0,c.A)(ma,e),(e,t)=>(0,l.A)(ma,e,t)]],0,(e=>pa.has((0,r.A)(e))),p.ReactNextElement)),Ci()},31653:(e,t,n)=>{n.d(t,{A:()=>o});var i=n(36758),a=n.n(i),s=n(40935),r=n.n(s)()(a());r.push([e.id,":host{display:inline-block;padding:3px 0}:host([hidden]){display:none}img{display:block}",""]);const o=r.toString()},32360:(e,t,n)=>{e.exports=n.p+"images/6336f999.png"},47008:(e,t,n)=>{n.d(t,{A:()=>h});var i=n(36758),a=n.n(i),s=n(40935),r=n.n(s),o=n(20062),l=n.n(o),c=new URL(n(91107),n.b),d=r()(a()),u=l()(c);d.push([e.id,`:host{display:block}:host([hidden]){display:none}*{box-sizing:border-box}.root{color:#262626;background-color:#e1e3ec;background-image:url(${u});background-size:694px 144px;background-position:top left;background-repeat:no-repeat;box-shadow:inset 0px 2px 5px 1px rgba(42,46,59,0.1);border-radius:20px;padding:12px}.container{position:relative}textarea{display:block;width:100%;padding:10px 16px 52px;color:var(--antd-input-color);background:rgba(255,255,255,0.8);border-radius:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.5);font-size:14px;line-height:22px;height:130px}textarea::placeholder{color:rgba(0,0,0,0.4)}.btn-send:focus,\ntextarea:focus{outline:none}.btn-send{position:absolute;bottom:14px;right:14px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#2540ff;border:none;border-radius:8px;color:#fff}.btn-send[disabled]{background:rgba(0,0,0,0.15)}.btn-send:not([disabled]){cursor:pointer}.btn-send:not([disabled]):hover{background:#5166ff}.btn-send:not([disabled]):active{background:#1e33cc}.suggestions{margin-top:19px}.heading{display:flex;align-items:center;padding:0 5px;margin-bottom:8px}.icon{margin-right:5px}.carousel{overflow:hidden}.carousel + .carousel{margin-top:7px}.list{display:flex;width:max-content;list-style:none;margin:0;padding:0;font-size:12px}.item{background:rgba(255,255,255,0.4);border-radius:12px;border:1px solid #dcdee6;padding:12px;max-width:330px;cursor:pointer}.item:hover{background:rgba(255,255,255,0.5);border:1px solid rgba(37,64,255,0.3)}.list > li + li{margin-left:7px}.title{margin-bottom:4px}.content{color:rgba(0,0,0,0.45);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tooltip{display:block}`,""]);const h=d.toString()},61408:(e,t,n)=>{n.d(t,{A:()=>o});var i=n(36758),a=n.n(i),s=n(40935),r=n.n(s)()(a());r.push([e.id,':host{display:block}:host([hidden]){display:none}*{box-sizing:border-box}.sidebar{position:relative;width:261px;height:100%;background:#f6f7f9;border-right:1px solid #e3e5eb;padding:26px 16px 0;display:flex;flex-direction:column;transition:transform 0.3s ease-in-out}.logo-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px}.logo-link::part(link){display:block}.logo{vertical-align:middle}.toggle{color:#595959;font-size:18px;width:28px;height:28px;display:flex;align-items:center;justify-content:space-between;background:none;border:none;cursor:pointer;border-radius:8px}.toggle:hover{background:rgba(0,0,0,0.04)}.new-chat::part(link){display:flex;align-items:center;color:var(--elevo-color-brand);font-size:14px;text-align:left;cursor:pointer}.sidebar .new-chat::part(link){background:#f0f4ff;border-radius:8px;border:1px solid #c9d7ff;padding:9px 13px;font-weight:500;margin-bottom:23px}.sidebar .new-chat::part(link):hover{background:rgba(201,215,255,0.5)}.new-chat-icon{font-size:16px;margin-right:5px}.footer{border-top:1px solid rgba(0,0,0,0.04);padding:9px 12px;margin:0 -16px}.dropdown{display:block}.account{background:none;border:none;border-radius:8px;padding:6px 10px;display:block;width:100%;text-align:left;cursor:pointer}.account:hover{background:rgba(0,0,0,0.04)}.alternative{position:fixed;top:14px;left:16px;display:flex;align-items:center;opacity:0;z-index:1;transition:opacity 0.2s ease-in-out}.alternative .new-chat::part(link){padding:4px;margin-left:16px;font-size:12px}.alternative .new-chat::part(link):hover{color:#7891ff}.alternative .new-chat::part(link):active{color:#0911b3}.container{width:261px;height:100%;transition:width 0.3s ease-in-out}.collapsed{width:0;overflow:visible}.collapsed .sidebar{transform:translateX(-100%)}.collapsed .alternative{opacity:1}:host([behavior="drawer"]){z-index:1;width:0}:host(:not([behavior="drawer"])) .alternative .new-chat{display:none}.mask{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--antd-modal-mask-bg)}.history{flex:1;min-height:0;overflow-y:auto;margin:0 -16px;padding:0 12px}.history ul{list-style:none;margin:0;padding:0}.history .loading{display:flex;justify-content:center;padding:8px}.history .group + .group{margin-top:15px}.history .group-title{font-weight:500;font-size:12px;color:#000;padding:8px;height:36px;line-height:20px}.history .item{display:block}.history .item::part(link){display:flex;align-items:center;padding:0 8px;height:36px;border-radius:8px;color:#000}.history .item.active::part(link){background:rgba(0,0,0,0.06)}.history .item:not(.active)::part(link):hover{background:rgba(0,0,0,0.04)}.history .item-title{flex:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.history .actions{cursor:auto}.history .item:not(:hover):not(.actions-active) .actions{display:none}.history .working{width:8px;height:8px;border-radius:8px;background:#2540ff;margin:0 7px}.history .item:hover .working,.history .item.active .working{display:none}.history .load-more{display:flex;justify-content:center;align-items:center;height:36px}',""]);const o=r.toString()},82165:(e,t,n)=>{n.d(t,{A:()=>h});var i=n(36758),a=n.n(i),s=n(40935),r=n.n(s),o=n(20062),l=n.n(o),c=new URL(n(32360),n.b),d=r()(a()),u=l()(c);d.push([e.id,`:host{display:block;background-color:#fff;background-image:url(${u});background-position:center;background-size:cover;background-repeat:no-repeat;background-attachment:fixed}:host([hidden]){display:none}`,""]);const h=d.toString()},91107:(e,t,n)=>{e.exports=n.p+"images/eef4f2bd.png"}}]);
3
+ //# sourceMappingURL=6220.865493dc.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunks/6220.865493dc.js","mappings":"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","sources":["webpack:///./src/stat-with-mini-chart/styles.shadow.css","webpack:///./src/chat-history/styles.shadow.css","webpack:///./src/cruise-canvas/index.tsx","webpack:///./src/chat-box/i18n.ts","webpack:///./src/chat-box/index.tsx","webpack:///./src/home-container/index.tsx","webpack:///./src/chat-history/i18n.ts","webpack:///./src/chat-history/index.tsx","webpack:///./src/stat-with-mini-chart/index.tsx","webpack:///./src/elevo-logo/index.tsx","webpack:///./src/elevo-sidebar/i18n.ts","webpack:///./src/elevo-sidebar/bricks.ts","webpack:///../../node_modules/@next-api-sdk/llm-sdk/dist/esm/api/llm/agent_flow/searchTaskForAgentFlow.js","webpack:///./src/elevo-sidebar/ChatHistory.tsx","webpack:///./src/elevo-sidebar/index.tsx","webpack:///./src/elevo-logo/styles.shadow.css","webpack:///./src/chat-box/styles.shadow.css","webpack:///./src/elevo-sidebar/styles.shadow.css","webpack:///./src/home-container/styles.shadow.css"],"sourcesContent":["// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:block;white-space:nowrap}.container{border-radius:var(--elevo-border-radius)}:host([hidden]){display:none}*{box-sizing:border-box}.label{font-weight:500;overflow:hidden;text-overflow:ellipsis}.stat{font-weight:600}.chart{min-width:0}.chart > *{display:block}:host(:not([size=\"small\"])) .container{background:linear-gradient(164deg,rgba(105,153,253,0) 40%,rgba(105,153,253,0.05) 60%,rgba(105,153,253,0.32) 100%),#fff;padding:22px}:host(:not([size=\"small\"])) .label{font-size:14px;height:22px;margin-bottom:16px}:host(:not([size=\"small\"])) .stat-and-chart{display:flex;align-items:center;justify-content:end;position:relative}:host(:not([size=\"small\"])) .stat{font-size:36px;color:#1d212a;position:absolute;left:0}:host(:not([size=\"small\"])) .chart{width:calc(100% - 160px)}:host([size=\"small\"]) .container{padding:11px 15px;display:flex;align-items:center;justify-content:end;position:relative;background:var(--elevo-component-background);-webkit-backdrop-filter:var(--elevo-component-backdrop-filter);backdrop-filter:var(--elevo-component-backdrop-filter)}:host([size=\"small\"]) .label-and-stat{position:absolute;left:15px}:host([size=\"small\"]) .label{font-size:12px;color:#8c8c8c;line-height:17px;height:17px;margin-bottom:7px}:host([size=\"small\"]) .stat{font-size:20px;color:#262626;line-height:24px}:host([size=\"small\"]) .chart{width:calc(100% - 90px)}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:block}:host([hidden]){display:none}*{box-sizing:border-box}ul{list-style:none;margin:0;padding:0}.loading{display:flex;justify-content:center;padding:8px}.group + .group{margin-top:15px}.group-title{font-weight:500;font-size:12px;color:#000;padding:8px;height:36px;line-height:20px}.item{display:block}.item::part(link){display:flex;align-items:center;padding:0 8px;height:36px;border-radius:8px;color:#000}.item::part(link):hover{background:rgba(0,0,0,0.04)}.item-title{flex:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.actions{cursor:auto}.item:not(:hover):not(.active) .actions{display:none}.working{width:8px;height:8px;border-radius:8px;background:#2540ff;margin:0 7px}.item:hover .working,\n.item.active .working{display:none}.load-more{display:flex;justify-content:center;align-items:center;height:36px}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// istanbul ignore file: experimental\nimport React, {\n createRef,\n forwardRef,\n memo,\n useCallback,\n useContext,\n useEffect,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport { getRuntime, handleHttpError } from \"@next-core/runtime\";\nimport \"@next-core/theme\";\nimport { initializeI18n } from \"@next-core/i18n\";\nimport classNames from \"classnames\";\nimport ResizeObserver from \"resize-observer-polyfill\";\nimport { select, type Selection, type TransitionLike } from \"d3-selection\";\nimport { ZoomTransform } from \"d3-zoom\";\nimport { mergeRects } from \"@next-shared/diagram\";\nimport { NS, locales } from \"./i18n.js\";\nimport styles from \"./styles.module.css\";\nimport { useZoom } from \"./useZoom.js\";\nimport type {\n SizeTuple,\n GraphNode,\n Job,\n RequirementGraphNode,\n JobGraphNode,\n TaskBaseDetail,\n GraphEdge,\n ZoomAction,\n} from \"./interfaces.js\";\nimport { useAutoCenter } from \"./useAutoCenter.js\";\nimport { useLayout } from \"./useLayout.js\";\nimport { useTaskDetail } from \"./useTaskDetail.js\";\nimport { useTaskGraph } from \"./useTaskGraph.js\";\nimport { PlanProgress } from \"./PlanProgress/PlanProgress.js\";\nimport { ZoomBar } from \"./ZoomBar/ZoomBar.js\";\nimport { NodeStart } from \"./NodeStart/NodeStart.js\";\nimport { NodeRequirement } from \"./NodeRequirement/NodeRequirement.js\";\nimport { NodeInstruction } from \"./NodeInstruction/NodeInstruction.js\";\nimport { NodeJob } from \"./NodeJob/NodeJob.js\";\nimport { NodeEnd } from \"./NodeEnd/NodeEnd.js\";\nimport { NodeView } from \"./NodeView/NodeView.js\";\nimport {\n CANVAS_PADDING_BOTTOM,\n CANVAS_PADDING_LEFT,\n CANVAS_PADDING_RIGHT,\n CANVAS_PADDING_TOP,\n DONE_STATES,\n GENERAL_DONE_STATES,\n} from \"./constants.js\";\nimport { WrappedIcon } from \"./bricks.js\";\nimport { CanvasContext } from \"./CanvasContext.js\";\nimport { ToolCallDetail } from \"./ToolCallDetail/ToolCallDetail.js\";\nimport { getScrollTo } from \"./utils/getScrollTo.js\";\nimport { handleKeyboardNav } from \"./utils/handleKeyboardNav.js\";\nimport { ExpandedView } from \"./ExpandedView/ExpandedView.js\";\n\ninitializeI18n(NS, locales);\n\nconst { defineElement, property, event, method } = createDecorators();\n\nconst MemoizedNodeComponent = memo(NodeComponent);\n\nexport interface CruiseCanvasProps {\n taskId?: string;\n task?: TaskBaseDetail;\n jobs?: Job[];\n replay?: number;\n}\n\nconst CruiseCanvasComponent = forwardRef(LegacyCruiseCanvasComponent);\n\n/**\n * 构件 `ai-portal.cruise-canvas`\n */\nexport\n@defineElement(\"ai-portal.cruise-canvas\", {\n // Will wrap v2 bricks which don't support in shadow DOM.\n shadowOptions: false,\n})\nclass CruiseCanvas extends ReactNextElement implements CruiseCanvasProps {\n @property()\n accessor taskId: string | undefined;\n\n @property({ attribute: false })\n accessor task: TaskBaseDetail | undefined;\n\n @property({ attribute: false })\n accessor jobs: Job[] | undefined;\n\n /**\n * 设置回放时消息之间的时间间隔,单位为秒。\n */\n @property({ type: Number })\n accessor replay: number | undefined;\n\n @event({ type: \"share\" })\n accessor #shareEvent!: EventEmitter<void>;\n\n #onShare = () => {\n this.#shareEvent.emit();\n };\n\n @event({ type: \"pause\" })\n accessor #pauseEvent!: EventEmitter<void>;\n\n #onPause = () => {\n this.#pauseEvent.emit();\n };\n\n @event({ type: \"resume\" })\n accessor #resumeEvent!: EventEmitter<void>;\n\n #onResume = () => {\n this.#resumeEvent.emit();\n };\n\n @event({ type: \"cancel\" })\n accessor #cancelEvent!: EventEmitter<void>;\n\n #onCancel = () => {\n this.#cancelEvent.emit();\n };\n\n #ref = createRef<CruiseCanvasRef>();\n\n @method()\n resumed() {\n this.#ref.current?.resumed();\n }\n\n render() {\n return (\n <CruiseCanvasComponent\n taskId={this.taskId}\n jobs={this.jobs}\n task={this.task}\n replay={this.replay}\n onShare={this.#onShare}\n onPause={this.#onPause}\n onResume={this.#onResume}\n onCancel={this.#onCancel}\n ref={this.#ref}\n />\n );\n }\n}\n\ninterface CruiseCanvasComponentProps extends CruiseCanvasProps {\n onShare: () => void;\n onPause: () => void;\n onResume: () => void;\n onCancel: () => void;\n}\n\ninterface ScrollToOptions {\n nodeId?: string;\n jobId?: string;\n\n /**\n * @default \"auto\"\n */\n behavior?: \"smooth\" | \"instant\" | \"auto\";\n\n /**\n * When set to \"start\", force scroll even if the node is fully visible.\n *\n * @default \"nearest\"\n */\n block?: \"start\" | \"nearest\";\n}\n\ninterface CruiseCanvasRef {\n resumed: () => void;\n}\n\nfunction LegacyCruiseCanvasComponent(\n {\n taskId,\n task: propTask,\n jobs: propJobs,\n replay,\n onShare,\n onPause,\n onResume,\n onCancel,\n }: CruiseCanvasComponentProps,\n ref: React.Ref<CruiseCanvasRef>\n) {\n const rootRef = useRef<HTMLDivElement>(null);\n const {\n task: _task,\n jobs: _jobs,\n plan: _plan,\n error,\n humanInputRef,\n resumedRef,\n } = useTaskDetail(taskId, replay);\n const task = taskId ? _task : propTask;\n const jobs = taskId ? _jobs : propJobs;\n const plan = taskId ? _plan : propTask?.plan;\n const graph = useTaskGraph(task, jobs);\n const rawNodes = graph?.nodes;\n const rawEdges = graph?.edges;\n const nav = graph?.nav;\n const views = graph?.views;\n const pageTitle = task?.title ?? \"\";\n const taskState = task?.state;\n const [activeNodeId, setActiveNodeId] = useState<string | null>(null);\n const currentNavId = useMemo(() => {\n if (activeNodeId) {\n const [type, jobId] = activeNodeId.split(\":\");\n if (type === \"job\" || type === \"view\") {\n return jobId;\n }\n }\n return null;\n }, [activeNodeId]);\n\n useImperativeHandle(\n ref,\n () => ({\n resumed: () => resumedRef.current?.(),\n }),\n [resumedRef]\n );\n\n // Enable transition after 3 seconds to avoid initial flicker\n const transitionEnabledRef = useRef(false);\n useEffect(() => {\n const timer = setTimeout(() => {\n transitionEnabledRef.current = true;\n }, 3e3);\n return () => {\n clearTimeout(timer);\n };\n }, []);\n\n useEffect(() => {\n getRuntime().applyPageTitle(pageTitle);\n }, [pageTitle]);\n\n useEffect(() => {\n if (error) {\n handleHttpError(error);\n }\n }, [error]);\n\n const humanInput = useCallback(\n (jobId: string, input: string) => {\n humanInputRef.current?.(jobId, input);\n },\n [humanInputRef]\n );\n\n const [sizeMap, setSizeMap] = useState<Map<string, SizeTuple> | null>(null);\n const onNodeResize = useCallback((id: string, size: SizeTuple | null) => {\n // Handle resize logic here\n setSizeMap((prev) => {\n if (!size) {\n if (!prev) {\n return null;\n }\n const newMap = new Map(prev);\n const deleted = newMap.delete(id);\n return deleted ? newMap : prev;\n }\n return prev ? new Map(prev).set(id, size) : new Map([[id, size]]);\n });\n }, []);\n\n const { sizeReady, nodes, edges } = useLayout({\n rawNodes,\n rawEdges,\n state: taskState,\n sizeMap,\n });\n\n // Disable auto scroll when the user manually scrolled up\n const detectScrolledUpRef = useRef(false);\n const manualScrolledUpRef = useRef(false);\n\n const [hoverOnScrollableContent, setHoverOnScrollableContent] =\n useState(false);\n\n const { grabbing, transform, transformRef, zoomer /* , scaleRange */ } =\n useZoom({\n rootRef,\n zoomable: sizeReady,\n scrollable: sizeReady && !hoverOnScrollableContent,\n pannable: sizeReady,\n manualScrolledUpRef,\n });\n\n const transitionRef = useRef(false);\n\n const pushZoomTransition = useMemo(() => {\n let nextAction: ZoomAction | null = null;\n\n const run = (action: ZoomAction) => {\n const current = transformRef.current;\n const target = typeof action === \"function\" ? action(current) : action;\n\n if (!target) {\n return;\n }\n\n const { transform, translateBy } = target;\n\n let selection:\n | Selection<HTMLDivElement, unknown, null, undefined>\n | TransitionLike<HTMLDivElement, unknown> = select(rootRef.current!);\n\n if (transitionEnabledRef.current && target.duration !== 0) {\n transitionRef.current = true;\n selection = selection\n .transition()\n .duration(target.duration ?? 300)\n .ease((t) => t * (2 - t)) // Ease in-out\n .on(\"end\", () => {\n transitionRef.current = false;\n if (nextAction) {\n const next = nextAction;\n nextAction = null;\n run(next);\n }\n });\n }\n\n if (transform) {\n zoomer.transform(\n selection,\n new ZoomTransform(\n transform.k ?? current.k,\n transform.x ?? current.x,\n transform.y ?? current.y\n )\n );\n } else {\n zoomer.translateBy(selection, translateBy[0] ?? 0, translateBy[1] ?? 0);\n }\n };\n\n return (action: ZoomAction) => {\n if (transitionRef.current) {\n nextAction = action;\n } else {\n run(action);\n }\n };\n }, [transformRef, zoomer]);\n\n const { centered, setCentered, reCenterRef } = useAutoCenter({\n nodes,\n sizeReady,\n zoomer,\n rootRef,\n pushZoomTransition,\n });\n\n const taskDone = DONE_STATES.includes(taskState ?? \"working\");\n const taskLoading = !taskDone && nodes.length === 2;\n\n const nonLeafNodes = useMemo(() => {\n return new Set<string>(edges.map((edge) => edge.source));\n }, [edges]);\n\n const bottom = useMemo(() => {\n if (!sizeReady) {\n return null;\n }\n\n const leafNodes: GraphNode[] = [];\n for (const node of nodes) {\n if (!nonLeafNodes.has(node.id)) {\n leafNodes.push(node);\n }\n }\n if (leafNodes.length > 0) {\n const y1 = Math.max(\n ...leafNodes.map((node) => node.view!.y + node.view!.height)\n );\n return y1;\n }\n\n return null;\n }, [nodes, nonLeafNodes, sizeReady]);\n\n const bottomRef = useRef<number | null>(null);\n useEffect(() => {\n bottomRef.current = bottom;\n }, [bottom]);\n\n // Make the latest (bottom most) node visible\n useEffect(() => {\n const root = rootRef.current;\n if (\n !root ||\n bottom === null ||\n (detectScrolledUpRef.current && manualScrolledUpRef.current)\n ) {\n return;\n }\n pushZoomTransition((current) => {\n const { offsetHeight } = root;\n const transformedBottom = bottom * current.k + current.y;\n const diffY = offsetHeight - CANVAS_PADDING_BOTTOM - transformedBottom;\n if (diffY < 0) {\n // Use `zoomer.transform()` which will not be restricted to its translate/scale extent\n return {\n transform: {\n y: current.y + diffY,\n },\n duration: diffY > -100 ? 100 : diffY < -500 ? 300 : 200,\n };\n }\n return null;\n });\n }, [bottom, pushZoomTransition]);\n\n // Detect if the user scrolled up manually\n useEffect(() => {\n const bottom = bottomRef.current;\n const root = rootRef.current;\n if (!root || bottom === null || transitionRef.current) {\n return;\n }\n const { offsetHeight } = root;\n const transformedBottom = bottom * transform.k + transform.y;\n\n const diffY = offsetHeight - CANVAS_PADDING_BOTTOM - transformedBottom;\n detectScrolledUpRef.current = diffY < 0;\n }, [transform, zoomer]);\n\n const handleReCenter = useCallback(() => {\n reCenterRef.current = true;\n setCentered(false);\n }, [reCenterRef, setCentered]);\n\n const handleScaleChange = useCallback(\n (scale: number) => {\n zoomer.scaleTo(select(rootRef.current!), scale);\n },\n [zoomer]\n );\n\n const fullRect = useMemo(() => {\n if (!sizeReady) {\n return null;\n }\n return mergeRects(nodes.map((node) => node.view!));\n }, [nodes, sizeReady]);\n\n useEffect(() => {\n if (!fullRect) {\n return;\n }\n const root = rootRef.current;\n if (!root) {\n return;\n }\n\n const distance = 20;\n const { offsetWidth, offsetHeight } = root;\n const viewportWidth = offsetWidth / transform.k;\n const viewportHeight = offsetHeight / transform.k;\n const minX = -(viewportWidth - distance - fullRect.x);\n const maxX = viewportWidth - distance + (fullRect.x + fullRect.width);\n const minY = -(viewportHeight - distance - fullRect.y);\n const maxY = viewportHeight - distance + (fullRect.y + fullRect.height);\n\n zoomer.translateExtent([\n [minX, minY],\n [maxX, maxY],\n ]);\n }, [zoomer, transform.k, fullRect]);\n\n const scrollTo = useCallback(\n ({ nodeId, jobId, behavior, block }: ScrollToOptions) => {\n /**\n * - When the node is fully visible, take no action.\n * - Otherwise, scroll to make it fully visible while make the scroll\n * distance as small as possible.\n * - Special cases:\n * - When the node is higher or wider than the viewport, scroll to\n * the top or left of the node.\n */\n const root = rootRef.current;\n const targets = nodes.filter((n) => {\n if (nodeId && n.id !== nodeId) {\n return false;\n }\n if (jobId && (n as JobGraphNode).job?.id !== jobId) {\n return false;\n }\n return true;\n });\n if (!root || targets.length === 0) {\n return;\n }\n const rect = mergeRects(targets.map((node) => node.view!));\n\n const { x, y } = getScrollTo(\n rect,\n [root.offsetWidth, root.offsetHeight],\n [\n CANVAS_PADDING_TOP,\n CANVAS_PADDING_RIGHT,\n CANVAS_PADDING_BOTTOM,\n CANVAS_PADDING_LEFT,\n ],\n transformRef.current,\n block\n );\n\n if (x || y) {\n pushZoomTransition({\n translateBy: [x, y],\n duration: behavior === \"instant\" ? 0 : undefined,\n });\n }\n },\n [nodes, pushZoomTransition, transformRef]\n );\n\n const scrollBy = useCallback(\n (\n direction: \"up\" | \"down\" | \"left\" | \"right\",\n range: \"line\" | \"page\" | \"document\"\n ) => {\n const root = rootRef.current;\n if (!root || !sizeReady) {\n return;\n }\n let x = 0;\n let y = 0;\n let duration = 300;\n let distance: number;\n const isHorizontal = direction === \"left\" || direction === \"right\";\n if (range === \"line\") {\n const lineHeight = 40;\n distance =\n lineHeight * (direction === \"up\" || direction === \"left\" ? 1 : -1);\n duration = 150;\n } else if (range === \"page\") {\n const pageHeight = root.offsetHeight - CANVAS_PADDING_BOTTOM;\n distance = pageHeight * (direction === \"up\" ? -1 : 1);\n } else {\n const { y: top, height } = mergeRects(nodes.map((node) => node.view!));\n\n if (direction === \"down\") {\n const bottom = top + height;\n const targetHeight = bottom - top + CANVAS_PADDING_BOTTOM;\n distance = root.offsetHeight - targetHeight - transformRef.current.y;\n } else {\n distance = top + CANVAS_PADDING_TOP - transformRef.current.y;\n }\n }\n\n if (isHorizontal) {\n x = distance;\n } else {\n y = distance;\n }\n\n if (x || y) {\n pushZoomTransition({\n translateBy: [x, y],\n duration,\n });\n }\n },\n [nodes, pushZoomTransition, sizeReady, transformRef]\n );\n\n const [activeToolCallJobId, setActiveToolCallJobId] = useState<string | null>(\n null\n );\n\n const [activeExpandedViewJobId, setActiveExpandedViewJobId] = useState<\n string | null\n >(null);\n\n const canvasContextValue = useMemo(\n () => ({\n humanInput,\n onShare,\n onPause,\n onResume,\n onCancel,\n onNodeResize,\n activeToolCallJobId,\n setActiveToolCallJobId,\n setActiveNodeId,\n hoverOnScrollableContent,\n setHoverOnScrollableContent,\n activeExpandedViewJobId,\n setActiveExpandedViewJobId,\n }),\n [\n activeToolCallJobId,\n hoverOnScrollableContent,\n activeExpandedViewJobId,\n onNodeResize,\n humanInput,\n onShare,\n onPause,\n onResume,\n onCancel,\n ]\n );\n\n const activeToolCallJob = useMemo(() => {\n if (!activeToolCallJobId) {\n return null;\n }\n return jobs?.find((job) => job.id === activeToolCallJobId);\n }, [activeToolCallJobId, jobs]);\n\n const handleRootClick = useCallback((e: React.MouseEvent) => {\n for (const element of e.nativeEvent.composedPath()) {\n if (\n element instanceof HTMLElement &&\n element.classList.contains(styles.node)\n ) {\n // If the click is on a node, do not reset active node\n return;\n }\n if (element === rootRef.current) {\n break;\n }\n }\n setActiveNodeId(null);\n }, []);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || activeToolCallJob || activeExpandedViewJobId) {\n return;\n }\n\n const handleKeyDown = (e: KeyboardEvent) => {\n if (\n document.activeElement &&\n document.activeElement !== document.body &&\n document.activeElement !== root\n ) {\n return;\n }\n\n const keyboardAction = handleKeyboardNav(e, { activeNodeId, nodes });\n if (!keyboardAction) {\n return;\n }\n const { action, node } = keyboardAction;\n\n if (action === \"scroll\") {\n scrollBy(keyboardAction.direction, keyboardAction.range);\n } else if (action === \"enter\") {\n if (node.type !== \"job\" && node.type !== \"view\") {\n return;\n }\n const askUser = node.job.toolCall?.name === \"ask_human\";\n const askUserPlan =\n node.job.toolCall?.name === \"ask_human_confirming_plan\";\n if (askUser || askUserPlan) {\n return;\n }\n }\n e.preventDefault();\n e.stopPropagation();\n\n if (action === \"enter\") {\n if (node.type === \"view\") {\n setActiveExpandedViewJobId(node.job.id);\n } else {\n setActiveToolCallJobId((node as JobGraphNode).job.id);\n }\n } else if (action === \"switch-active-node\") {\n setActiveNodeId(node.id);\n if (node.type === \"job\" || node.type === \"view\") {\n scrollTo({\n jobId: node.job.id,\n behavior: \"smooth\",\n });\n } else {\n scrollTo({\n nodeId: node.id,\n behavior: \"smooth\",\n });\n }\n }\n };\n document.addEventListener(\"keydown\", handleKeyDown);\n return () => {\n document.removeEventListener(\"keydown\", handleKeyDown);\n };\n }, [\n activeNodeId,\n activeToolCallJob,\n activeExpandedViewJobId,\n nodes,\n scrollTo,\n scrollBy,\n ]);\n\n return (\n <CanvasContext.Provider value={canvasContextValue}>\n <div\n className={classNames(styles.root, { [styles.loading]: !task })}\n ref={rootRef}\n style={{\n cursor: grabbing ? \"grabbing\" : \"grab\",\n }}\n tabIndex={-1}\n onClick={handleRootClick}\n >\n {!task && (\n <div className={styles[\"loading-icon\"]}>\n <WrappedIcon\n lib=\"antd\"\n theme=\"outlined\"\n icon=\"loading-3-quarters\"\n spinning\n />\n </div>\n )}\n <div\n className={classNames(styles.canvas, {\n [styles.ready]: sizeReady && centered,\n })}\n style={{\n transform: `translate3d(${transform.x}px, ${transform.y}px, 0) scale(${transform.k})`,\n }}\n >\n <svg className={styles.edges}>\n {edges.map((edge) => (\n <path\n className={styles.edge}\n key={`${edge.source}-${edge.target}`}\n d={edge\n .points!.map(\n ({ x, y }, i) => `${i === 0 ? \"M\" : \"L\"}${x},${y}`\n )\n .join(\" \")}\n />\n ))}\n </svg>\n {nodes.map((node) => (\n <MemoizedNodeComponent\n key={node.id}\n id={node.id}\n type={node.type}\n content={(node as RequirementGraphNode).content}\n job={(node as JobGraphNode).job}\n state={node.state}\n startTime={task?.startTime}\n taskLoading={taskLoading}\n instructionLoading={\n node.type === \"instruction\" &&\n !nonLeafNodes.has(node.id) &&\n !DONE_STATES.includes(node.state ?? \"working\") &&\n !GENERAL_DONE_STATES.includes(taskState ?? \"working\")\n }\n edges={edges}\n x={node.view?.x}\n y={node.view?.y}\n active={activeNodeId === node.id}\n />\n ))}\n </div>\n </div>\n <div className={styles.widgets}>\n <div className={styles[\"nav-container\"]}>\n <ul className={styles.nav}>\n {nav?.map((item) => (\n <li\n key={item.id}\n className={classNames(styles[\"nav-item\"], {\n [styles.active]: currentNavId === item.id,\n })}\n >\n <a\n className={styles[\"nav-link\"]}\n onClick={() => {\n setActiveNodeId(`job:${item.id}`);\n scrollTo({ jobId: item.id, block: \"start\" });\n }}\n >\n <span className={styles[\"nav-link-text\"]}>{item.title}</span>\n </a>\n </li>\n ))}\n </ul>\n </div>\n <PlanProgress plan={plan} state={taskState} />\n <ZoomBar\n scale={transform.k}\n onScaleChange={handleScaleChange}\n onReCenter={handleReCenter}\n />\n </div>\n {activeToolCallJob && <ToolCallDetail job={activeToolCallJob} />}\n {activeExpandedViewJobId && <ExpandedView views={views!} />}\n </CanvasContext.Provider>\n );\n}\n\ninterface NodeComponentProps {\n id: string;\n type: GraphNode[\"type\"];\n edges: GraphEdge[];\n content?: string;\n job?: Job;\n state?: string;\n startTime?: number;\n taskLoading?: boolean;\n instructionLoading?: boolean;\n x?: number;\n y?: number;\n active?: boolean;\n}\n\nfunction NodeComponent({\n id,\n type,\n state,\n job,\n content,\n startTime,\n taskLoading,\n instructionLoading,\n x,\n y,\n active,\n}: NodeComponentProps) {\n const nodeRef = useRef<HTMLDivElement>(null);\n const { onNodeResize, setActiveNodeId } = useContext(CanvasContext);\n\n useEffect(() => {\n const element = nodeRef.current;\n if (!element) {\n return;\n }\n const observer = new ResizeObserver(() => {\n onNodeResize(id, [element.offsetWidth, element.offsetHeight]);\n });\n observer.observe(element);\n return () => {\n observer.disconnect();\n onNodeResize(id, null);\n };\n }, [id, onNodeResize]);\n\n useEffect(() => {\n const element = nodeRef.current;\n if (!element) {\n return;\n }\n const handleMouseDown = (e: MouseEvent) => {\n e.stopPropagation();\n };\n element.addEventListener(\"mousedown\", handleMouseDown);\n return () => {\n element.removeEventListener(\"mousedown\", handleMouseDown);\n };\n }, []);\n\n const handleClick = useCallback(() => {\n if (type !== \"start\" && type !== \"instruction\") {\n setActiveNodeId(id);\n }\n }, [id, setActiveNodeId, type]);\n\n return (\n <div\n className={classNames(styles.node, {\n [styles.ready]: x != null && y != null,\n })}\n ref={nodeRef}\n style={{\n left: x,\n top: y,\n }}\n onClick={handleClick}\n >\n {type === \"start\" ? (\n <NodeStart />\n ) : type === \"end\" ? (\n <NodeEnd active={active} />\n ) : type === \"requirement\" ? (\n <NodeRequirement\n content={content}\n startTime={startTime}\n loading={taskLoading}\n active={active}\n />\n ) : type === \"instruction\" ? (\n <NodeInstruction\n content={job!.instruction}\n loading={instructionLoading}\n />\n ) : type === \"view\" ? (\n <NodeView job={job!} active={active} />\n ) : (\n <NodeJob state={state} job={job!} active={active} />\n )}\n </div>\n );\n}\n","import { i18n } from \"@next-core/i18n\";\n\nexport enum K {\n ASK_ANY_THING = \"ASK_ANYTHING\",\n COMMON_TASKS = \"COMMON_TASKS\",\n}\n\nconst en: Locale = {\n [K.ASK_ANY_THING]: \"Ask anything\",\n [K.COMMON_TASKS]: \"Common tasks\",\n};\n\nconst zh: Locale = {\n [K.ASK_ANY_THING]: \"询问任何问题\",\n [K.COMMON_TASKS]: \"常用任务\",\n};\n\nexport const NS = \"bricks/ai-portal/chat-box\";\n\nexport const locales = { en, zh };\n\nexport const t = i18n.getFixedT(null, NS);\n\ntype Locale = { [k in K]: string } & {\n [k in K as `${k}_plural`]?: string;\n};\n","import React, {\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport { ReactNextElement, wrapBrick } from \"@next-core/react-element\";\nimport {\n TextareaAutoResize,\n type TextareaAutoResizeRef,\n} from \"@next-shared/form\";\nimport { chunk } from \"lodash\";\nimport \"@next-core/theme\";\nimport { initializeI18n } from \"@next-core/i18n\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport { K, NS, locales, t } from \"./i18n.js\";\nimport tips from \"./images/tips.svg\";\nimport styleText from \"./styles.shadow.css\";\n\ninitializeI18n(NS, locales);\n\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\n\nconst { defineElement, property, event } = createDecorators();\n\nexport interface ChatBoxProps {\n disabled?: boolean;\n placeholder?: string;\n autoFocus?: boolean;\n suggestions?: Suggestion[];\n suggestionsLabel?: string;\n}\n\nexport interface Suggestion {\n title: string;\n content: string;\n}\n\n/**\n * 构件 `ai-portal.chat-box`\n */\nexport\n@defineElement(\"ai-portal.chat-box\", {\n styleTexts: [styleText],\n})\nclass ChatBox extends ReactNextElement implements ChatBoxProps {\n @property({ type: Boolean })\n accessor disabled: boolean | undefined;\n\n @property()\n accessor placeholder: string | undefined;\n\n @property({ type: Boolean })\n accessor autoFocus: boolean | undefined;\n\n @property({ attribute: false })\n accessor suggestions: Suggestion[] | undefined;\n\n @property()\n accessor suggestionsLabel: string | undefined;\n\n @event({ type: \"message.submit\" })\n accessor #messageSubmit!: EventEmitter<string>;\n\n #handleMessageSubmit = (value: string) => {\n this.#messageSubmit.emit(value);\n };\n\n render() {\n return (\n <ChatBoxComponent\n disabled={this.disabled}\n placeholder={this.placeholder}\n autoFocus={this.autoFocus}\n suggestions={this.suggestions}\n suggestionsLabel={this.suggestionsLabel}\n onSubmit={this.#handleMessageSubmit}\n />\n );\n }\n}\n\nexport interface ChatBoxComponentProps extends ChatBoxProps {\n // Define react event handlers here.\n onSubmit?: (value: string) => void;\n}\n\nexport function ChatBoxComponent({\n disabled,\n placeholder,\n autoFocus,\n suggestions,\n suggestionsLabel,\n onSubmit,\n}: ChatBoxComponentProps) {\n const containerRef = useRef<HTMLDivElement>(null);\n const textareaRef = useRef<TextareaAutoResizeRef>(null);\n const [value, setValue] = useState(\"\");\n const valueRef = useRef(\"\");\n\n const handleSubmit = useCallback(\n (e: React.FormEvent<HTMLTextAreaElement>) => {\n if (e.currentTarget.value) {\n onSubmit?.(e.currentTarget.value);\n }\n },\n [onSubmit]\n );\n\n const handleChange = useCallback(\n (e: React.ChangeEvent<HTMLTextAreaElement>) => {\n valueRef.current = e.target.value;\n setValue(e.target.value);\n },\n []\n );\n\n const handleSubmitClick = useCallback(() => {\n onSubmit?.(valueRef.current);\n }, [onSubmit]);\n\n useEffect(\n () => {\n if (autoFocus) {\n Promise.resolve().then(() => {\n textareaRef.current?.focus();\n });\n }\n },\n // One-time focus\n // eslint-disable-next-line react-hooks/exhaustive-deps\n []\n );\n\n // istanbul ignore next: experimental\n const groupedSuggestions = useMemo(() => {\n if (!suggestions?.length) {\n return [];\n }\n return chunk(suggestions, Math.max(2, Math.ceil(suggestions.length / 2)));\n }, [suggestions]);\n\n // istanbul ignore next: experimental\n const handleSelectSuggestion = useCallback((suggestion: Suggestion) => {\n valueRef.current = suggestion.content;\n setValue(suggestion.content);\n setTimeout(() => {\n textareaRef.current?.focus();\n });\n }, []);\n\n return (\n <div className=\"root\">\n <div className=\"container\" ref={containerRef}>\n <TextareaAutoResize\n containerRef={containerRef}\n ref={textareaRef}\n value={value}\n minRows={3}\n paddingSize={62}\n autoResize\n disabled={disabled}\n placeholder={placeholder ?? t(K.ASK_ANY_THING)}\n submitWhen=\"enter-without-shift\"\n onSubmit={handleSubmit}\n onChange={handleChange}\n />\n <button\n className=\"btn-send\"\n disabled={!value}\n onClick={handleSubmitClick}\n >\n <WrappedIcon lib=\"fa\" prefix=\"fas\" icon=\"arrow-up\" />\n </button>\n </div>\n {\n // istanbul ignore next: experimental\n !!groupedSuggestions?.length && (\n <div className=\"suggestions\">\n <div className=\"heading\">\n <img\n className=\"icon\"\n src={tips as unknown as string}\n width={16}\n height={16}\n />\n <span>{suggestionsLabel ?? t(K.COMMON_TASKS)}</span>\n </div>\n {groupedSuggestions.map((group, index) => (\n <SuggestionCarousel\n key={index}\n suggestions={group}\n pixelPerSecond={(index + 2) * 10}\n onSelect={handleSelectSuggestion}\n />\n ))}\n </div>\n )\n }\n </div>\n );\n}\n\nexport interface SuggestionCarouselProps {\n suggestions: Suggestion[];\n pixelPerSecond: number;\n onSelect: (suggestion: Suggestion) => void;\n}\n\n// istanbul ignore next: experimental\nfunction SuggestionCarousel({\n suggestions,\n pixelPerSecond,\n onSelect,\n}: SuggestionCarouselProps) {\n const carouselRef = useRef<HTMLDivElement>(null);\n const listRef = useRef<HTMLUListElement>(null);\n const [x, setX] = useState(0);\n\n // Auto scroll suggestions infinitely.\n // Stop scrolling when mouse enter, and resume when mouse leave.\n useEffect(() => {\n const carousel = carouselRef.current;\n const list = listRef.current;\n\n if (!carousel || !list) {\n return;\n }\n\n let previousTimestamp: number | undefined;\n let currentTimestamp: number | undefined;\n let offsetTime = 0;\n let start: number | undefined;\n let timer: number;\n\n // We doubled the suggestions to make it scroll infinitely.\n const gap = 7;\n const listSingleWidth = (list.offsetWidth - gap) / 2;\n const mod = listSingleWidth + gap;\n\n function step(timestamp: number) {\n currentTimestamp = timestamp;\n if (start === undefined) {\n start = timestamp;\n }\n if (previousTimestamp !== undefined) {\n offsetTime += timestamp - previousTimestamp;\n previousTimestamp = undefined;\n }\n const elapsed = timestamp - start - offsetTime;\n setX(((elapsed / 1000) * pixelPerSecond) % mod);\n timer = requestAnimationFrame(step);\n }\n\n timer = requestAnimationFrame(step);\n\n const onMouseEnter = () => {\n cancelAnimationFrame(timer);\n previousTimestamp = currentTimestamp;\n };\n const onMouseLeave = () => {\n timer = requestAnimationFrame(step);\n };\n\n carousel.addEventListener(\"mouseenter\", onMouseEnter);\n carousel.addEventListener(\"mouseleave\", onMouseLeave);\n\n return () => {\n cancelAnimationFrame(timer);\n carousel.removeEventListener(\"mouseenter\", onMouseEnter);\n carousel.removeEventListener(\"mouseleave\", onMouseLeave);\n };\n }, [suggestions, pixelPerSecond]);\n\n return (\n <div className=\"carousel\" ref={carouselRef}>\n <ul\n className=\"list\"\n ref={listRef}\n style={{ transform: `translateX(${-x}px)` }}\n >\n {[...suggestions, ...suggestions].map((item, index) => (\n <li key={index}>\n <div\n className=\"item\"\n onClick={() => onSelect(item)}\n title={item.content}\n >\n <div className=\"title\">{item.title}</div>\n <div className=\"content\">{item.content}</div>\n </div>\n </li>\n ))}\n </ul>\n </div>\n );\n}\n","import React from \"react\";\nimport { createDecorators } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport styleText from \"./styles.shadow.css\";\n\nconst { defineElement } = createDecorators();\n\n/**\n * 构件 `ai-portal.home-container`\n */\nexport\n@defineElement(\"ai-portal.home-container\", {\n styleTexts: [styleText],\n})\nclass HomeContainer extends ReactNextElement {\n render() {\n return <HomeContainerComponent />;\n }\n}\n\nexport function HomeContainerComponent() {\n return <slot />;\n}\n","import { i18n } from \"@next-core/i18n\";\n\nexport enum K {\n TODAY = \"TODAY\",\n YESTERDAY = \"YESTERDAY\",\n PREVIOUS_7_DAYS = \"PREVIOUS_7_DAYS\",\n PREVIOUS_30_DAYS = \"PREVIOUS_30_DAYS\",\n}\n\nconst en: Locale = {\n [K.TODAY]: \"Today\",\n [K.YESTERDAY]: \"Yesterday\",\n [K.PREVIOUS_7_DAYS]: \"Previous 7 days\",\n [K.PREVIOUS_30_DAYS]: \"Previous 30 days\",\n};\n\nconst zh: Locale = {\n [K.TODAY]: \"今天\",\n [K.YESTERDAY]: \"昨天\",\n [K.PREVIOUS_7_DAYS]: \"过去7天\",\n [K.PREVIOUS_30_DAYS]: \"过去30天\",\n};\n\nexport const NS = \"bricks/ai-portal/chat-history\";\n\nexport const locales = { en, zh };\n\nexport const t = i18n.getFixedT(null, NS);\n\ntype Locale = { [k in K]: string } & {\n [k in K as `${k}_plural`]?: string;\n};\n","// istanbul ignore file: experimental\nimport React, { useEffect, useMemo, useRef, useState } from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport { ReactNextElement, wrapBrick } from \"@next-core/react-element\";\nimport moment from \"moment\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport type { Link, LinkProps } from \"@next-bricks/basic/link\";\nimport type {\n ActionType,\n EoMiniActions,\n EoMiniActionsEvents,\n EoMiniActionsEventsMapping,\n EoMiniActionsProps,\n SimpleActionType,\n} from \"@next-bricks/basic/mini-actions\";\nimport \"@next-core/theme\";\nimport { initializeI18n } from \"@next-core/i18n\";\nimport { K, NS, locales, t } from \"./i18n.js\";\nimport styleText from \"./styles.shadow.css\";\nimport type { TaskState } from \"../cruise-canvas/interfaces.js\";\nimport classNames from \"classnames\";\nimport { DONE_STATES } from \"../cruise-canvas/constants.js\";\n\ninitializeI18n(NS, locales);\n\nconst WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\nconst WrappedLink = wrapBrick<Link, LinkProps>(\"eo-link\");\nconst WrappedMiniActions = wrapBrick<\n EoMiniActions,\n EoMiniActionsProps,\n EoMiniActionsEvents,\n EoMiniActionsEventsMapping\n>(\"eo-mini-actions\", {\n onActionClick: \"action.click\",\n onVisibleChange: \"visible.change\",\n});\n\nconst { defineElement, property, event } = createDecorators();\n\nexport interface ChatHistoryProps {\n list?: HistoryItem[];\n actions?: ActionType[];\n nextToken?: string;\n}\n\nexport interface HistoryItem {\n id: string;\n url: string;\n title: string;\n startTime: number;\n state?: TaskState;\n}\n\nexport interface ActionClickDetail {\n action: SimpleActionType;\n item: HistoryItem;\n}\n\n/**\n * 构件 `ai-portal.chat-history`\n */\nexport\n@defineElement(\"ai-portal.chat-history\", {\n styleTexts: [styleText],\n})\nclass ChatHistory extends ReactNextElement implements ChatHistoryProps {\n @property({ attribute: false })\n accessor list: HistoryItem[] | undefined;\n\n @property({ attribute: false })\n accessor actions: ActionType[] | undefined;\n\n @property()\n accessor nextToken: string | undefined;\n\n @event({ type: \"action.click\" })\n accessor #actionClick!: EventEmitter<ActionClickDetail>;\n\n #handleActionClick = (detail: ActionClickDetail) => {\n this.#actionClick.emit(detail);\n };\n\n @event({ type: \"load.more\" })\n accessor #loadMore!: EventEmitter<{ nextToken: string }>;\n\n #handleLoadMore = (nextToken: string) => {\n this.#loadMore.emit({ nextToken });\n };\n\n render() {\n return (\n <ChatHistoryComponent\n root={this}\n list={this.list}\n actions={this.actions}\n nextToken={this.nextToken}\n onActionClick={this.#handleActionClick}\n onLoadMore={this.#handleLoadMore}\n />\n );\n }\n}\n\nexport interface ChatHistoryComponentProps extends ChatHistoryProps {\n root: HTMLElement;\n onActionClick: (detail: ActionClickDetail) => void;\n onLoadMore: (nextToken: string) => void;\n}\n\ninterface GroupedHistory {\n title: string;\n items: HistoryItem[];\n}\n\nexport function ChatHistoryComponent({\n root,\n list,\n actions,\n nextToken,\n onActionClick,\n onLoadMore,\n}: ChatHistoryComponentProps) {\n const groups = useMemo(() => {\n const groupMap = new Map<string, GroupedHistory>();\n // Group history by\n // - today\n // - yesterday\n // - previous 7 days\n // - previous 30 days\n // - each month this year\n // - each year before.\n const now = moment();\n const startOfDay = now.startOf(\"day\");\n const yesterday = startOfDay.clone().subtract(1, \"day\");\n const sevenDaysAgo = startOfDay.clone().subtract(7, \"days\");\n const thirtyDaysAgo = startOfDay.clone().subtract(30, \"days\");\n const thisYear = now.startOf(\"year\");\n\n const timestamps = {\n startOfDay: +startOfDay / 1000,\n yesterday: +yesterday / 1000,\n sevenDaysAgo: +sevenDaysAgo / 1000,\n thirtyDaysAgo: +thirtyDaysAgo / 1000,\n thisYear: +thisYear / 1000,\n };\n for (const item of list ?? []) {\n let groupKey: string;\n if (item.startTime >= timestamps.startOfDay) {\n groupKey = t(K.TODAY);\n } else if (item.startTime >= timestamps.yesterday) {\n groupKey = t(K.YESTERDAY);\n } else if (item.startTime >= timestamps.sevenDaysAgo) {\n groupKey = t(K.PREVIOUS_7_DAYS);\n } else if (item.startTime >= timestamps.thirtyDaysAgo) {\n groupKey = t(K.PREVIOUS_30_DAYS);\n } else if (item.startTime >= timestamps.thisYear) {\n groupKey = moment(item.startTime * 1000).format(\"MMMM\");\n } else {\n groupKey = moment(item.startTime * 1000).format(\"YYYY\");\n }\n let group = groupMap.get(groupKey);\n if (!group) {\n groupMap.set(groupKey, (group = { title: groupKey, items: [] }));\n }\n group.items.push(item);\n }\n\n return [...groupMap.values()];\n }, [list]);\n\n const [actionsVisible, setActionsVisible] = useState<string | null>(null);\n\n const nextRef = useRef<HTMLDivElement | null>(null);\n\n useEffect(() => {\n const next = nextRef.current;\n if (!next || !nextToken) {\n return;\n }\n const observer = new IntersectionObserver(\n (entries) => {\n for (const entry of entries) {\n if (entry.isIntersecting) {\n onLoadMore(nextToken);\n }\n }\n },\n { root }\n );\n observer.observe(next);\n return () => {\n observer.disconnect();\n };\n }, [nextToken, onLoadMore, root]);\n\n if (!list) {\n return (\n <div className=\"loading\">\n <WrappedIcon\n lib=\"antd\"\n theme=\"outlined\"\n icon=\"loading-3-quarters\"\n spinning\n />\n </div>\n );\n }\n\n return (\n <>\n <ul>\n {groups.map((group) => (\n <li key={group.title} className=\"group\">\n <div className=\"group-title\">{group.title}</div>\n <ul className=\"items\">\n {group.items.map((item) => (\n <li key={item.id}>\n <WrappedLink\n className={classNames(\"item\", {\n active: actionsVisible === item.id,\n })}\n url={item.url}\n >\n <div className=\"item-title\" title={item.title}>\n {item.title}\n </div>\n <WrappedMiniActions\n className=\"actions\"\n actions={actions}\n onActionClick={(e) => {\n onActionClick({ action: e.detail, item });\n }}\n onVisibleChange={(e) => {\n setActionsVisible(e.detail ? item.id : null);\n }}\n />\n {!DONE_STATES.includes(item.state!) && (\n <div className=\"working\"></div>\n )}\n </WrappedLink>\n </li>\n ))}\n </ul>\n </li>\n ))}\n </ul>\n {nextToken && (\n <div className=\"load-more\" ref={nextRef}>\n <WrappedIcon lib=\"antd\" icon=\"loading-3-quarters\" spinning />\n </div>\n )}\n </>\n );\n}\n","import React from \"react\";\nimport { createDecorators } from \"@next-core/element\";\nimport { ReactNextElement, wrapBrick } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport styleText from \"./styles.shadow.css\";\nimport type {\n MiniLineChart,\n MiniLineChartProps,\n} from \"@next-bricks/mini-chart/mini-line-chart\";\n\nconst WrappedMiniLineChart = wrapBrick<MiniLineChart, MiniLineChartProps>(\n \"eo-mini-line-chart\"\n);\n\nconst { defineElement, property } = createDecorators();\n\nexport interface StatWithMiniChartProps\n extends Pick<\n MiniLineChartProps,\n \"data\" | \"xField\" | \"yField\" | \"lineColor\" | \"showArea\" | \"min\" | \"max\"\n > {\n label?: string;\n value?: string;\n size?: \"medium\" | \"small\";\n}\n\n/**\n * 构件 `ai-portal.stat-with-mini-chart`\n */\nexport\n@defineElement(\"ai-portal.stat-with-mini-chart\", {\n styleTexts: [styleText],\n})\nclass StatWithMiniChart\n extends ReactNextElement\n implements StatWithMiniChartProps\n{\n @property()\n accessor label: string | undefined;\n\n @property()\n accessor value: string | undefined;\n\n /**\n * @default \"medium\"\n */\n @property()\n accessor size: \"medium\" | \"small\" | undefined;\n\n /**\n * @default \"var(--color-brand)\"\n */\n @property()\n accessor lineColor: string | undefined;\n\n @property({ type: Boolean })\n accessor showArea: boolean | undefined;\n\n /**\n * Specify the minimum value of the y-axis.\n * If not specified, the minimum value will be calculated from the data.\n */\n @property({ type: Number })\n accessor min: number | undefined;\n\n /**\n * Specify the maximum value of the y-axis.\n * If not specified, the maximum value will be calculated from the data.\n */\n @property({ type: Number })\n accessor max: number | undefined;\n\n /**\n * @default \"0\"\n */\n @property()\n accessor xField: string | undefined;\n\n /**\n * @default \"1\"\n */\n @property()\n accessor yField: string | undefined;\n\n @property({ attribute: false })\n accessor data: Record<string, number>[] | undefined;\n\n render() {\n return (\n <StatWithMiniChartComponent\n label={this.label}\n value={this.value}\n size={this.size}\n lineColor={this.lineColor}\n showArea={this.showArea}\n min={this.min}\n max={this.max}\n xField={this.xField}\n yField={this.yField}\n data={this.data}\n />\n );\n }\n}\n\nfunction StatWithMiniChartComponent({\n label,\n value,\n size,\n ...chartProps\n}: StatWithMiniChartProps) {\n if (size === \"small\") {\n return (\n <div className=\"container\">\n <div className=\"label-and-stat\">\n <div className=\"label\">{label}</div>\n <div className=\"stat\">{value}</div>\n </div>\n <div className=\"chart\">\n <WrappedMiniLineChart\n {...chartProps}\n lineWidth={1.5}\n width=\"auto\"\n height=\"55\"\n />\n </div>\n </div>\n );\n }\n return (\n <div className=\"container\">\n <div className=\"label\">{label}</div>\n <div className=\"stat-and-chart\">\n <div className=\"chart\">\n <WrappedMiniLineChart\n {...chartProps}\n lineWidth={2}\n width=\"auto\"\n height=\"92\"\n />\n </div>\n <div className=\"stat\">{value}</div>\n </div>\n </div>\n );\n}\n","import React from \"react\";\nimport { createDecorators } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport logoImage from \"./images/logo@2x.png\";\nimport styleText from \"./styles.shadow.css\";\n\nconst { defineElement } = createDecorators();\n\n/**\n * Elevo Logo\n */\nexport\n@defineElement(\"ai-portal.elevo-logo\", {\n styleTexts: [styleText],\n})\nclass ElevoLogo extends ReactNextElement {\n render() {\n return <ElevoLogoComponent />;\n }\n}\n\nfunction ElevoLogoComponent() {\n return <img src={logoImage} alt=\"Elevo\" width={95} height={26} />;\n}\n","import { i18n } from \"@next-core/i18n\";\n\nexport enum K {\n NEW_CHAT = \"NEW_CHAT\",\n LOGOUT = \"LOGOUT\",\n TODAY = \"TODAY\",\n YESTERDAY = \"YESTERDAY\",\n PREVIOUS_7_DAYS = \"PREVIOUS_7_DAYS\",\n PREVIOUS_30_DAYS = \"PREVIOUS_30_DAYS\",\n}\n\nconst en: Locale = {\n [K.NEW_CHAT]: \"New chat\",\n [K.LOGOUT]: \"Logout\",\n [K.TODAY]: \"Today\",\n [K.YESTERDAY]: \"Yesterday\",\n [K.PREVIOUS_7_DAYS]: \"Previous 7 days\",\n [K.PREVIOUS_30_DAYS]: \"Previous 30 days\",\n};\n\nconst zh: Locale = {\n [K.NEW_CHAT]: \"新对话\",\n [K.LOGOUT]: \"登出\",\n [K.TODAY]: \"今天\",\n [K.YESTERDAY]: \"昨天\",\n [K.PREVIOUS_7_DAYS]: \"过去7天\",\n [K.PREVIOUS_30_DAYS]: \"过去30天\",\n};\n\nexport const NS = \"bricks/ai-portal/elevo-sidebar\";\n\nexport const locales = { en, zh };\n\nexport const t = i18n.getFixedT(null, NS);\n\ntype Locale = { [k in K]: string } & {\n [k in K as `${k}_plural`]?: string;\n};\n","import { wrapBrick } from \"@next-core/react-element\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport type { Link, LinkProps } from \"@next-bricks/basic/link\";\nimport type {\n EoDropdownActions,\n DropdownActionsProps,\n DropdownActionsEvents,\n DropdownActionsEventsMapping,\n} from \"@next-bricks/basic/dropdown-actions\";\nimport type {\n EoEasyopsAvatar,\n EoEasyopsAvatarProps,\n} from \"@next-bricks/basic/easyops-avatar\";\nimport type {\n EoMiniActions,\n EoMiniActionsEvents,\n EoMiniActionsEventsMapping,\n EoMiniActionsProps,\n} from \"@next-bricks/basic/mini-actions\";\n\nexport const WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\nexport const WrappedLink = wrapBrick<Link, LinkProps>(\"eo-link\");\nexport const WrappedDropdownActions = wrapBrick<\n EoDropdownActions,\n DropdownActionsProps,\n DropdownActionsEvents,\n DropdownActionsEventsMapping\n>(\"eo-dropdown-actions\", {\n onActionClick: \"action.click\",\n onVisibleChange: \"visible.change\",\n});\nexport const WrappedEasyopsAvatar = wrapBrick<\n EoEasyopsAvatar,\n EoEasyopsAvatarProps\n>(\"eo-easyops-avatar\");\nexport const WrappedMiniActions = wrapBrick<\n EoMiniActions,\n EoMiniActionsProps,\n EoMiniActionsEvents,\n EoMiniActionsEventsMapping\n>(\"eo-mini-actions\", {\n onActionClick: \"action.click\",\n onVisibleChange: \"visible.change\",\n});\n","import { http } from \"@next-core/http\";\n/**\n * @description 分页查询agent flow, 默认只查询最近三个页的数据\n * @endpoint POST /api/v1/llm/agent/flow/search\n */\nexport const AgentFlowApi_searchTaskForAgentFlow = async (data, options) => /**! @contract easyops.api.llm.agent_flow.SearchTaskForAgentFlow@1.0.0 */(await http.post(\"api/gateway/logic.llm.aiops_service/api/v1/llm/agent/flow/search\", data, options)).data;\n//# sourceMappingURL=searchTaskForAgentFlow.js.map","import React, { useEffect, useMemo, useRef, useState } from \"react\";\nimport moment from \"moment\";\nimport classNames from \"classnames\";\nimport { AgentFlowApi_searchTaskForAgentFlow } from \"@next-api-sdk/llm-sdk\";\nimport type {\n ActionType,\n SimpleActionType,\n} from \"@next-bricks/basic/mini-actions\";\nimport { get } from \"lodash\";\nimport { K, t } from \"./i18n.js\";\nimport type { TaskState } from \"../cruise-canvas/interfaces.js\";\nimport { WrappedIcon, WrappedLink, WrappedMiniActions } from \"./bricks.js\";\nimport { DONE_STATES } from \"../cruise-canvas/constants.js\";\n\nexport interface HistoryItem {\n id: string;\n title: string;\n startTime: number;\n state?: TaskState;\n}\n\nexport interface GroupedHistory {\n title: string;\n items: HistoryItem[];\n}\n\nexport interface ActionClickDetail {\n action: SimpleActionType;\n item: HistoryItem;\n}\n\nexport interface ChatHistoryProps {\n activeId?: string;\n urlTemplate?: string;\n actions?: ActionType[];\n onActionClick: (detail: ActionClickDetail) => void;\n onHistoryClick: () => void;\n}\n\nexport function ChatHistory({\n activeId,\n actions,\n urlTemplate,\n onActionClick,\n onHistoryClick,\n}: ChatHistoryProps) {\n const rootRef = useRef<HTMLDivElement | null>(null);\n const [list, setList] = useState<HistoryItem[] | null>(null);\n const [nextToken, setNextToken] = useState<string | undefined>();\n const [loadNextToken, setLoadNextToken] = useState<string | undefined>();\n\n useEffect(() => {\n Promise.all([\n AgentFlowApi_searchTaskForAgentFlow({ next_token: loadNextToken }),\n new Promise((resolve) => setTimeout(resolve, 500)), // Force a minimum delay\n ])\n .then(([data]) => {\n setList((prev) => [...(prev ?? []), ...(data.data as HistoryItem[])]);\n setNextToken(data.next_token);\n })\n .catch((error) => {\n if (process.env.NODE_ENV !== \"test\") {\n // eslint-disable-next-line no-console\n console.error(\"Error loading chat history:\", error);\n }\n });\n }, [loadNextToken]);\n\n const groups = useMemo(() => {\n const groupMap = new Map<string, GroupedHistory>();\n // Group history by\n // - today\n // - yesterday\n // - previous 7 days\n // - previous 30 days\n // - each month this year\n // - each year before.\n const now = moment();\n const startOfDay = now.startOf(\"day\");\n const yesterday = startOfDay.clone().subtract(1, \"day\");\n const sevenDaysAgo = startOfDay.clone().subtract(7, \"days\");\n const thirtyDaysAgo = startOfDay.clone().subtract(30, \"days\");\n const thisYear = now.startOf(\"year\");\n\n const timestamps = {\n startOfDay: +startOfDay / 1000,\n yesterday: +yesterday / 1000,\n sevenDaysAgo: +sevenDaysAgo / 1000,\n thirtyDaysAgo: +thirtyDaysAgo / 1000,\n thisYear: +thisYear / 1000,\n };\n for (const item of list ?? []) {\n let groupKey: string;\n if (item.startTime >= timestamps.startOfDay) {\n groupKey = t(K.TODAY);\n } else if (item.startTime >= timestamps.yesterday) {\n groupKey = t(K.YESTERDAY);\n } else if (item.startTime >= timestamps.sevenDaysAgo) {\n groupKey = t(K.PREVIOUS_7_DAYS);\n } else if (item.startTime >= timestamps.thirtyDaysAgo) {\n groupKey = t(K.PREVIOUS_30_DAYS);\n } else if (item.startTime >= timestamps.thisYear) {\n groupKey = moment(item.startTime * 1000).format(\"MMMM\");\n } else {\n groupKey = moment(item.startTime * 1000).format(\"YYYY\");\n }\n let group = groupMap.get(groupKey);\n if (!group) {\n groupMap.set(groupKey, (group = { title: groupKey, items: [] }));\n }\n group.items.push(item);\n }\n\n return [...groupMap.values()];\n }, [list]);\n\n const [actionsVisible, setActionsVisible] = useState<string | null>(null);\n\n const nextRef = useRef<HTMLDivElement | null>(null);\n\n useEffect(() => {\n const next = nextRef.current;\n const root = rootRef.current;\n if (!next || !nextToken || !root) {\n return;\n }\n const observer = new IntersectionObserver(\n (entries) => {\n for (const entry of entries) {\n if (entry.isIntersecting) {\n setLoadNextToken(nextToken);\n }\n }\n },\n { root }\n );\n observer.observe(next);\n return () => {\n observer.disconnect();\n };\n }, [nextToken]);\n\n if (!list) {\n return (\n <div className=\"history\">\n <div className=\"loading\">\n <WrappedIcon\n lib=\"antd\"\n theme=\"outlined\"\n icon=\"loading-3-quarters\"\n spinning\n />\n </div>\n </div>\n );\n }\n\n return (\n <div className=\"history\" ref={rootRef}>\n <ul>\n {groups.map((group) => (\n <li key={group.title} className=\"group\">\n <div className=\"group-title\">{group.title}</div>\n <ul className=\"items\">\n {group.items.map((item) => (\n <li key={item.id}>\n <WrappedLink\n className={classNames(\"item\", {\n \"actions-active\": item.id === actionsVisible,\n active: item.id === activeId,\n })}\n onClick={onHistoryClick}\n {...(urlTemplate\n ? { url: parseTemplate(urlTemplate, item) }\n : null)}\n >\n <div className=\"item-title\" title={item.title}>\n {item.title}\n </div>\n <WrappedMiniActions\n className=\"actions\"\n actions={actions}\n onActionClick={(e) => {\n onActionClick({ action: e.detail, item });\n }}\n onVisibleChange={(e) => {\n setActionsVisible(e.detail ? item.id : null);\n }}\n />\n {!DONE_STATES.includes(item.state!) && (\n <div className=\"working\"></div>\n )}\n </WrappedLink>\n </li>\n ))}\n </ul>\n </li>\n ))}\n </ul>\n {nextToken && (\n <div className=\"load-more\" ref={nextRef}>\n <WrappedIcon lib=\"antd\" icon=\"loading-3-quarters\" spinning />\n </div>\n )}\n </div>\n );\n}\n\nfunction parseTemplate(template: string, context: Record<string, any>) {\n return template?.replace(/{{(.*?)}}/g, (_match: string, key: string) => {\n const value = get(context, key);\n return value;\n });\n}\n","import React, { useCallback, useEffect, useState } from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport { initializeI18n } from \"@next-core/i18n\";\nimport classNames from \"classnames\";\nimport type { DropdownActionsProps } from \"@next-bricks/basic/dropdown-actions\";\nimport { K, NS, locales, t } from \"./i18n.js\";\nimport styleText from \"./styles.shadow.css\";\nimport ElevoLogo from \"../elevo-logo/images/logo@2x.png\";\nimport {\n WrappedDropdownActions,\n WrappedEasyopsAvatar,\n WrappedIcon,\n WrappedLink,\n} from \"./bricks.js\";\nimport { ChatHistory, type ActionClickDetail } from \"./ChatHistory.js\";\nimport type { ActionType } from \"@next-bricks/basic/mini-actions\";\n\ninitializeI18n(NS, locales);\n\nconst dropdownActions: DropdownActionsProps[\"actions\"] = [\n {\n icon: {\n lib: \"fa\",\n prefix: \"fas\",\n icon: \"arrow-right-from-bracket\",\n },\n text: t(K.LOGOUT),\n },\n];\n\nconst { defineElement, property, event } = createDecorators();\n\nexport interface ElevoSidebarProps {\n userInstanceId?: string;\n behavior?: \"default\" | \"drawer\";\n logoUrl?: string;\n newChatUrl?: string;\n historyActiveId?: string;\n historyUrlTemplate?: string;\n historyActions?: ActionType[];\n}\n\n/**\n * 构件 `ai-portal.elevo-sidebar`\n */\nexport\n@defineElement(\"ai-portal.elevo-sidebar\", {\n styleTexts: [styleText],\n})\nclass ElevoSidebar extends ReactNextElement implements ElevoSidebarProps {\n @property()\n accessor userInstanceId: string | undefined;\n\n @property()\n accessor behavior: \"default\" | \"drawer\" | undefined;\n\n @property()\n accessor logoUrl: string | undefined;\n\n @property()\n accessor newChatUrl: string | undefined;\n\n @property()\n accessor historyActiveId: string | undefined;\n\n @property()\n accessor historyUrlTemplate: string | undefined;\n\n @property({ attribute: false })\n accessor historyActions: ActionType[] | undefined;\n\n @event({ type: \"logout\" })\n accessor #logout!: EventEmitter<void>;\n\n #handleLogout = () => {\n this.#logout.emit();\n };\n\n @event({ type: \"action.click\" })\n accessor #actionClick!: EventEmitter<ActionClickDetail>;\n\n #handleActionClick = (detail: ActionClickDetail) => {\n this.#actionClick.emit(detail);\n };\n\n render() {\n return (\n <ElevoSidebarComponent\n userInstanceId={this.userInstanceId}\n behavior={this.behavior}\n logoUrl={this.logoUrl}\n newChatUrl={this.newChatUrl}\n historyActiveId={this.historyActiveId}\n historyUrlTemplate={this.historyUrlTemplate}\n historyActions={this.historyActions}\n onLogout={this.#handleLogout}\n onActionClick={this.#handleActionClick}\n />\n );\n }\n}\n\ninterface ElevoSidebarComponentProps extends ElevoSidebarProps {\n onLogout: () => void;\n onActionClick: (detail: ActionClickDetail) => void;\n}\n\nfunction ElevoSidebarComponent({\n userInstanceId,\n behavior,\n logoUrl,\n newChatUrl,\n historyActiveId,\n historyUrlTemplate,\n historyActions,\n onLogout,\n onActionClick,\n}: ElevoSidebarComponentProps) {\n const [collapsed, setCollapsed] = useState(behavior === \"drawer\");\n const handleCollapse = useCallback(() => {\n setCollapsed(true);\n }, []);\n const handleExpand = useCallback(() => {\n setCollapsed(false);\n }, []);\n\n useEffect(() => {\n if (behavior === \"drawer\") {\n setCollapsed(true);\n }\n }, [behavior]);\n\n const handleClickMask = useCallback(() => {\n setCollapsed(true);\n }, []);\n\n const handleHistoryClick = useCallback(() => {\n if (behavior === \"drawer\") {\n setCollapsed(true);\n }\n }, [behavior]);\n\n return (\n <div className={classNames(\"container\", { collapsed })}>\n {behavior === \"drawer\" && !collapsed && (\n <div className=\"mask\" onClick={handleClickMask} />\n )}\n <div className=\"sidebar\">\n <div className=\"logo-bar\">\n <WrappedLink url={logoUrl} className=\"logo-link\">\n <img\n className=\"logo\"\n alt=\"Elevo\"\n src={ElevoLogo}\n width={95}\n height={26}\n />\n </WrappedLink>\n <button className=\"toggle\" onClick={handleCollapse}>\n <WrappedIcon lib=\"easyops\" icon=\"sidebar\" />\n </button>\n </div>\n <WrappedLink className=\"new-chat\" url={newChatUrl}>\n <WrappedIcon\n className=\"new-chat-icon\"\n lib=\"easyops\"\n icon=\"new-chat\"\n />\n {t(K.NEW_CHAT)}\n </WrappedLink>\n <ChatHistory\n activeId={historyActiveId}\n urlTemplate={historyUrlTemplate}\n actions={historyActions}\n onActionClick={onActionClick}\n onHistoryClick={handleHistoryClick}\n />\n <div className=\"footer\">\n <WrappedDropdownActions\n className=\"dropdown\"\n actions={dropdownActions}\n onActionClick={onLogout}\n >\n <button className=\"account\">\n <WrappedEasyopsAvatar\n nameOrInstanceId={userInstanceId}\n showName\n size=\"xs\"\n />\n </button>\n </WrappedDropdownActions>\n </div>\n </div>\n <div className=\"alternative\">\n <button className=\"toggle\" onClick={handleExpand}>\n <WrappedIcon lib=\"easyops\" icon=\"sidebar\" />\n </button>\n <WrappedLink className=\"new-chat\" url={newChatUrl}>\n <WrappedIcon\n className=\"new-chat-icon\"\n lib=\"easyops\"\n icon=\"new-chat\"\n />\n {t(K.NEW_CHAT)}\n </WrappedLink>\n </div>\n </div>\n );\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:inline-block;padding:3px 0}:host([hidden]){display:none}img{display:block}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nimport ___CSS_LOADER_GET_URL_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/getUrl.js\";\nvar ___CSS_LOADER_URL_IMPORT_0___ = new URL(\"./images/background@2x.png\", import.meta.url);\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\nvar ___CSS_LOADER_URL_REPLACEMENT_0___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_0___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:block}:host([hidden]){display:none}*{box-sizing:border-box}.root{color:#262626;background-color:#e1e3ec;background-image:url(${___CSS_LOADER_URL_REPLACEMENT_0___});background-size:694px 144px;background-position:top left;background-repeat:no-repeat;box-shadow:inset 0px 2px 5px 1px rgba(42,46,59,0.1);border-radius:20px;padding:12px}.container{position:relative}textarea{display:block;width:100%;padding:10px 16px 52px;color:var(--antd-input-color);background:rgba(255,255,255,0.8);border-radius:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.5);font-size:14px;line-height:22px;height:130px}textarea::placeholder{color:rgba(0,0,0,0.4)}.btn-send:focus,\ntextarea:focus{outline:none}.btn-send{position:absolute;bottom:14px;right:14px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#2540ff;border:none;border-radius:8px;color:#fff}.btn-send[disabled]{background:rgba(0,0,0,0.15)}.btn-send:not([disabled]){cursor:pointer}.btn-send:not([disabled]):hover{background:#5166ff}.btn-send:not([disabled]):active{background:#1e33cc}.suggestions{margin-top:19px}.heading{display:flex;align-items:center;padding:0 5px;margin-bottom:8px}.icon{margin-right:5px}.carousel{overflow:hidden}.carousel + .carousel{margin-top:7px}.list{display:flex;width:max-content;list-style:none;margin:0;padding:0;font-size:12px}.item{background:rgba(255,255,255,0.4);border-radius:12px;border:1px solid #dcdee6;padding:12px;max-width:330px;cursor:pointer}.item:hover{background:rgba(255,255,255,0.5);border:1px solid rgba(37,64,255,0.3)}.list > li + li{margin-left:7px}.title{margin-bottom:4px}.content{color:rgba(0,0,0,0.45);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tooltip{display:block}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:block}:host([hidden]){display:none}*{box-sizing:border-box}.sidebar{position:relative;width:261px;height:100%;background:#f6f7f9;border-right:1px solid #e3e5eb;padding:26px 16px 0;display:flex;flex-direction:column;transition:transform 0.3s ease-in-out}.logo-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px}.logo-link::part(link){display:block}.logo{vertical-align:middle}.toggle{color:#595959;font-size:18px;width:28px;height:28px;display:flex;align-items:center;justify-content:space-between;background:none;border:none;cursor:pointer;border-radius:8px}.toggle:hover{background:rgba(0,0,0,0.04)}.new-chat::part(link){display:flex;align-items:center;color:var(--elevo-color-brand);font-size:14px;text-align:left;cursor:pointer}.sidebar .new-chat::part(link){background:#f0f4ff;border-radius:8px;border:1px solid #c9d7ff;padding:9px 13px;font-weight:500;margin-bottom:23px}.sidebar .new-chat::part(link):hover{background:rgba(201,215,255,0.5)}.new-chat-icon{font-size:16px;margin-right:5px}.footer{border-top:1px solid rgba(0,0,0,0.04);padding:9px 12px;margin:0 -16px}.dropdown{display:block}.account{background:none;border:none;border-radius:8px;padding:6px 10px;display:block;width:100%;text-align:left;cursor:pointer}.account:hover{background:rgba(0,0,0,0.04)}.alternative{position:fixed;top:14px;left:16px;display:flex;align-items:center;opacity:0;z-index:1;transition:opacity 0.2s ease-in-out}.alternative .new-chat::part(link){padding:4px;margin-left:16px;font-size:12px}.alternative .new-chat::part(link):hover{color:#7891ff}.alternative .new-chat::part(link):active{color:#0911b3}.container{width:261px;height:100%;transition:width 0.3s ease-in-out}.collapsed{width:0;overflow:visible}.collapsed .sidebar{transform:translateX(-100%)}.collapsed .alternative{opacity:1}:host([behavior=\"drawer\"]){z-index:1;width:0}:host(:not([behavior=\"drawer\"])) .alternative .new-chat{display:none}.mask{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--antd-modal-mask-bg)}.history{flex:1;min-height:0;overflow-y:auto;margin:0 -16px;padding:0 12px}.history ul{list-style:none;margin:0;padding:0}.history .loading{display:flex;justify-content:center;padding:8px}.history .group + .group{margin-top:15px}.history .group-title{font-weight:500;font-size:12px;color:#000;padding:8px;height:36px;line-height:20px}.history .item{display:block}.history .item::part(link){display:flex;align-items:center;padding:0 8px;height:36px;border-radius:8px;color:#000}.history .item.active::part(link){background:rgba(0,0,0,0.06)}.history .item:not(.active)::part(link):hover{background:rgba(0,0,0,0.04)}.history .item-title{flex:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.history .actions{cursor:auto}.history .item:not(:hover):not(.actions-active) .actions{display:none}.history .working{width:8px;height:8px;border-radius:8px;background:#2540ff;margin:0 7px}.history .item:hover .working,.history .item.active .working{display:none}.history .load-more{display:flex;justify-content:center;align-items:center;height:36px}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nimport ___CSS_LOADER_GET_URL_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/getUrl.js\";\nvar ___CSS_LOADER_URL_IMPORT_0___ = new URL(\"./images/background.png\", import.meta.url);\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\nvar ___CSS_LOADER_URL_REPLACEMENT_0___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_0___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:block;background-color:#fff;background-image:url(${___CSS_LOADER_URL_REPLACEMENT_0___});background-position:center;background-size:cover;background-repeat:no-repeat;background-attachment:fixed}:host([hidden]){display:none}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n"],"names":["___CSS_LOADER_EXPORT___","push","module","id","toString","initializeI18n","NS","locales","defineElement","property","event","method","createDecorators","MemoizedNodeComponent","memo","NodeComponent","CruiseCanvasComponent","forwardRef","LegacyCruiseCanvasComponent","_CruiseCanvas","_A","WeakMap","_B","_C","_D","_E","_CruiseCanvas_brand","WeakSet","_onShare","_F","_onPause","_G","_onResume","_H","_onCancel","_ref","CruiseCanvas","ReactNextElement","constructor","arguments","_classPrivateMethodInitSpec","_classPrivateFieldInitSpec","_initProto","_init_taskId","_init_extra_taskId","_init_task","_init_extra_task","_init_jobs","_init_extra_jobs","_init_replay","_init_extra_replay","_init_shareEvent","_init_extra_shareEvent","_classPrivateGetter","this","_get_shareEvent","emit","_init_pauseEvent","_init_extra_pauseEvent","_get_pauseEvent","_init_resumeEvent","_init_extra_resumeEvent","_get_resumeEvent","_init_cancelEvent","_init_extra_cancelEvent","_get_cancelEvent","createRef","taskId","_classPrivateFieldGet","v","_classPrivateFieldSet","task","jobs","replay","resumed","_classPrivateFieldGet2","current","render","React","onShare","onPause","onResume","onCancel","ref","_ref2","_task$title","propTask","propJobs","rootRef","useRef","_task","_jobs","plan","_plan","error","humanInputRef","resumedRef","useTaskDetail","graph","useTaskGraph","rawNodes","nodes","rawEdges","edges","nav","views","pageTitle","title","taskState","state","activeNodeId","setActiveNodeId","useState","currentNavId","useMemo","type","jobId","split","useImperativeHandle","_resumedRef$current","call","transitionEnabledRef","useEffect","timer","setTimeout","clearTimeout","getRuntime","applyPageTitle","handleHttpError","humanInput","useCallback","input","_humanInputRef$curren","sizeMap","setSizeMap","onNodeResize","size","prev","newMap","Map","delete","set","sizeReady","useLayout","detectScrolledUpRef","manualScrolledUpRef","hoverOnScrollableContent","setHoverOnScrollableContent","grabbing","transform","transformRef","zoomer","useZoom","zoomable","scrollable","pannable","transitionRef","pushZoomTransition","nextAction","run","action","target","translateBy","selection","select","_target$duration","_transform$k","_transform$x","_transform$y","_translateBy$","_translateBy$2","duration","transition","ease","t","on","next","ZoomTransform","k","x","y","centered","setCentered","reCenterRef","useAutoCenter","taskLoading","DONE_STATES","includes","length","nonLeafNodes","Set","map","edge","source","bottom","leafNodes","node","has","Math","max","view","height","bottomRef","root","offsetHeight","transformedBottom","diffY","CANVAS_PADDING_BOTTOM","handleReCenter","handleScaleChange","scale","scaleTo","fullRect","mergeRects","offsetWidth","viewportWidth","viewportHeight","minX","maxX","width","minY","maxY","translateExtent","scrollTo","_ref3","nodeId","behavior","block","targets","filter","n","_job","job","rect","getScrollTo","CANVAS_PADDING_TOP","CANVAS_PADDING_RIGHT","CANVAS_PADDING_LEFT","undefined","scrollBy","direction","range","distance","isHorizontal","top","targetHeight","activeToolCallJobId","setActiveToolCallJobId","activeExpandedViewJobId","setActiveExpandedViewJobId","canvasContextValue","activeToolCallJob","find","handleRootClick","e","element","nativeEvent","composedPath","HTMLElement","classList","contains","styles","handleKeyDown","document","activeElement","body","keyboardAction","handleKeyboardNav","_node$job$toolCall","_node$job$toolCall2","askUser","toolCall","name","askUserPlan","preventDefault","stopPropagation","addEventListener","removeEventListener","CanvasContext","Provider","value","className","classNames","loading","style","cursor","tabIndex","onClick","WrappedIcon","lib","theme","icon","spinning","canvas","ready","key","d","points","_ref4","i","join","_node$state","_node$view","_node$view2","content","startTime","instructionLoading","GENERAL_DONE_STATES","active","widgets","item","PlanProgress","ZoomBar","onScaleChange","onReCenter","ToolCallDetail","ExpandedView","_ref5","nodeRef","useContext","observer","ResizeObserver","observe","disconnect","handleMouseDown","handleClick","left","NodeStart","NodeEnd","NodeRequirement","NodeInstruction","instruction","NodeView","NodeJob","_CruiseCanvas2","_set_shareEvent","_set_pauseEvent","_set_resumeEvent","_set_cancelEvent","c","_initClass","_applyDecs","shadowOptions","attribute","Number","o","_","_checkInRHS","K","en","ASK_ANY_THING","COMMON_TASKS","zh","i18n","getFixedT","wrapBrick","_ChatBox","_ChatBox_brand","_handleMessageSubmit","ChatBox","_init_disabled","_init_extra_disabled","_init_placeholder","_init_extra_placeholder","_init_autoFocus","_init_extra_autoFocus","_init_suggestions","_init_extra_suggestions","_init_suggestionsLabel","_init_extra_suggestionsLabel","_init_messageSubmit","_init_extra_messageSubmit","_get_messageSubmit","disabled","placeholder","autoFocus","suggestions","suggestionsLabel","ChatBoxComponent","onSubmit","containerRef","textareaRef","setValue","valueRef","handleSubmit","currentTarget","handleChange","handleSubmitClick","Promise","resolve","then","_textareaRef$current","focus","groupedSuggestions","chunk","ceil","handleSelectSuggestion","suggestion","_textareaRef$current2","TextareaAutoResize","minRows","paddingSize","autoResize","submitWhen","onChange","prefix","src","tips","group","index","SuggestionCarousel","pixelPerSecond","onSelect","carouselRef","listRef","setX","carousel","list","previousTimestamp","currentTimestamp","start","offsetTime","mod","step","timestamp","requestAnimationFrame","onMouseEnter","cancelAnimationFrame","onMouseLeave","_ChatBox2","_set_messageSubmit","styleTexts","styleText","Boolean","_HomeContainer","HomeContainer","HomeContainerComponent","_HomeContainer2","TODAY","YESTERDAY","PREVIOUS_7_DAYS","PREVIOUS_30_DAYS","WrappedLink","WrappedMiniActions","onActionClick","onVisibleChange","_ChatHistory","_ChatHistory_brand","_handleActionClick","_handleLoadMore","ChatHistory","_init_list","_init_extra_list","_init_actions","_init_extra_actions","_init_nextToken","_init_extra_nextToken","_init_actionClick","_init_extra_actionClick","detail","_get_actionClick","_init_loadMore","_init_extra_loadMore","nextToken","_get_loadMore","actions","ChatHistoryComponent","onLoadMore","groups","groupMap","now","moment","startOfDay","startOf","yesterday","clone","subtract","sevenDaysAgo","thirtyDaysAgo","timestamps","groupKey","format","get","items","values","actionsVisible","setActionsVisible","nextRef","IntersectionObserver","entries","entry","isIntersecting","url","_ChatHistory2","_set_actionClick","_set_loadMore","WrappedMiniLineChart","_StatWithMiniChart","_I","_J","StatWithMiniChart","_init_label","_init_extra_label","_init_value","_init_extra_value","_init_size","_init_extra_size","_init_lineColor","_init_extra_lineColor","_init_showArea","_init_extra_showArea","_init_min","_init_extra_min","_init_max","_init_extra_max","_init_xField","_init_extra_xField","_init_yField","_init_extra_yField","_init_data","_init_extra_data","label","lineColor","showArea","min","xField","yField","data","StatWithMiniChartComponent","chartProps","_extends","lineWidth","_StatWithMiniChart2","_ElevoLogo","ElevoLogo","ElevoLogoComponent","logoImage","alt","_ElevoLogo2","NEW_CHAT","LOGOUT","WrappedDropdownActions","WrappedEasyopsAvatar","AgentFlowApi_searchTaskForAgentFlow","async","options","http","post","activeId","urlTemplate","onHistoryClick","setList","setNextToken","loadNextToken","setLoadNextToken","all","next_token","catch","console","template","context","replace","_match","dropdownActions","text","_ElevoSidebar","_ElevoSidebar_brand","_handleLogout","ElevoSidebar","_init_userInstanceId","_init_extra_userInstanceId","_init_behavior","_init_extra_behavior","_init_logoUrl","_init_extra_logoUrl","_init_newChatUrl","_init_extra_newChatUrl","_init_historyActiveId","_init_extra_historyActiveId","_init_historyUrlTemplate","_init_extra_historyUrlTemplate","_init_historyActions","_init_extra_historyActions","_init_logout","_init_extra_logout","_get_logout","userInstanceId","logoUrl","newChatUrl","historyActiveId","historyUrlTemplate","historyActions","ElevoSidebarComponent","onLogout","collapsed","setCollapsed","handleCollapse","handleExpand","handleClickMask","handleHistoryClick","nameOrInstanceId","showName","_ElevoSidebar2","_set_logout","___CSS_LOADER_URL_IMPORT_0___","URL","___CSS_LOADER_URL_REPLACEMENT_0___"],"sourceRoot":""}