@next-bricks/ai-portal 0.12.2 → 0.12.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (33) hide show
  1. package/dist/bricks.json +9 -5
  2. package/dist/chunks/1607.f5537929.js +2 -0
  3. package/dist/chunks/1607.f5537929.js.map +1 -0
  4. package/dist/chunks/8136.c756ba85.js +2 -0
  5. package/dist/chunks/8136.c756ba85.js.map +1 -0
  6. package/dist/chunks/cruise-canvas.4af272b8.js +2 -0
  7. package/dist/chunks/{cruise-canvas.c87f0250.js.map → cruise-canvas.4af272b8.js.map} +1 -1
  8. package/dist/chunks/main.c7bb363c.js +2 -0
  9. package/dist/chunks/main.c7bb363c.js.map +1 -0
  10. package/dist/chunks/stat-with-mini-chart.0c8b5712.js +2 -0
  11. package/dist/chunks/stat-with-mini-chart.0c8b5712.js.map +1 -0
  12. package/dist/examples.json +6 -3
  13. package/dist/index.2dbc0ade.js +2 -0
  14. package/dist/index.2dbc0ade.js.map +1 -0
  15. package/dist/manifest.json +89 -38
  16. package/dist/types.json +150 -60
  17. package/dist-types/bootstrap.d.ts +1 -0
  18. package/dist-types/cruise-canvas/utils/converters/convertForm.d.ts +1 -1
  19. package/dist-types/cruise-canvas/utils/converters/expressions.d.ts +11 -0
  20. package/dist-types/cruise-canvas/utils/converters/interfaces.d.ts +1 -0
  21. package/dist-types/stat-with-mini-chart/index.d.ts +35 -0
  22. package/dist-types/stat-with-mini-chart/index.spec.d.ts +1 -0
  23. package/docs/stat-with-mini-chart.md +226 -0
  24. package/package.json +4 -3
  25. package/dist/chunks/2335.08b02fcc.js +0 -2
  26. package/dist/chunks/2335.08b02fcc.js.map +0 -1
  27. package/dist/chunks/7301.eb125ee2.js +0 -2
  28. package/dist/chunks/7301.eb125ee2.js.map +0 -1
  29. package/dist/chunks/cruise-canvas.c87f0250.js +0 -2
  30. package/dist/chunks/main.8ebb7977.js +0 -2
  31. package/dist/chunks/main.8ebb7977.js.map +0 -1
  32. package/dist/index.90639dd9.js +0 -2
  33. package/dist/index.90639dd9.js.map +0 -1
package/dist/bricks.json CHANGED
@@ -1,18 +1,16 @@
1
1
  {
2
2
  "id": "bricks/ai-portal",
3
3
  "bricks": [
4
- "ai-portal.chat-box",
5
4
  "ai-portal.cruise-canvas",
6
5
  "ai-portal.chat-history",
6
+ "ai-portal.stat-with-mini-chart",
7
+ "ai-portal.chat-box",
7
8
  "ai-portal.home-container"
8
9
  ],
9
10
  "elements": [],
10
11
  "processors": [],
11
12
  "editors": [],
12
13
  "dependencies": {
13
- "ai-portal.chat-box": [
14
- "eo-icon"
15
- ],
16
14
  "ai-portal.cruise-canvas": [
17
15
  "eo-icon",
18
16
  "eo-button",
@@ -27,7 +25,13 @@
27
25
  "eo-icon",
28
26
  "eo-link",
29
27
  "eo-mini-actions"
28
+ ],
29
+ "ai-portal.stat-with-mini-chart": [
30
+ "eo-mini-line-chart"
31
+ ],
32
+ "ai-portal.chat-box": [
33
+ "eo-icon"
30
34
  ]
31
35
  },
32
- "filePath": "bricks/ai-portal/dist/index.90639dd9.js"
36
+ "filePath": "bricks/ai-portal/dist/index.2dbc0ade.js"
33
37
  }
@@ -0,0 +1,2 @@
1
+ "use strict";(globalThis.webpackChunk_next_bricks_ai_portal=globalThis.webpackChunk_next_bricks_ai_portal||[]).push([[1607],{24:(e,t,n)=>{n.d(t,{A:()=>o});var a=n(6758),s=n.n(a),i=n(935),r=n.n(i)()(s());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()},1107:(e,t,n)=>{e.exports=n.p+"images/eef4f2bd.png"},1411:(e,t,n)=>{n.d(t,{A:()=>o});var a=n(6758),s=n.n(a),i=n(935),r=n.n(i)()(s());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}",""]);const o=r.toString()},2165:(e,t,n)=>{n.d(t,{A:()=>h});var a=n(6758),s=n.n(a),i=n(935),r=n.n(i),o=n(62),l=n.n(o),c=new URL(n(2360),n.b),u=r()(s()),d=l()(c);u.push([e.id,`:host{display:block;background-color:#fff;background-image:url(${d});background-position:center;background-size:cover;background-repeat:no-repeat;background-attachment:fixed}:host([hidden]){display:none}`,""]);const h=u.toString()},2360:(e,t,n)=>{e.exports=n.p+"images/6336f999.png"},7008:(e,t,n)=>{n.d(t,{A:()=>h});var a=n(6758),s=n.n(a),i=n(935),r=n.n(i),o=n(62),l=n.n(o),c=new URL(n(1107),n.b),u=r()(s()),d=l()(c);u.push([e.id,`:host{display:block}:host([hidden]){display:none}*{box-sizing:border-box}.root{color:#262626;background-color:#e1e3ec;background-image:url(${d});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=u.toString()},8430:(e,t,n)=>{var a,s=n(4635),i=n(918),r=n(6902),o=n(5536),l=n(6121),c=n(829),u=n(2740),d=n(8769),h=n.n(d),m=n(7921),p=n(1280),g=n(3081),b=(n(5168),n(79)),f=n(3373),v=n.n(f),A=n(9126),k=n(7566),x=n(9445),E=n(2460),w=n(2464),y=n(8231),N=n(6494),S=n(7642),M=n(2773),R=n(9533),T=n(3153),C=n(4999),_=n(7954),z=n(4388),W=n(6938),I=n(4609),Y=n(9295),j=n(410),O=n(6854),D=n(5805),L=n(5620),B=n(3349),F=n(2601),P=n(7097);let U,H,V,$,K,q,X,G,Q,J,Z,ee,te,ne,ae,se,ie,re,oe,le,ce,ue,de,he,me,pe;(0,b.initializeI18n)(E.NS,E.I);const{defineElement:ge,property:be,event:fe,method:ve}=(0,m.createDecorators)(),Ae=(0,d.memo)(De),ke=(0,d.forwardRef)(Oe);let xe;var Ee=new WeakMap,we=new WeakMap,ye=new WeakMap,Ne=new WeakMap,Se=new WeakMap,Me=new WeakSet,Re=new WeakMap,Te=new WeakMap,Ce=new WeakMap,_e=new WeakMap,ze=new WeakMap,We=new WeakMap,Ie=new WeakMap,Ye=new WeakMap;class je extends p.ReactNextElement{constructor(){super(...arguments),(0,s.A)(this,Me),(0,i.A)(this,Ee,(U(this),V(this))),(0,i.A)(this,we,($(this),K(this))),(0,i.A)(this,ye,(q(this),X(this))),(0,i.A)(this,Ne,(G(this),Q(this))),(0,i.A)(this,Se,(J(this),Z(this))),(0,i.A)(this,Re,(ne(this),()=>{(0,o.A)(Me,this,ee).emit()})),(0,i.A)(this,Te,ae(this)),(0,i.A)(this,Ce,(re(this),()=>{(0,o.A)(Me,this,se).emit()})),(0,i.A)(this,_e,oe(this)),(0,i.A)(this,ze,(ue(this),()=>{(0,o.A)(Me,this,le).emit()})),(0,i.A)(this,We,de(this)),(0,i.A)(this,Ie,(pe(this),()=>{(0,o.A)(Me,this,he).emit()})),(0,i.A)(this,Ye,(0,d.createRef)())}get taskId(){return(0,c.A)(Ee,this)}set taskId(e){(0,l.A)(Ee,this,e)}get task(){return(0,c.A)(we,this)}set task(e){(0,l.A)(we,this,e)}get jobs(){return(0,c.A)(ye,this)}set jobs(e){(0,l.A)(ye,this,e)}get goBackUrl(){return(0,c.A)(Ne,this)}set goBackUrl(e){(0,l.A)(Ne,this,e)}resumed(){var e;null===(e=(0,c.A)(Ye,this).current)||void 0===e||e.resumed()}render(){return h().createElement(ke,{taskId:this.taskId,jobs:this.jobs,task:this.task,goBackUrl:this.goBackUrl,onShare:(0,c.A)(Re,this),onPause:(0,c.A)(Ce,this),onResume:(0,c.A)(ze,this),onCancel:(0,c.A)(Ie,this),ref:(0,c.A)(Ye,this)})}}function Oe(e,t){var n;let{taskId:a,task:s,jobs:i,goBackUrl:r,onShare:o,onPause:l,onResume:c,onCancel:u}=e;const m=(0,d.useRef)(null),{task:p,jobs:b,plan:f,error:A,humanInputRef:E,resumedRef:_}=(0,M.S)(a),z=a?p:s,W=a?b:i,I=a?f:null==s?void 0:s.plan,Y=(0,R.B)(z,W),j=null==Y?void 0:Y.nodes,U=null==Y?void 0:Y.edges,H=null==Y?void 0:Y.nav,V=null!==(n=null==z?void 0:z.title)&&void 0!==n?n:"",$=null==z?void 0:z.state,[K,q]=(0,d.useState)(null);(0,d.useImperativeHandle)(t,(()=>({resumed:()=>{var e;return null===(e=_.current)||void 0===e?void 0:e.call(_)}})),[_]);const X=(0,d.useRef)(!1);(0,d.useEffect)((()=>{const e=setTimeout((()=>{X.current=!0}),3e3);return()=>{clearTimeout(e)}}),[]);const G=(0,d.useRef)(!1),Q=(0,d.useCallback)(((e,t)=>X.current&&0!==t?(G.current=!0,e.transition().duration(null!=t?t:300).ease((e=>e*(2-e))).on("end",(()=>{G.current=!1}))):e),[]);(0,d.useEffect)((()=>{(0,g.getRuntime)().applyPageTitle(V)}),[V]),(0,d.useEffect)((()=>{A&&(0,g.handleHttpError)(A)}),[A]);const J=(0,d.useCallback)(((e,t)=>{var n;null===(n=E.current)||void 0===n||n.call(E,e,t)}),[E]),[Z,ee]=(0,d.useState)(null),te=(0,d.useCallback)(((e,t)=>{ee((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:ne,nodes:ae,edges:se}=(0,S.g)({rawNodes:j,rawEdges:U,state:$,sizeMap:Z}),{grabbing:ie,transform:re,transformRef:oe,zoomer:le}=(0,y.f)({rootRef:m,zoomable:ne,scrollable:ne,pannable:ne}),{centered:ce,setCentered:ue,reCenterRef:de}=(0,N.E)({nodes:ae,sizeReady:ne,zoomer:le,rootRef:m,selectTransition:Q}),he=!O.QB.includes(null!=$?$:"working")&&2===ae.length,me=(0,d.useMemo)((()=>new Set(se.map((e=>e.source)))),[se]),pe=(0,d.useMemo)((()=>{if(!ne)return null;const e=[];for(const t of ae)me.has(t.id)||e.push(t);return e.length>0?Math.max(...e.map((e=>e.view.y+e.view.height))):null}),[ae,me,ne]),ge=(0,d.useRef)(null);(0,d.useEffect)((()=>{ge.current=pe}),[pe]);const be=(0,d.useRef)(!1);(0,d.useEffect)((()=>{const e=m.current;if(!e||null===pe||be.current)return;const{offsetHeight:t}=e,n=oe.current,a=pe*n.k+n.y,s=t-O.xX-a;s<0&&le.translateBy(Q((0,k.A)(e),s>-100?100:s<-500?300:200),0,s/n.k)}),[pe,oe,le,Q]),(0,d.useEffect)((()=>{const e=ge.current,t=m.current;if(!t||null===e||G.current)return;const{offsetHeight:n}=t,a=e*re.k+re.y,s=n-O.xX-a;be.current=s<0}),[re,le]);const fe=(0,d.useCallback)((()=>{de.current=!0,ue(!1)}),[de,ue]),ve=(0,d.useCallback)((e=>{le.scaleTo((0,k.A)(m.current),e)}),[le]),[ke,xe]=(0,d.useState)();(0,d.useEffect)((()=>{if(!ne)return;const e=setTimeout((()=>{let e,t=1/0;for(const n of ae)if("instruction"===n.type){const a=n.view.y*re.k+re.y-O.RV;a>=0&&a<t&&(t=a,e=n.job.id)}xe(e)}),100);return()=>{clearTimeout(e)}}),[ae,ne,re]);const Ee=(0,d.useCallback)((e=>{let{nodeId:t,jobId:n,behavior:a,block:s}=e;const i=m.current,r=ae.filter((e=>{var a;return!(t&&e.id!==t||n&&(null===(a=e.job)||void 0===a?void 0:a.id)!==n)}));if(!i||0===r.length)return;const o=(0,x.o)(r.map((e=>e.view))),{x:l,y:c}=(0,F.D)(o,[i.offsetWidth,i.offsetHeight],[O.RV,O.kq,O.xX,O.bL],oe.current,s);(l||c)&&le.translateBy(Q((0,k.A)(i),"instant"===a?0:void 0),l,c)}),[ae,Q,oe,le]),we=(0,d.useCallback)(((e,t)=>{const n=m.current;if(!n||!ne)return;let a,s=0,i=0,r=300;const o="left"===e||"right"===e;if("line"===t)a=40*("up"===e||"left"===e?1:-1),r=150;else if("page"===t)a=(n.offsetHeight-O.xX)*("up"===e?-1:1);else{const{y:t,height:s}=(0,x.o)(ae.map((e=>e.view)));if("down"===e){const e=t+s-t+O.xX;a=n.offsetHeight-e-oe.current.y}else a=t+O.RV-oe.current.y}o?s=a:i=a,(s||i)&&le.translateBy(Q((0,k.A)(n),r),s,i)}),[ae,Q,ne,oe,le]),[ye,Ne]=(0,d.useState)(null),Se=(0,d.useMemo)((()=>({humanInput:J,onShare:o,onPause:l,onResume:c,onCancel:u,onNodeResize:te,activeToolCallJobId:ye,setActiveToolCallJobId:Ne,setActiveNodeId:q})),[ye,te,J,o,l,c,u]),Me=(0,d.useMemo)((()=>ye?null==W?void 0:W.find((e=>e.id===ye)):null),[ye,W]),Re=(0,d.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,d.useEffect)((()=>{const e=m.current;if(!e||Me)return;const t=t=>{if(document.activeElement&&document.activeElement!==document.body&&document.activeElement!==e)return;const n=(0,P.l)(t,{activeNodeId:K,nodes:ae});if(!n)return;const{action:a,node:s}=n;if("scroll"===a)we(n.direction,n.range);else if("enter"===a){var i,r;if("job"!==s.type)return;const e="ask_human"===(null===(i=s.job.toolCall)||void 0===i?void 0:i.name),t="ask_human_confirming_plan"===(null===(r=s.job.toolCall)||void 0===r?void 0:r.name);if(e||t)return}t.preventDefault(),t.stopPropagation(),"enter"===a?Ne(s.job.id):"switch-active-node"===a&&(q(s.id),"job"===s.type||"view"===s.type?Ee({jobId:s.job.id,behavior:"smooth"}):Ee({nodeId:s.id,behavior:"smooth"}))};return document.addEventListener("keydown",t),()=>{document.removeEventListener("keydown",t)}}),[K,Me,ae,Ee,we]),h().createElement(L.Q.Provider,{value:Se},h().createElement("div",{className:v()(w.A.root,{[w.A.loading]:!z}),ref:m,style:{cursor:ie?"grabbing":"grab"},tabIndex:-1,onClick:Re},!z&&h().createElement("div",{className:w.A["loading-icon"]},h().createElement(D.Bj,{lib:"antd",theme:"outlined",icon:"loading-3-quarters",spinning:!0})),h().createElement("div",{className:v()(w.A.canvas,{[w.A.ready]:ne&&ce}),style:{transform:`translate3d(${re.x}px, ${re.y}px, 0) scale(${re.k})`}},h().createElement("svg",{className:w.A.edges},se.map((e=>h().createElement("path",{className:w.A.edge,key:`${e.source}-${e.target}`,d:e.points.map(((e,t)=>{let{x:n,y:a}=e;return`${0===t?"M":"L"}${n},${a}`})).join(" ")})))),ae.map((e=>{var t,n,a;return h().createElement(Ae,{key:e.id,id:e.id,type:e.type,content:e.content,job:e.job,state:e.state,startTime:null==z?void 0:z.startTime,taskLoading:he,instructionLoading:"instruction"===e.type&&!me.has(e.id)&&!O.QB.includes(null!==(t=e.state)&&void 0!==t?t:"working")&&!O.X4.includes(null!=$?$:"working"),edges:se,x:null===(n=e.view)||void 0===n?void 0:n.x,y:null===(a=e.view)||void 0===a?void 0:a.y,active:K===e.id})})))),h().createElement("div",{className:w.A.widgets},r&&h().createElement(D.EM,{className:w.A["go-back"],url:r},h().createElement(D.Bj,{lib:"fa",prefix:"fas",icon:"arrow-left-long"})),h().createElement("div",{className:w.A["nav-container"]},h().createElement("ul",{className:w.A.nav},null==H?void 0:H.map((e=>h().createElement("li",{key:e.id,className:v()(w.A["nav-item"],{[w.A.active]:ke===e.id})},h().createElement("a",{className:w.A["nav-link"],onClick:()=>{Ee({jobId:e.id,block:"start"})}},h().createElement("span",{className:w.A["nav-link-text"]},e.title))))))),h().createElement(T.r,{plan:I,state:$}),h().createElement(C.l,{scale:re.k,onScaleChange:ve,onReCenter:fe})),Me&&h().createElement(B.M,{job:Me}))}function De(e){let{id:t,type:n,state:a,job:s,content:i,startTime:r,taskLoading:o,instructionLoading:l,x:c,y:u,active:m}=e;const p=(0,d.useRef)(null),{onNodeResize:g,setActiveNodeId:b}=(0,d.useContext)(L.Q);(0,d.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,d.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,d.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!=u}),ref:p,style:{left:c,top:u},onClick:f},"start"===n?h().createElement(_.H,null):"end"===n?h().createElement(Y.s,{active:m}):"requirement"===n?h().createElement(z.O,{content:i,startTime:r,loading:o,active:m}):"instruction"===n?h().createElement(W.L,{content:s.instruction,loading:l}):"view"===n?h().createElement(j.Y,{job:s,active:m}):h().createElement(I.W,{state:a,job:s,active:m}))}a=je,({e:[V,$,K,q,X,G,Q,J,Z,ee,te,ne,ae,se,ie,re,oe,le,ce,ue,de,he,me,pe,U],c:[xe,H]}=(0,u.A)(a,[ge("ai-portal.cruise-canvas",{shadowOptions:!1})],[[be(),1,"taskId"],[be({attribute:!1}),1,"task"],[be({attribute:!1}),1,"jobs"],[be(),1,"goBackUrl"],[fe({type:"share"}),1,"shareEvent",e=>(0,c.A)(Se,e),(e,t)=>(0,l.A)(Se,e,t)],[fe({type:"pause"}),1,"pauseEvent",e=>(0,c.A)(Te,e),(e,t)=>(0,l.A)(Te,e,t)],[fe({type:"resume"}),1,"resumeEvent",e=>(0,c.A)(_e,e),(e,t)=>(0,l.A)(_e,e,t)],[fe({type:"cancel"}),1,"cancelEvent",e=>(0,c.A)(We,e),(e,t)=>(0,l.A)(We,e,t)],[ve(),2,"resumed"]],0,(e=>Ye.has((0,r.A)(e))),p.ReactNextElement)),H();var Le=n(1451),Be=n(1030);let Fe=function(e){return e.ASK_ANY_THING="ASK_ANYTHING",e.COMMON_TASKS="COMMON_TASKS",e}({});const Pe="bricks/ai-portal/chat-box",Ue={en:{[Fe.ASK_ANY_THING]:"Ask anything",[Fe.COMMON_TASKS]:"Common tasks"},zh:{[Fe.ASK_ANY_THING]:"询问任何问题",[Fe.COMMON_TASKS]:"常用任务"}},He=b.i18n.getFixedT(null,Pe),Ve=n.p+"images/af389fa6.svg";var $e,Ke=n(7008);let qe,Xe,Ge,Qe,Je,Ze,et,tt,nt,at,st,it,rt,ot,lt;(0,b.initializeI18n)(Pe,Ue);const ct=(0,p.wrapBrick)("eo-icon"),{defineElement:ut,property:dt,event:ht}=(0,m.createDecorators)();let mt;var pt=new WeakMap,gt=new WeakMap,bt=new WeakMap,ft=new WeakMap,vt=new WeakMap,At=new WeakMap,kt=new WeakSet,xt=new WeakMap;class Et extends p.ReactNextElement{constructor(){super(...arguments),(0,s.A)(this,kt),(0,i.A)(this,pt,Xe(this)),(0,i.A)(this,gt,(Ge(this),Qe(this))),(0,i.A)(this,bt,(Je(this),Ze(this))),(0,i.A)(this,ft,(et(this),tt(this))),(0,i.A)(this,vt,(nt(this),at(this))),(0,i.A)(this,At,(st(this),it(this))),(0,i.A)(this,xt,(lt(this),e=>{(0,o.A)(kt,this,rt).emit(e)}))}get disabled(){return(0,c.A)(pt,this)}set disabled(e){(0,l.A)(pt,this,e)}get placeholder(){return(0,c.A)(gt,this)}set placeholder(e){(0,l.A)(gt,this,e)}get autoFocus(){return(0,c.A)(bt,this)}set autoFocus(e){(0,l.A)(bt,this,e)}get suggestions(){return(0,c.A)(ft,this)}set suggestions(e){(0,l.A)(ft,this,e)}get suggestionsLabel(){return(0,c.A)(vt,this)}set suggestionsLabel(e){(0,l.A)(vt,this,e)}render(){return h().createElement(wt,{disabled:this.disabled,placeholder:this.placeholder,autoFocus:this.autoFocus,suggestions:this.suggestions,suggestionsLabel:this.suggestionsLabel,onSubmit:(0,c.A)(xt,this)})}}function wt(e){let{disabled:t,placeholder:n,autoFocus:a,suggestions:s,suggestionsLabel:i,onSubmit:r}=e;const o=(0,d.useRef)(null),l=(0,d.useRef)(null),[c,u]=(0,d.useState)(""),m=(0,d.useRef)(""),p=(0,d.useCallback)((e=>{e.currentTarget.value&&(null==r||r(e.currentTarget.value))}),[r]),g=(0,d.useCallback)((e=>{m.current=e.target.value,u(e.target.value)}),[]),b=(0,d.useCallback)((()=>{null==r||r(m.current)}),[r]);(0,d.useEffect)((()=>{a&&Promise.resolve().then((()=>{var e;null===(e=l.current)||void 0===e||e.focus()}))}),[]);const f=(0,d.useMemo)((()=>null!=s&&s.length?(0,Be.chunk)(s,Math.max(2,Math.ceil(s.length/2))):[]),[s]),v=(0,d.useCallback)((e=>{m.current=e.content,u(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:He(Fe.ASK_ANY_THING),submitWhen:"enter-without-shift",onSubmit:p,onChange:g}),h().createElement("button",{className:"btn-send",disabled:!c,onClick:b},h().createElement(ct,{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:Ve,width:16,height:16}),h().createElement("span",null,null!=i?i:He(Fe.COMMON_TASKS))),f.map(((e,t)=>h().createElement(yt,{key:t,suggestions:e,pixelPerSecond:10*(t+2),onSelect:v})))))}function yt(e){let{suggestions:t,pixelPerSecond:n,onSelect:a}=e;const s=(0,d.useRef)(null),i=(0,d.useRef)(null),[r,o]=(0,d.useState)(0);return(0,d.useEffect)((()=>{const e=s.current,t=i.current;if(!e||!t)return;let a,r,l,c,u=0;const d=(t.offsetWidth-7)/2+7;function h(e){r=e,void 0===l&&(l=e),void 0!==a&&(u+=e-a,a=void 0),o((e-l-u)/1e3*n%d),c=requestAnimationFrame(h)}c=requestAnimationFrame(h);const m=()=>{cancelAnimationFrame(c),a=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:s},h().createElement("ul",{className:"list",ref:i,style:{transform:`translateX(${-r}px)`}},[...t,...t].map(((e,t)=>h().createElement("li",{key:t},h().createElement("div",{className:"item",onClick:()=>a(e),title:e.content},h().createElement("div",{className:"title"},e.title),h().createElement("div",{className:"content"},e.content)))))))}$e=Et,({e:[Xe,Ge,Qe,Je,Ze,et,tt,nt,at,st,it,rt,ot,lt],c:[mt,qe]}=(0,u.A)($e,[ut("ai-portal.chat-box",{styleTexts:[Ke.A]})],[[dt({type:Boolean}),1,"disabled"],[dt(),1,"placeholder"],[dt({type:Boolean}),1,"autoFocus"],[dt({attribute:!1}),1,"suggestions"],[dt(),1,"suggestionsLabel"],[ht({type:"message.submit"}),1,"messageSubmit",e=>(0,c.A)(At,e),(e,t)=>(0,l.A)(At,e,t)]],0,(e=>xt.has((0,r.A)(e))),p.ReactNextElement)),qe();var Nt,St=n(2165);let Mt;const{defineElement:Rt}=(0,m.createDecorators)();let Tt;class Ct extends p.ReactNextElement{render(){return h().createElement(_t,null)}}function _t(){return h().createElement("slot",null)}Nt=Ct,[Tt,Mt]=(0,u.A)(Nt,[Rt("ai-portal.home-container",{styleTexts:[St.A]})],[],0,void 0,p.ReactNextElement).c,Mt();var zt=n(1302),Wt=n.n(zt);let It=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 Yt="bricks/ai-portal/chat-history",jt={en:{[It.TODAY]:"Today",[It.YESTERDAY]:"Yesterday",[It.PREVIOUS_7_DAYS]:"Previous 7 days",[It.PREVIOUS_30_DAYS]:"Previous 30 days"},zh:{[It.TODAY]:"今天",[It.YESTERDAY]:"昨天",[It.PREVIOUS_7_DAYS]:"过去7天",[It.PREVIOUS_30_DAYS]:"过去30天"}},Ot=b.i18n.getFixedT(null,Yt);var Dt,Lt=n(1411);let Bt,Ft,Pt,Ut,Ht,Vt,$t,Kt,qt;(0,b.initializeI18n)(Yt,jt);const Xt=(0,p.wrapBrick)("eo-icon"),Gt=(0,p.wrapBrick)("eo-link"),Qt=(0,p.wrapBrick)("eo-mini-actions",{onActionClick:"action.click",onVisibleChange:"visible.change"}),{defineElement:Jt,property:Zt,event:en}=(0,m.createDecorators)();let tn;var nn=new WeakMap,an=new WeakMap,sn=new WeakMap,rn=new WeakSet,on=new WeakMap;class ln extends p.ReactNextElement{constructor(){super(...arguments),(0,s.A)(this,rn),(0,i.A)(this,nn,Ft(this)),(0,i.A)(this,an,(Pt(this),Ut(this))),(0,i.A)(this,sn,(Ht(this),Vt(this))),(0,i.A)(this,on,(qt(this),e=>{(0,o.A)(rn,this,$t).emit(e)}))}get list(){return(0,c.A)(nn,this)}set list(e){(0,l.A)(nn,this,e)}get actions(){return(0,c.A)(an,this)}set actions(e){(0,l.A)(an,this,e)}render(){return h().createElement(cn,{list:this.list,actions:this.actions,onActionClick:(0,c.A)(on,this)})}}function cn(e){let{list:t,actions:n,onActionClick:a}=e;const s=(0,d.useMemo)((()=>{const e=new Map,n=Wt()(),a=n.startOf("day"),s=a.clone().subtract(1,"day"),i=a.clone().subtract(7,"days"),r=a.clone().subtract(30,"days"),o=+a/1e3,l=+s/1e3,c=+i/1e3,u=+r/1e3,d=n.year();for(const n of null!=t?t:[]){let t;t=n.startTime>=o?Ot(It.TODAY):n.startTime>=l?Ot(It.YESTERDAY):n.startTime>=c?Ot(It.PREVIOUS_7_DAYS):n.startTime>=u?Ot(It.PREVIOUS_30_DAYS):n.startTime>=d?Wt()(1e3*n.startTime).format("MMMM"):Wt()(1e3*n.startTime).format("YYYY");let a=e.get(t);a||e.set(t,a={title:t,items:[]}),a.items.push(n)}return[...e.values()]}),[t]),[i,r]=(0,d.useState)(null);return t?h().createElement("ul",null,s.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(Gt,{className:v()("item",{active:i===e.id}),url:e.url},h().createElement("div",{className:"item-title"},e.title),h().createElement(Qt,{className:"actions",actions:n,onActionClick:t=>{null==a||a({action:t.detail,item:e})},onVisibleChange:t=>{r(t.detail?e.id:null)}}),!O.QB.includes(e.state)&&h().createElement("div",{className:"working"})))))))))):h().createElement("div",{className:"loading"},h().createElement(Xt,{lib:"antd",theme:"outlined",icon:"loading-3-quarters",spinning:!0}))}Dt=ln,({e:[Ft,Pt,Ut,Ht,Vt,$t,Kt,qt],c:[tn,Bt]}=(0,u.A)(Dt,[Jt("ai-portal.chat-history",{styleTexts:[Lt.A]})],[[Zt({attribute:!1}),1,"list"],[Zt({attribute:!1}),1,"actions"],[en({type:"action.click"}),1,"actionClick",e=>(0,c.A)(sn,e),(e,t)=>(0,l.A)(sn,e,t)]],0,(e=>on.has((0,r.A)(e))),p.ReactNextElement)),Bt();var un,dn=n(9575),hn=n(24);let mn,pn,gn,bn,fn,vn,An,kn,xn,En,wn,yn,Nn,Sn,Mn,Rn,Tn;const Cn=(0,p.wrapBrick)("eo-mini-line-chart"),{defineElement:_n,property:zn}=(0,m.createDecorators)();let Wn;var In=new WeakMap,Yn=new WeakMap,jn=new WeakMap,On=new WeakMap,Dn=new WeakMap,Ln=new WeakMap,Bn=new WeakMap,Fn=new WeakMap;class Pn extends p.ReactNextElement{constructor(){super(...arguments),(0,i.A)(this,In,pn(this)),(0,i.A)(this,Yn,(gn(this),bn(this))),(0,i.A)(this,jn,(fn(this),vn(this))),(0,i.A)(this,On,(An(this),kn(this))),(0,i.A)(this,Dn,(xn(this),En(this))),(0,i.A)(this,Ln,(wn(this),yn(this))),(0,i.A)(this,Bn,(Nn(this),Sn(this))),(0,i.A)(this,Fn,(Mn(this),Rn(this))),Tn(this)}get label(){return(0,c.A)(In,this)}set label(e){(0,l.A)(In,this,e)}get value(){return(0,c.A)(Yn,this)}set value(e){(0,l.A)(Yn,this,e)}get size(){return(0,c.A)(jn,this)}set size(e){(0,l.A)(jn,this,e)}get lineColor(){return(0,c.A)(On,this)}set lineColor(e){(0,l.A)(On,this,e)}get showArea(){return(0,c.A)(Dn,this)}set showArea(e){(0,l.A)(Dn,this,e)}get xField(){return(0,c.A)(Ln,this)}set xField(e){(0,l.A)(Ln,this,e)}get yField(){return(0,c.A)(Bn,this)}set yField(e){(0,l.A)(Bn,this,e)}get data(){return(0,c.A)(Fn,this)}set data(e){(0,l.A)(Fn,this,e)}render(){return h().createElement(Un,{label:this.label,value:this.value,size:this.size,lineColor:this.lineColor,showArea:this.showArea,xField:this.xField,yField:this.yField,data:this.data})}}function Un(e){let{label:t,value:n,size:a,...s}=e;return"small"===a?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(Cn,(0,dn.A)({},s,{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(Cn,(0,dn.A)({},s,{lineWidth:2,width:"auto",height:"92"}))),h().createElement("div",{className:"stat"},n)))}un=Pn,({e:[pn,gn,bn,fn,vn,An,kn,xn,En,wn,yn,Nn,Sn,Mn,Rn,Tn],c:[Wn,mn]}=(0,u.A)(un,[_n("ai-portal.stat-with-mini-chart",{styleTexts:[hn.A]})],[[zn(),1,"label"],[zn(),1,"value"],[zn(),1,"size"],[zn(),1,"lineColor"],[zn({type:Boolean}),1,"showArea"],[zn(),1,"xField"],[zn(),1,"yField"],[zn({attribute:!1}),1,"data"]],0,void 0,p.ReactNextElement)),mn()}}]);
2
+ //# sourceMappingURL=1607.f5537929.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunks/1607.f5537929.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/home-container/styles.shadow.css","webpack:///./src/chat-box/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"],"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}`, \"\"]);\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","// 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","// 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 } from \"d3-selection\";\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} 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, WrappedLink } 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\";\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 goBackUrl?: string;\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 @property()\n accessor goBackUrl: string | 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 goBackUrl={this.goBackUrl}\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 goBackUrl,\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);\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 pageTitle = task?.title ?? \"\";\n const taskState = task?.state;\n const [activeNodeId, setActiveNodeId] = useState<string | null>(null);\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 const transitionRef = useRef(false);\n const selectTransition = useCallback(\n (\n selection: Selection<HTMLDivElement, unknown, null, undefined>,\n duration?: number\n ) => {\n if (!transitionEnabledRef.current || duration === 0) {\n return selection;\n }\n transitionRef.current = true;\n return selection\n .transition()\n .duration(duration ?? 300)\n .ease((t) => t * (2 - t)) // Ease in-out\n .on(\"end\", () => {\n transitionRef.current = false;\n });\n },\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 const { grabbing, transform, transformRef, zoomer /* , scaleRange */ } =\n useZoom({\n rootRef,\n zoomable: sizeReady,\n scrollable: sizeReady,\n pannable: sizeReady,\n });\n\n const { centered, setCentered, reCenterRef } = useAutoCenter({\n nodes,\n sizeReady,\n zoomer,\n rootRef,\n selectTransition,\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 // Disable auto scroll when the user manually scrolled up\n const manualScrolledUpRef = useRef(false);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || bottom === null || manualScrolledUpRef.current) {\n return;\n }\n const { offsetHeight } = root;\n const transform = transformRef.current;\n const transformedBottom = bottom * transform.k + transform.y;\n const diffY = offsetHeight - CANVAS_PADDING_BOTTOM - transformedBottom;\n if (diffY < 0) {\n // Make the latest node visible\n zoomer.translateBy(\n selectTransition(\n select(root),\n diffY > -100 ? 100 : diffY < -500 ? 300 : 200\n ),\n 0,\n diffY / transform.k\n );\n }\n }, [bottom, transformRef, zoomer, selectTransition]);\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 manualScrolledUpRef.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 [currentNavId, setCurrentNavId] = useState<string | undefined>();\n\n // Find the active nav item by node position against the canvas top\n useEffect(() => {\n if (!sizeReady) {\n return;\n }\n\n const timer = setTimeout(() => {\n let distance = Infinity;\n let navId: string | undefined;\n for (const node of nodes) {\n if (node.type === \"instruction\") {\n const y = node.view!.y * transform.k + transform.y;\n const diff = y - CANVAS_PADDING_TOP;\n if (diff >= 0 && diff < distance) {\n distance = diff;\n navId = node.job.id;\n }\n }\n }\n setCurrentNavId(navId);\n }, 100);\n\n return () => {\n clearTimeout(timer);\n };\n }, [nodes, sizeReady, transform]);\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 zoomer.translateBy(\n selectTransition(\n select(root),\n behavior === \"instant\" ? 0 : undefined\n ),\n x,\n y\n );\n }\n },\n [nodes, selectTransition, transformRef, zoomer]\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 zoomer.translateBy(selectTransition(select(root), duration), x, y);\n }\n },\n [nodes, selectTransition, sizeReady, transformRef, zoomer]\n );\n\n const [activeToolCallJobId, setActiveToolCallJobId] = useState<string | null>(\n null\n );\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 }),\n [\n activeToolCallJobId,\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) {\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\") {\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 setActiveToolCallJobId((node as JobGraphNode).job.id);\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 }, [activeNodeId, activeToolCallJob, nodes, scrollTo, scrollBy]);\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 {goBackUrl && (\n <WrappedLink className={styles[\"go-back\"]} url={goBackUrl}>\n <WrappedIcon lib=\"fa\" prefix=\"fas\" icon=\"arrow-left-long\" />\n </WrappedLink>\n )}\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 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 </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, { useMemo, 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}\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 @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 <ChatHistoryComponent\n list={this.list}\n actions={this.actions}\n onActionClick={this.#handleActionClick}\n />\n );\n }\n}\n\nexport interface ChatHistoryComponentProps extends ChatHistoryProps {\n onActionClick?: (detail: ActionClickDetail) => void;\n}\n\ninterface GroupedHistory {\n title: string;\n items: HistoryItem[];\n}\n\nexport function ChatHistoryComponent({\n list,\n actions,\n onActionClick,\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.year();\n\n const timestamps = {\n startOfDay: +startOfDay / 1000,\n yesterday: +yesterday / 1000,\n sevenDaysAgo: +sevenDaysAgo / 1000,\n thirtyDaysAgo: +thirtyDaysAgo / 1000,\n thisYear,\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 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 <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\">{item.title}</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 );\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\"\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 * @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 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"],"names":["___CSS_LOADER_EXPORT___","push","module","id","toString","___CSS_LOADER_URL_IMPORT_0___","URL","___CSS_LOADER_URL_REPLACEMENT_0___","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_goBackUrl","_init_extra_goBackUrl","_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","goBackUrl","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","pageTitle","title","taskState","state","activeNodeId","setActiveNodeId","useState","useImperativeHandle","_resumedRef$current","call","transitionEnabledRef","useEffect","timer","setTimeout","clearTimeout","transitionRef","selectTransition","useCallback","selection","duration","transition","ease","t","on","getRuntime","applyPageTitle","handleHttpError","humanInput","jobId","input","_humanInputRef$curren","sizeMap","setSizeMap","onNodeResize","size","prev","newMap","Map","delete","set","sizeReady","useLayout","grabbing","transform","transformRef","zoomer","useZoom","zoomable","scrollable","pannable","centered","setCentered","reCenterRef","useAutoCenter","taskLoading","DONE_STATES","includes","length","nonLeafNodes","useMemo","Set","map","edge","source","bottom","leafNodes","node","has","Math","max","view","y","height","bottomRef","manualScrolledUpRef","root","offsetHeight","transformedBottom","k","diffY","CANVAS_PADDING_BOTTOM","translateBy","select","handleReCenter","handleScaleChange","scale","scaleTo","currentNavId","setCurrentNavId","navId","distance","Infinity","type","diff","CANVAS_PADDING_TOP","job","scrollTo","_ref3","nodeId","behavior","block","targets","filter","n","_job","rect","mergeRects","x","getScrollTo","offsetWidth","CANVAS_PADDING_RIGHT","CANVAS_PADDING_LEFT","undefined","scrollBy","direction","range","isHorizontal","top","targetHeight","activeToolCallJobId","setActiveToolCallJobId","canvasContextValue","activeToolCallJob","find","handleRootClick","e","element","nativeEvent","composedPath","HTMLElement","classList","contains","styles","handleKeyDown","document","activeElement","body","keyboardAction","handleKeyboardNav","action","_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","target","d","points","_ref4","i","join","_node$state","_node$view","_node$view2","content","startTime","instructionLoading","GENERAL_DONE_STATES","active","widgets","WrappedLink","url","prefix","item","PlanProgress","ZoomBar","onScaleChange","onReCenter","ToolCallDetail","_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","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","src","tips","width","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","WrappedMiniActions","onActionClick","onVisibleChange","_ChatHistory","_ChatHistory_brand","_handleActionClick","ChatHistory","_init_list","_init_extra_list","_init_actions","_init_extra_actions","_init_actionClick","_init_extra_actionClick","detail","_get_actionClick","actions","ChatHistoryComponent","groups","groupMap","now","moment","startOfDay","startOf","yesterday","clone","subtract","sevenDaysAgo","thirtyDaysAgo","timestamps","year","groupKey","format","get","items","values","actionsVisible","setActionsVisible","_ChatHistory2","_set_actionClick","WrappedMiniLineChart","_StatWithMiniChart","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_xField","_init_extra_xField","_init_yField","_init_extra_yField","_init_data","_init_extra_data","label","lineColor","showArea","xField","yField","data","StatWithMiniChartComponent","chartProps","_extends","lineWidth","_StatWithMiniChart2"],"sourceRoot":""}