@next-bricks/ai-portal 0.64.6 → 0.64.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (33) hide show
  1. package/dist/bricks.json +34 -34
  2. package/dist/chunks/{4208.90f96600.js → 4208.54a5a7dd.js} +2 -2
  3. package/dist/chunks/4208.54a5a7dd.js.map +1 -0
  4. package/dist/chunks/{4820.d3be9b94.js → 4820.51e9c918.js} +2 -2
  5. package/dist/chunks/4820.51e9c918.js.map +1 -0
  6. package/dist/chunks/5411.095a6093.js +3 -0
  7. package/dist/chunks/5411.095a6093.js.map +1 -0
  8. package/dist/chunks/{778.850294cf.js → 778.1a43bbd5.js} +2 -2
  9. package/dist/chunks/778.1a43bbd5.js.map +1 -0
  10. package/dist/chunks/chat-panel.abf4cbf4.js +2 -0
  11. package/dist/chunks/chat-panel.abf4cbf4.js.map +1 -0
  12. package/dist/chunks/{elevo-sidebar.78a35f1d.js → elevo-sidebar.4aa42ab3.js} +3 -3
  13. package/dist/chunks/{elevo-sidebar.78a35f1d.js.map → elevo-sidebar.4aa42ab3.js.map} +1 -1
  14. package/dist/chunks/{main.87744001.js → main.f7f23cfb.js} +2 -2
  15. package/dist/chunks/{main.87744001.js.map → main.f7f23cfb.js.map} +1 -1
  16. package/dist/examples.json +20 -20
  17. package/dist/{index.00f609de.js → index.6af15770.js} +2 -2
  18. package/dist/{index.00f609de.js.map → index.6af15770.js.map} +1 -1
  19. package/dist/manifest.json +179 -179
  20. package/dist/types.json +713 -713
  21. package/dist-types/cruise-canvas/reducers/interfaces.d.ts +1 -0
  22. package/dist-types/elevo-sidebar/NavLinkWithActions.d.ts +11 -0
  23. package/dist-types/shared/interfaces.d.ts +1 -0
  24. package/package.json +2 -2
  25. package/dist/chunks/4208.90f96600.js.map +0 -1
  26. package/dist/chunks/4820.d3be9b94.js.map +0 -1
  27. package/dist/chunks/7059.912e3307.js +0 -3
  28. package/dist/chunks/7059.912e3307.js.map +0 -1
  29. package/dist/chunks/778.850294cf.js.map +0 -1
  30. package/dist/chunks/chat-panel.a3dafde9.js +0 -2
  31. package/dist/chunks/chat-panel.a3dafde9.js.map +0 -1
  32. /package/dist/chunks/{7059.912e3307.js.LICENSE.txt → 5411.095a6093.js.LICENSE.txt} +0 -0
  33. /package/dist/chunks/{elevo-sidebar.78a35f1d.js.LICENSE.txt → elevo-sidebar.4aa42ab3.js.LICENSE.txt} +0 -0
@@ -1,3 +0,0 @@
1
- /*! For license information please see 7059.912e3307.js.LICENSE.txt */
2
- "use strict";(globalThis.webpackChunk_next_bricks_ai_portal=globalThis.webpackChunk_next_bricks_ai_portal||[]).push([[7059],{5813:(e,t,i)=>{i.d(t,{I:()=>c,K:()=>a,NS:()=>o,t:()=>s});var n=i(67177);let a=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.SWITCH_LANGUAGE="SWITCH_LANGUAGE",e.MY="MY",e.PROJECTS="PROJECTS",e.HISTORY="HISTORY",e.CREATE_PROJECT="CREATE_PROJECT",e.MOVE_TO_PROJECT="MOVE_TO_PROJECT",e.UNTITLED="UNTITLED",e.UNNAMED="UNNAMED",e.BUSINESS_OBJECTS="BUSINESS_OBJECTS",e.BUSINESS_OBJECT_MODELS="BUSINESS_OBJECT_MODELS",e.SERVICEFLOWS="SERVICEFLOWS",e.COLLABORATION_SPACES="COLLABORATION_SPACES",e.CREATE_SERVICEFLOW="CREATE_SERVICEFLOW",e}({});const r={[a.NEW_CHAT]:"New chat",[a.LOGOUT]:"Logout",[a.TODAY]:"Today",[a.YESTERDAY]:"Yesterday",[a.PREVIOUS_7_DAYS]:"Previous 7 days",[a.PREVIOUS_30_DAYS]:"Previous 30 days",[a.SWITCH_LANGUAGE]:"中文",[a.MY]:"My",[a.PROJECTS]:"Projects",[a.HISTORY]:"Chats",[a.CREATE_PROJECT]:"Create project",[a.MOVE_TO_PROJECT]:"Move to project",[a.UNTITLED]:"Untitled",[a.UNNAMED]:"Unnamed",[a.BUSINESS_OBJECTS]:"Business objects",[a.SERVICEFLOWS]:"Serviceflows",[a.COLLABORATION_SPACES]:"Collaboration spaces",[a.CREATE_SERVICEFLOW]:"Create serviceflow",[a.BUSINESS_OBJECT_MODELS]:"Business object models"},l={[a.NEW_CHAT]:"新对话",[a.LOGOUT]:"登出",[a.TODAY]:"今天",[a.YESTERDAY]:"昨天",[a.PREVIOUS_7_DAYS]:"过去7天",[a.PREVIOUS_30_DAYS]:"过去30天",[a.SWITCH_LANGUAGE]:"English",[a.MY]:"我的",[a.PROJECTS]:"项目",[a.HISTORY]:"对话",[a.CREATE_PROJECT]:"创建项目",[a.MOVE_TO_PROJECT]:"移动到项目",[a.UNTITLED]:"无标题",[a.UNNAMED]:"未命名",[a.BUSINESS_OBJECTS]:"业务对象",[a.SERVICEFLOWS]:"业务流",[a.COLLABORATION_SPACES]:"协作空间",[a.CREATE_SERVICEFLOW]:"创建业务流",[a.BUSINESS_OBJECT_MODELS]:"业务对象模型"},o="bricks/ai-portal/elevo-sidebar",c={en:r,zh:l},s=n.i18n.getFixedT(null,o)},17452:(e,t,i)=>{i.d(t,{c:()=>n,w:()=>a});const n={lib:"fa",icon:"plus"},a={lib:"lucide",icon:"box"}},41938:(e,t,i)=>{i.d(t,{c:()=>g});var n=i(89575),a=i(18769),r=i.n(a),l=i(53373),o=i.n(l),c=i(60128),s=i(51578),d=i(5813),p=i(70579),u=i(94504),m=i(17452),E=i(84311);function g(e){let{returnUrl:t,introUrl:i,spaceDetail:l,spaceObjects:g,spaceServiceflows:h,spaceLinks:v,onAddServiceflow:f}=e;const x=(0,a.useRef)(null),[b,k]=(0,a.useState)(!1),[S,y]=(0,a.useState)(!1),T=(0,E.d)(i),O=null==l?void 0:l.icon,C=(null==O?void 0:O.color)||"gray",{color:N,...w}=O||{};return r().createElement(r().Fragment,null,r().createElement(p.EM,{url:t,className:"return-link"},r().createElement(p.Bj,{className:"icon",lib:"lucide",icon:"chevron-left"}),r().createElement("div",{className:"avatar",style:{color:`var(--theme-${C}-color)`}},r().createElement(p.Bj,w)),r().createElement("div",{className:"heading"},r().createElement("div",{className:"title"},null==l?void 0:l.name),r().createElement("div",{className:"sub-title"},(0,d.t)(d.K.COLLABORATION_SPACES)))),r().createElement("div",{className:"divider"}),r().createElement("div",{className:"history",ref:x},g?r().createElement("div",{className:o()("section",{collapsed:b})},r().createElement(s._,{rootRef:x,title:(0,d.t)(d.K.BUSINESS_OBJECTS),collapsed:b,onToggle:()=>k((e=>!e))},r().createElement(p.Py,{icon:m.w,variant:"mini-light",tooltip:(0,d.t)(d.K.BUSINESS_OBJECT_MODELS),tooltipHoist:!0,className:"button",active:T,onClick:()=>(0,c.getHistory)().push(i)})),r().createElement("ul",{className:"items"},g.map(((e,t)=>r().createElement("li",{key:t},r().createElement(u.k,{url:e.url,activeIncludes:e.activeIncludes,render:t=>{let{active:i}=t;return r().createElement(p.EM,{className:o()("item",{active:i}),url:e.url},r().createElement("div",{className:"item-title"},e.title))}})))))):null,h?r().createElement("div",{className:o()("section",{collapsed:S})},r().createElement(s._,{rootRef:x,title:(0,d.t)(d.K.SERVICEFLOWS),collapsed:S,onToggle:()=>y((e=>!e))},r().createElement(p.Py,{icon:m.c,variant:"mini-light",tooltip:(0,d.t)(d.K.CREATE_SERVICEFLOW),tooltipHoist:!0,className:"button",onClick:f})),r().createElement("ul",{className:"items"},h.map(((e,t)=>r().createElement("li",{key:t},r().createElement(u.k,{url:e.url,activeIncludes:e.activeIncludes,render:t=>{let{active:i}=t;return r().createElement(p.EM,{className:o()("item",{active:i}),url:e.url},r().createElement("div",{className:"item-title"},e.title))}})))))):null,null!=v&&v.length?r().createElement("div",{className:"space-links"},v.map(((e,t)=>r().createElement(u.k,{key:t,url:e.url,activeIncludes:e.activeIncludes,render:i=>{let{active:a}=i;return r().createElement(p.EM,{key:t,className:o()("link",{active:a}),url:e.url},r().createElement(p.Bj,(0,n.A)({className:"icon"},e.icon)),r().createElement("span",{className:"title"},e.title))}})))):null))}},51578:(e,t,i)=>{i.d(t,{_:()=>s});var n=i(18769),a=i.n(n),r=i(41030),l=i(53373),o=i.n(l),c=i(70579);function s(e){let{rootRef:t,title:i,collapsed:l,children:s,onToggle:d}=e;const p=(0,n.useRef)(null),[u,m]=(0,n.useState)(!1);return(0,n.useEffect)((()=>{if(l)return void m(!1);const e=t.current,i=p.current,n=null==i?void 0:i.nextElementSibling;if(!e||!i||!n)return;const a=(0,r.throttle)((()=>{const e=i.getBoundingClientRect(),t=n.getBoundingClientRect().top-e.top-e.height;m(t<1)}),100);return e.addEventListener("scroll",a),()=>{e.removeEventListener("scroll",a)}}),[l,t]),a().createElement("div",{className:o()("section-title",{sticky:u}),ref:p},a().createElement("div",{className:"section-label",onClick:d},i,a().createElement(c.Bj,{lib:"fa",icon:"angle-down"})),s)}},61408:(e,t,i)=>{i.d(t,{A:()=>o});var n=i(36758),a=i.n(n),r=i(40935),l=i.n(r)()(a());l.push([e.id,':host{display:block}:host([hidden]){display:none}*{box-sizing:border-box}.sidebar{position:relative;z-index:2;width:260px;height:100%;background:rgba(246,247,249,0.5);border:1px solid rgba(255,255,255,0.3);border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:23px 11px 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;margin-left:4px}.main{flex:1;min-height:0;display:flex;flex-direction:column}.divider{border-top:1px solid rgba(0,0,0,0.06);margin:16px 0}.logo-link::part(link){display:block}.logo{vertical-align:middle}.new-chat::part(link){display:flex;gap:0;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:16px}.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 -12px}.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:8px;left:8px;padding:6px 10px 6px 8px;display:flex;align-items:center;opacity:0;z-index:2;transition:opacity 0.2s ease-in-out;background:rgba(255,255,255,0);border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.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:270px;padding:10px 0 10px 10px;height:100%;transition:width 0.3s ease-in-out,padding 0.3s ease-in-out}.container.collapsed{width:0;padding:10px 0;overflow:visible}.container.collapsed .sidebar{transform:translateX(-100%)}.container.collapsed .alternative{opacity:1}:host([behavior="drawer"]){z-index:2;width:0}:host(:not([behavior="drawer"])) .alternative .new-chat{display:none}.mask{position:fixed;top:0;right:0;bottom:0;left:0}.link{display:block}.link + .link{margin-top:4px}.link::part(link){display:flex;gap:0;align-items:center;padding:7px 10px;border-radius:8px;color:#000}.link.active::part(link),.link::part(link):hover{background:rgba(0,0,0,0.04)}.link .icon{font-size:16px;margin-right:10px}.link .title{flex:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.history{flex:1;min-height:0;overflow-y:auto;margin:0 -12px;padding:0 12px}.history ul{list-style:none;margin:0;padding:0}.history .section + .section{margin-top:14px}.history .section-title{display:flex;align-items:center;justify-content:space-between;height:30px;margin-bottom:6px;padding:0 8px;position:sticky;top:0}.history .section-title.sticky::before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-color:rgb(229,228,234);border-radius:8px;z-index:-1}.history .section-label{display:flex;align-items:center;height:24px;padding:0 8px;margin-left:-8px;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500;font-size:12px;color:#8c8c8c;border-radius:8px}.history .section-label eo-icon{vertical-align:middle;margin-left:6px;transition:transform 0.2s ease-in-out}.history .section-label:hover{background:rgba(0,0,0,0.04)}.history .collapsed > ul{display:none}.history .collapsed .section-label eo-icon{transform:rotate(-90deg)}.history .error,.history .loading{display:flex;align-items:center;height:36px;padding:0 8px}.history .loading{justify-content:center}.history .error{color:var(--color-error)}.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.actions-active::part(link),.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(.actions-active) .actions{display:none}.history .working{width:8px;height:8px;border-radius:8px;background:var(--elevo-color-brand);margin:0 7px}.history .item.actions-active .working,.history .item:hover .working,.history .item.active .working{display:none}.history .load-more{display:flex;justify-content:center;align-items:center;height:36px}.button{display:flex}.space-links{margin-top:16px}.return-link{display:block}.return-link .heading{display:flex;flex-direction:column;align-items:flex-start;gap:4px;flex:1;min-width:0}.return-link .title,.return-link .sub-title{width:100%;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.return-link .title{font-weight:500;font-size:14px}.return-link .sub-title{font-size:12px;color:rgba(0,0,0,0.45)}.return-link .icon{font-size:16px;color:#646a73}.return-link .avatar{background:#fff;border-radius:8px;border:1px solid rgba(0,0,0,0.1);width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:18px}.return-link::part(link){display:flex;align-items:center;justify-content:center;gap:10px;padding:6px 8px;border-radius:8px;color:#262626}.return-link::part(link):hover{background:rgba(0,0,0,0.04)}',""]);const o=l.toString()},70579:(e,t,i)=>{i.d(t,{Bj:()=>a,EM:()=>r,JQ:()=>o,Py:()=>s,qb:()=>l,qu:()=>c});var n=i(30981);const a=(0,n.wrapBrick)("eo-icon"),r=(0,n.wrapBrick)("eo-link"),l=(0,n.wrapBrick)("eo-dropdown-actions",{onActionClick:"action.click",onVisibleChange:"visible.change"}),o=(0,n.wrapBrick)("eo-easyops-avatar"),c=(0,n.wrapBrick)("eo-mini-actions",{onActionClick:"action.click",onVisibleChange:"visible.change"}),s=(0,n.wrapBrick)("ai-portal.icon-button")},75197:(e,t,i)=>{i.d(t,{D:()=>f});var n=i(89575),a=i(18769),r=i.n(a),l=i(53373),o=i.n(l),c=i(22919);const s=async(e,t)=>(await c.http.get("api/gateway/logic.llm.aiops_service/api/v1/elevo/conversations",{...t,params:e})).data;var d=i(41030),p=i(5813),u=i(70579),m=i(40177),E=i(65549),g=i(94504),h=i(51578),v=i(17452);const f=(0,a.forwardRef)(x);function x(e,t){let{showProjects:i,historyActions:l,historyUrlTemplate:f,projectUrlTemplate:x,projectActions:b,canAddProject:k,myLinks:S,onActionClick:y,onHistoryClick:T,onProjectActionClick:O,onAddProject:C}=e;const N=(0,a.useRef)(null),[w,_]=(0,a.useState)(!1),[A,I]=(0,a.useState)(null),[R,P]=(0,a.useState)(!1),[B,L]=(0,a.useState)(!1),[U,j]=(0,a.useState)(null),[D,M]=(0,a.useState)(!1),[Y,V]=(0,a.useState)(),[J,H]=(0,a.useState)(),[W,z]=(0,a.useState)(!1),F=(0,a.useRef)(!0),[K,G]=(0,a.useState)([]),q=(0,a.useMemo)((()=>[...null!=l?l:[],{isDropdown:!0,text:(0,p.t)(p.K.MOVE_TO_PROJECT),disabled:!(null!=A&&A.length),items:null==A?void 0:A.map((e=>({event:"move",key:e.instanceId,text:e.name,project:e})))}]),[l,A]);(0,a.useEffect)((()=>{(async()=>{try{const e=await(async()=>(await c.http.get("api/gateway/logic.llm.aiops_service/api/v1/elevo/projects",{params:{page:1,page_size:3e3}})).data)();I(e.list)}catch(e){console.error("Error loading projects:",e),L(!0),I([])}})()}),[]),(0,a.useEffect)((()=>{Promise.all([s({token:J,limit:30,onlyOwner:!0,onlyUnrelatedProject:!0},{interceptorParams:{ignoreLoadingBar:!0}}),...F.current?[]:[new Promise((e=>setTimeout(e,500)))]]).then((e=>{let[t]=e;F.current=!1,j((e=>[...null!=e?e:[],...t.conversations])),V(t.nextToken)})).catch((e=>{console.error("Error loading chat history:",e),j([]),z(!0)}))}),[J]);const[Q,X]=(0,a.useState)(null),$=(0,a.useRef)(null);(0,a.useEffect)((()=>{const e=$.current,t=N.current;if(!e||!Y||!t||D)return;const i=new IntersectionObserver((e=>{for(const t of e)t.isIntersecting&&H(Y)}),{root:t});return i.observe(e),()=>{i.disconnect()}}),[Y,D]);const Z=(0,a.useRef)(0),ee=(0,a.useCallback)((async()=>{try{const e=++Z.current,t=await s({limit:30,onlyOwner:!0,onlyUnrelatedProject:!0},{interceptorParams:{ignoreLoadingBar:!0}});if(e!==Z.current)return;j((e=>{const i=null!=e?e:[],n=t.conversations,a=new Set(n.map((e=>e.conversationId))),r=new Map(n.map((e=>[e.conversationId,e])));let l=!1,o=!1,c=!0;for(const e of i){const t=r.get(e.conversationId);if(!t)break;if(l=!0,o=c&&t!==n[0]||!(0,d.isEqual)(t,e),o)break;c=!1}return l?o?[...n,...i.filter((e=>!a.has(e.conversationId)))]:e:(V(t.nextToken),n)}))}catch(e){console.error("Error pulling chat history:",e)}}),[]);(0,a.useImperativeHandle)(t,(()=>({pull:ee,removeProject:e=>{I((t=>t?t.filter((t=>t.instanceId!==e)):t))},addProject:e=>{I((t=>t?[...t,e]:[e]))},moveConversation:e=>{G((t=>[...t,e]))}})),[ee]);const te=(0,a.useMemo)((()=>U&&U.length?U.filter((e=>!K.includes(e.conversationId))):U),[U,K]);return r().createElement("div",{className:"history",ref:N},null!=S&&S.length?r().createElement("div",{className:o()("section",{collapsed:w})},r().createElement(h._,{rootRef:N,title:(0,p.t)(p.K.MY),collapsed:w,onToggle:()=>_((e=>!e))}),r().createElement("ul",{className:"items"},S.map(((e,t)=>r().createElement("li",{key:t},r().createElement(g.k,{url:e.url,activeIncludes:e.activeIncludes,render:t=>{let{active:i}=t;return r().createElement(u.EM,{className:o()("item",{active:i}),url:e.url},r().createElement("div",{className:"item-title"},e.title))}})))))):null,i&&r().createElement("div",{className:o()("section",{collapsed:R})},r().createElement(h._,{rootRef:N,title:(0,p.t)(p.K.PROJECTS),collapsed:R,onToggle:()=>P((e=>!e))},k&&r().createElement(u.Py,{icon:v.c,variant:"mini-light",tooltip:(0,p.t)(p.K.CREATE_PROJECT),tooltipHoist:!0,className:"button",onClick:C})),r().createElement("ul",{className:"items"},B?r().createElement("li",{className:"error"},"Failed to load project"):A?A.map((e=>{const t=x?(0,E.Q)(x,e):void 0;return r().createElement("li",{key:e.instanceId},r().createElement(g.k,{url:t,render:i=>{let{active:a}=i;return r().createElement(u.EM,(0,n.A)({className:o()("item",{"actions-active":e.instanceId===Q,active:a}),onClick:T},t?{url:t}:null),r().createElement("div",{className:"item-title",title:e.name},e.name||(0,p.t)(p.K.UNNAMED)),r().createElement(u.qu,{className:"actions",actions:b,themeVariant:"elevo",onActionClick:t=>{O({action:t.detail,project:e})},onVisibleChange:t=>{X(t.detail?e.instanceId:null)}}))}}))})):r().createElement("li",{className:"loading"},r().createElement(u.Bj,{lib:"antd",theme:"outlined",icon:"loading-3-quarters",spinning:!0})))),r().createElement("div",{className:o()("section",{collapsed:D})},r().createElement(h._,{rootRef:N,title:(0,p.t)(p.K.HISTORY),collapsed:D,onToggle:()=>M((e=>!e))}),r().createElement("ul",{className:"items"},te?te.map((e=>{const t=f?(0,E.Q)(f,e):void 0;return r().createElement("li",{key:e.conversationId},r().createElement(g.k,{url:t,render:t=>{let{active:i}=t;return r().createElement(u.EM,(0,n.A)({className:o()("item",{"actions-active":e.conversationId===Q,active:i}),onClick:T},f?{url:(0,E.Q)(f,e)}:null),r().createElement("div",{className:"item-title",title:e.title},e.title||(0,p.t)(p.K.UNTITLED)),r().createElement(u.qu,{className:"actions",actions:q,onActionClick:t=>{y({action:t.detail,item:e,project:t.detail.project})},onVisibleChange:t=>{X(t.detail?e.conversationId:null)}}),!m.QB.includes(e.state)&&r().createElement("div",{className:"working"}))}}))})):r().createElement("li",{className:"loading"},r().createElement(u.Bj,{lib:"antd",theme:"outlined",icon:"loading-3-quarters",spinning:!0})),W?r().createElement("li",{className:"error"},"Failed to load chat history"):null),!D&&Y&&r().createElement("div",{className:"load-more",ref:$},r().createElement(u.Bj,{lib:"antd",icon:"loading-3-quarters",spinning:!0}))))}},84311:(e,t,i)=>{i.d(t,{d:()=>r});var n=i(18769),a=i(60128);function r(e,t){const[i,r]=(0,n.useState)(!1);return(0,n.useEffect)((()=>{if(!e)return void r(!1);function i(i){for(const n of[e,...null!=t?t:[]])if((0,a.matchPath)(i.pathname,{path:n,exact:!1}))return void r(!0);r(!1)}const n=(0,a.getHistory)();return i(n.location),n.listen(i)}),[e,t]),i}},94504:(e,t,i)=>{i.d(t,{k:()=>a});var n=i(84311);function a(e){let{url:t,activeIncludes:i,render:a}=e;return a({active:(0,n.d)(t,i)})}}}]);
3
- //# sourceMappingURL=7059.912e3307.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"chunks/7059.912e3307.js","mappings":"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","sources":["webpack:///./src/elevo-sidebar/i18n.ts","webpack:///./src/elevo-sidebar/constants.ts","webpack:///./src/elevo-sidebar/SpaceNav.tsx","webpack:///./src/elevo-sidebar/SectionTitle.tsx","webpack:///./src/elevo-sidebar/styles.shadow.css","webpack:///./src/elevo-sidebar/bricks.ts","webpack:///../../node_modules/@next-api-sdk/llm-sdk/dist/esm/api/llm/elevo/getElevoProjects.js","webpack:///../../node_modules/@next-api-sdk/llm-sdk/dist/esm/api/llm/elevo/listElevoConversations.js","webpack:///./src/elevo-sidebar/ChatHistory.tsx","webpack:///./src/elevo-sidebar/useNavLinkActive.ts","webpack:///./src/elevo-sidebar/NavLink.tsx"],"sourcesContent":["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 SWITCH_LANGUAGE = \"SWITCH_LANGUAGE\",\n MY = \"MY\",\n PROJECTS = \"PROJECTS\",\n HISTORY = \"HISTORY\",\n CREATE_PROJECT = \"CREATE_PROJECT\",\n MOVE_TO_PROJECT = \"MOVE_TO_PROJECT\",\n UNTITLED = \"UNTITLED\",\n UNNAMED = \"UNNAMED\",\n BUSINESS_OBJECTS = \"BUSINESS_OBJECTS\",\n BUSINESS_OBJECT_MODELS = \"BUSINESS_OBJECT_MODELS\",\n SERVICEFLOWS = \"SERVICEFLOWS\",\n COLLABORATION_SPACES = \"COLLABORATION_SPACES\",\n CREATE_SERVICEFLOW = \"CREATE_SERVICEFLOW\",\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 [K.SWITCH_LANGUAGE]: \"中文\",\n [K.MY]: \"My\",\n [K.PROJECTS]: \"Projects\",\n [K.HISTORY]: \"Chats\",\n [K.CREATE_PROJECT]: \"Create project\",\n [K.MOVE_TO_PROJECT]: \"Move to project\",\n [K.UNTITLED]: \"Untitled\",\n [K.UNNAMED]: \"Unnamed\",\n [K.BUSINESS_OBJECTS]: \"Business objects\",\n [K.SERVICEFLOWS]: \"Serviceflows\",\n [K.COLLABORATION_SPACES]: \"Collaboration spaces\",\n [K.CREATE_SERVICEFLOW]: \"Create serviceflow\",\n [K.BUSINESS_OBJECT_MODELS]: \"Business object models\",\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 [K.SWITCH_LANGUAGE]: \"English\",\n [K.MY]: \"我的\",\n [K.PROJECTS]: \"项目\",\n [K.HISTORY]: \"对话\",\n [K.CREATE_PROJECT]: \"创建项目\",\n [K.MOVE_TO_PROJECT]: \"移动到项目\",\n [K.UNTITLED]: \"无标题\",\n [K.UNNAMED]: \"未命名\",\n [K.BUSINESS_OBJECTS]: \"业务对象\",\n [K.SERVICEFLOWS]: \"业务流\",\n [K.COLLABORATION_SPACES]: \"协作空间\",\n [K.CREATE_SERVICEFLOW]: \"创建业务流\",\n [K.BUSINESS_OBJECT_MODELS]: \"业务对象模型\",\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 type { GeneralIconProps } from \"@next-bricks/icons/general-icon\";\n\nexport const ADD_ICON: GeneralIconProps = {\n lib: \"fa\",\n icon: \"plus\",\n};\n\nexport const MODEL_ICON: GeneralIconProps = {\n lib: \"lucide\",\n icon: \"box\",\n};\n","import React, { useRef, useState } from \"react\";\nimport classNames from \"classnames\";\nimport { getHistory } from \"@next-core/runtime\";\nimport { SectionTitle } from \"./SectionTitle.js\";\nimport { K, t } from \"./i18n.js\";\nimport { WrappedIcon, WrappedIconButton, WrappedLink } from \"./bricks.js\";\nimport { NavLink } from \"./NavLink.js\";\nimport type { SidebarLink } from \"./interfaces.js\";\nimport { ADD_ICON, MODEL_ICON } from \"./constants.js\";\nimport { useNavLinkActive } from \"./useNavLinkActive.js\";\nimport type { GeneralIconProps } from \"@next-bricks/icons/general-icon\";\n\nexport interface SpaceNavProps {\n returnUrl: string;\n introUrl: string;\n spaceDetail: {\n instanceId: string;\n name: string;\n icon?: GeneralIconProps & {\n color?: string;\n };\n };\n spaceObjects?: SidebarLink[];\n spaceServiceflows?: SidebarLink[];\n spaceLinks?: SidebarLink[];\n}\n\nexport interface SpaceNavComponentProps extends SpaceNavProps {\n onAddServiceflow?: () => void;\n}\n\nexport function SpaceNav({\n returnUrl,\n introUrl,\n spaceDetail,\n spaceObjects,\n spaceServiceflows,\n spaceLinks,\n onAddServiceflow,\n}: SpaceNavComponentProps) {\n const rootRef = useRef<HTMLDivElement | null>(null);\n const [objectsCollapsed, setObjectsCollapsed] = useState(false);\n const [serviceflowsCollapsed, setServiceflowsCollapsed] = useState(false);\n const introActive = useNavLinkActive(introUrl);\n\n const avatarIcon = spaceDetail?.icon;\n const avatarColor = avatarIcon?.color || \"gray\";\n const { color, ...iconProps } = avatarIcon || {};\n\n return (\n <>\n <WrappedLink url={returnUrl} className=\"return-link\">\n <WrappedIcon className=\"icon\" lib=\"lucide\" icon=\"chevron-left\" />\n <div\n className=\"avatar\"\n style={{\n color: `var(--theme-${avatarColor}-color)`,\n }}\n >\n <WrappedIcon {...iconProps} />\n </div>\n <div className=\"heading\">\n <div className=\"title\">{spaceDetail?.name}</div>\n <div className=\"sub-title\">{t(K.COLLABORATION_SPACES)}</div>\n </div>\n </WrappedLink>\n <div className=\"divider\" />\n <div className=\"history\" ref={rootRef}>\n {spaceObjects ? (\n <div\n className={classNames(\"section\", { collapsed: objectsCollapsed })}\n >\n <SectionTitle\n rootRef={rootRef}\n title={t(K.BUSINESS_OBJECTS)}\n collapsed={objectsCollapsed}\n onToggle={() => setObjectsCollapsed((prev) => !prev)}\n >\n <WrappedIconButton\n icon={MODEL_ICON}\n variant=\"mini-light\"\n tooltip={t(K.BUSINESS_OBJECT_MODELS)}\n tooltipHoist={true}\n className=\"button\"\n active={introActive}\n onClick={() => getHistory().push(introUrl)}\n />\n </SectionTitle>\n <ul className=\"items\">\n {spaceObjects.map((obj, index) => (\n <li key={index}>\n <NavLink\n url={obj.url}\n activeIncludes={obj.activeIncludes}\n render={({ active }) => (\n <WrappedLink\n className={classNames(\"item\", { active })}\n url={obj.url}\n >\n <div className=\"item-title\">{obj.title}</div>\n </WrappedLink>\n )}\n />\n </li>\n ))}\n </ul>\n </div>\n ) : null}\n {spaceServiceflows ? (\n <div\n className={classNames(\"section\", {\n collapsed: serviceflowsCollapsed,\n })}\n >\n <SectionTitle\n rootRef={rootRef}\n title={t(K.SERVICEFLOWS)}\n collapsed={serviceflowsCollapsed}\n onToggle={() => setServiceflowsCollapsed((prev) => !prev)}\n >\n <WrappedIconButton\n icon={ADD_ICON}\n variant=\"mini-light\"\n tooltip={t(K.CREATE_SERVICEFLOW)}\n tooltipHoist={true}\n className=\"button\"\n onClick={onAddServiceflow}\n />\n </SectionTitle>\n <ul className=\"items\">\n {spaceServiceflows.map((obj, index) => (\n <li key={index}>\n <NavLink\n url={obj.url}\n activeIncludes={obj.activeIncludes}\n render={({ active }) => (\n <WrappedLink\n className={classNames(\"item\", { active })}\n url={obj.url}\n >\n <div className=\"item-title\">{obj.title}</div>\n </WrappedLink>\n )}\n />\n </li>\n ))}\n </ul>\n </div>\n ) : null}\n {spaceLinks?.length ? (\n <div className=\"space-links\">\n {spaceLinks.map((link, index) => (\n <NavLink\n key={index}\n url={link.url}\n activeIncludes={link.activeIncludes}\n render={({ active }) => (\n <WrappedLink\n key={index}\n className={classNames(\"link\", { active })}\n url={link.url}\n >\n <WrappedIcon className=\"icon\" {...link.icon} />\n <span className=\"title\">{link.title}</span>\n </WrappedLink>\n )}\n />\n ))}\n </div>\n ) : null}\n </div>\n </>\n );\n}\n","import React, {\n useEffect,\n useRef,\n useState,\n type MutableRefObject,\n type PropsWithChildren,\n} from \"react\";\nimport { throttle } from \"lodash\";\nimport classNames from \"classnames\";\nimport { WrappedIcon } from \"./bricks.js\";\n\nexport interface SectionTitleProps {\n rootRef: MutableRefObject<HTMLDivElement | null>;\n title: string;\n collapsed: boolean;\n onToggle: () => void;\n}\n\nexport function SectionTitle({\n rootRef,\n title,\n collapsed,\n children,\n onToggle,\n}: PropsWithChildren<SectionTitleProps>) {\n const ref = useRef<HTMLDivElement | null>(null);\n const [stickyActive, setStickyActive] = useState(false);\n\n useEffect(() => {\n if (collapsed) {\n setStickyActive(false);\n return;\n }\n const parent = rootRef.current;\n const element = ref.current;\n const sibling = element?.nextElementSibling as HTMLElement | null;\n if (!parent || !element || !sibling) {\n return;\n }\n const onScroll = throttle(() => {\n const rect = element.getBoundingClientRect();\n const siblingRect = sibling.getBoundingClientRect();\n const diff = siblingRect.top - rect.top - rect.height;\n setStickyActive(diff < 1);\n }, 100);\n parent.addEventListener(\"scroll\", onScroll);\n return () => {\n parent.removeEventListener(\"scroll\", onScroll);\n };\n }, [collapsed, rootRef]);\n\n return (\n <div\n className={classNames(\"section-title\", { sticky: stickyActive })}\n ref={ref}\n >\n <div className=\"section-label\" onClick={onToggle}>\n {title}\n <WrappedIcon lib=\"fa\" icon=\"angle-down\" />\n </div>\n {children}\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:block}:host([hidden]){display:none}*{box-sizing:border-box}.sidebar{position:relative;z-index:2;width:260px;height:100%;background:rgba(246,247,249,0.5);border:1px solid rgba(255,255,255,0.3);border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:23px 11px 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;margin-left:4px}.main{flex:1;min-height:0;display:flex;flex-direction:column}.divider{border-top:1px solid rgba(0,0,0,0.06);margin:16px 0}.logo-link::part(link){display:block}.logo{vertical-align:middle}.new-chat::part(link){display:flex;gap:0;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:16px}.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 -12px}.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:8px;left:8px;padding:6px 10px 6px 8px;display:flex;align-items:center;opacity:0;z-index:2;transition:opacity 0.2s ease-in-out;background:rgba(255,255,255,0);border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.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:270px;padding:10px 0 10px 10px;height:100%;transition:width 0.3s ease-in-out,padding 0.3s ease-in-out}.container.collapsed{width:0;padding:10px 0;overflow:visible}.container.collapsed .sidebar{transform:translateX(-100%)}.container.collapsed .alternative{opacity:1}:host([behavior=\"drawer\"]){z-index:2;width:0}:host(:not([behavior=\"drawer\"])) .alternative .new-chat{display:none}.mask{position:fixed;top:0;right:0;bottom:0;left:0}.link{display:block}.link + .link{margin-top:4px}.link::part(link){display:flex;gap:0;align-items:center;padding:7px 10px;border-radius:8px;color:#000}.link.active::part(link),.link::part(link):hover{background:rgba(0,0,0,0.04)}.link .icon{font-size:16px;margin-right:10px}.link .title{flex:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.history{flex:1;min-height:0;overflow-y:auto;margin:0 -12px;padding:0 12px}.history ul{list-style:none;margin:0;padding:0}.history .section + .section{margin-top:14px}.history .section-title{display:flex;align-items:center;justify-content:space-between;height:30px;margin-bottom:6px;padding:0 8px;position:sticky;top:0}.history .section-title.sticky::before{content:\"\";position:absolute;top:0;right:0;bottom:0;left:0;background-color:rgb(229,228,234);border-radius:8px;z-index:-1}.history .section-label{display:flex;align-items:center;height:24px;padding:0 8px;margin-left:-8px;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500;font-size:12px;color:#8c8c8c;border-radius:8px}.history .section-label eo-icon{vertical-align:middle;margin-left:6px;transition:transform 0.2s ease-in-out}.history .section-label:hover{background:rgba(0,0,0,0.04)}.history .collapsed > ul{display:none}.history .collapsed .section-label eo-icon{transform:rotate(-90deg)}.history .error,.history .loading{display:flex;align-items:center;height:36px;padding:0 8px}.history .loading{justify-content:center}.history .error{color:var(--color-error)}.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.actions-active::part(link),.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(.actions-active) .actions{display:none}.history .working{width:8px;height:8px;border-radius:8px;background:var(--elevo-color-brand);margin:0 7px}.history .item.actions-active .working,.history .item:hover .working,.history .item.active .working{display:none}.history .load-more{display:flex;justify-content:center;align-items:center;height:36px}.button{display:flex}.space-links{margin-top:16px}.return-link{display:block}.return-link .heading{display:flex;flex-direction:column;align-items:flex-start;gap:4px;flex:1;min-width:0}.return-link .title,.return-link .sub-title{width:100%;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.return-link .title{font-weight:500;font-size:14px}.return-link .sub-title{font-size:12px;color:rgba(0,0,0,0.45)}.return-link .icon{font-size:16px;color:#646a73}.return-link .avatar{background:#fff;border-radius:8px;border:1px solid rgba(0,0,0,0.1);width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:18px}.return-link::part(link){display:flex;align-items:center;justify-content:center;gap:10px;padding:6px 8px;border-radius:8px;color:#262626}.return-link::part(link):hover{background:rgba(0,0,0,0.04)}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\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\";\nimport type { IconButton, IconButtonProps } from \"../icon-button\";\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 & { themeVariant?: \"default\" | \"elevo\" },\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 & { themeVariant?: \"default\" | \"elevo\" },\n EoMiniActionsEvents,\n EoMiniActionsEventsMapping\n>(\"eo-mini-actions\", {\n onActionClick: \"action.click\",\n onVisibleChange: \"visible.change\",\n});\nexport const WrappedIconButton = wrapBrick<IconButton, IconButtonProps>(\n \"ai-portal.icon-button\"\n);\n","import { http } from \"@next-core/http\";\n/**\n * @description 获取elevo项目列表\n * @endpoint list /api/v1/elevo/projects\n */\nexport const ElevoApi_getElevoProjects = async (params, options) => /**! @contract easyops.api.llm.elevo.GetElevoProjects@1.0.0 */(await http.get(\"api/gateway/logic.llm.aiops_service/api/v1/elevo/projects\", {\n ...options,\n params\n})).data;\n//# sourceMappingURL=getElevoProjects.js.map","import { http } from \"@next-core/http\";\n/**\n * @description 获取elevo会话列表\n * @endpoint GET /api/v1/elevo/conversations\n */\nexport const ElevoApi_listElevoConversations = async (params, options) => /**! @contract easyops.api.llm.elevo.ListElevoConversations@1.0.0 */(await http.get(\"api/gateway/logic.llm.aiops_service/api/v1/elevo/conversations\", {\n ...options,\n params\n})).data;\n//# sourceMappingURL=listElevoConversations.js.map","import React, {\n forwardRef,\n useCallback,\n useEffect,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport classNames from \"classnames\";\nimport {\n ElevoApi_listElevoConversations,\n ElevoApi_getElevoProjects,\n type ElevoApi_ListElevoConversationsRequestParams,\n} from \"@next-api-sdk/llm-sdk\";\nimport type {\n ActionType,\n SimpleActionType,\n} from \"@next-bricks/basic/mini-actions\";\nimport { isEqual } from \"lodash\";\nimport { K, t } from \"./i18n.js\";\nimport {\n WrappedIcon,\n WrappedLink,\n WrappedMiniActions,\n WrappedIconButton,\n} from \"./bricks.js\";\nimport { DONE_STATES } from \"../shared/constants.js\";\nimport { parseTemplate } from \"../shared/parseTemplate.js\";\nimport type { ConversationState } from \"../shared/interfaces.js\";\nimport type { SidebarLink } from \"./interfaces.js\";\nimport { NavLink } from \"./NavLink.js\";\nimport { SectionTitle } from \"./SectionTitle.js\";\nimport { ADD_ICON } from \"./constants.js\";\n\nexport interface HistoryItem {\n conversationId: string;\n title: string;\n startTime: number;\n state?: ConversationState;\n}\n\nexport interface GroupedHistory {\n title: string;\n items: HistoryItem[];\n}\n\nexport interface ActionClickDetail {\n action: SimpleActionType & {\n project?: Project;\n };\n item: HistoryItem;\n project?: Project;\n}\n\nexport interface ProjectActionClickDetail {\n action: SimpleActionType;\n project: Project;\n}\n\nexport interface PersonalActionClickDetail {\n action: SimpleActionType;\n}\n\nexport interface Project {\n /** 实例ID */\n instanceId: string;\n /** 项目名称 */\n name: string;\n /** 项目描述 */\n description: string;\n /** 状态 */\n state: \"active\" | \"inactive\";\n /** 默认数字人ID */\n defaultAiEmployeeId: string;\n /** 创建者 */\n creator: string;\n /** 创建时间 */\n ctime: string;\n /** 修改时间 */\n mtime: string;\n /** 修改者 */\n modifier: string;\n}\n\nexport interface ChatHistoryProps {\n showProjects?: boolean;\n historyUrlTemplate?: string;\n historyActions?: ActionType[];\n projectUrlTemplate?: string;\n projectActions?: ActionType[];\n canAddProject?: boolean;\n myLinks?: SidebarLink[];\n onActionClick: (detail: ActionClickDetail) => void;\n onHistoryClick: () => void;\n onProjectActionClick: (detail: ProjectActionClickDetail) => void;\n onAddProject: () => void;\n}\n\nexport interface ChatHistoryRef {\n pull: () => void;\n removeProject?: (projectId: string) => void;\n addProject?: (project: Project) => void;\n moveConversation?: (conversationId: string) => void;\n}\n\nexport const ChatHistory = forwardRef(LowLevelChatHistory);\n\nexport function LowLevelChatHistory(\n {\n showProjects,\n historyActions,\n historyUrlTemplate,\n projectUrlTemplate,\n projectActions,\n canAddProject,\n myLinks,\n onActionClick,\n onHistoryClick,\n onProjectActionClick,\n onAddProject,\n }: ChatHistoryProps,\n ref: React.Ref<ChatHistoryRef>\n) {\n const rootRef = useRef<HTMLDivElement | null>(null);\n const [myCollapsed, setMyCollapsed] = useState(false);\n const [projects, setProjects] = useState<Project[] | null>(null);\n const [projectsCollapsed, setProjectsCollapsed] = useState(false);\n const [projectsError, setProjectsError] = useState(false);\n const [historyList, setHistoryList] = useState<HistoryItem[] | null>(null);\n const [historyCollapsed, setHistoryCollapsed] = useState(false);\n const [nextToken, setNextToken] = useState<string | undefined>();\n const [loadNextToken, setLoadNextToken] = useState<string | undefined>();\n const [historyError, setHistoryError] = useState(false);\n const initialRef = useRef(true);\n const [movedConversations, setMovedConversations] = useState<string[]>([]);\n\n const mergedHistoryActions = useMemo(\n () =>\n [\n ...(historyActions ?? []),\n {\n isDropdown: true,\n text: t(K.MOVE_TO_PROJECT),\n disabled: !projects?.length,\n items: projects?.map((project) => ({\n event: \"move\",\n key: project.instanceId,\n text: project.name,\n project,\n })),\n },\n ] as ActionType[],\n [historyActions, projects]\n );\n\n useEffect(() => {\n (async () => {\n try {\n const projects = await ElevoApi_getElevoProjects({\n page: 1,\n page_size: 3000,\n });\n setProjects(projects.list as Project[]);\n } catch (error) {\n // eslint-disable-next-line no-console\n console.error(\"Error loading projects:\", error);\n setProjectsError(true);\n setProjects([]);\n }\n })();\n }, []);\n\n useEffect(() => {\n Promise.all([\n ElevoApi_listElevoConversations(\n {\n token: loadNextToken,\n limit: 30,\n onlyOwner: true,\n onlyUnrelatedProject: true,\n } as ElevoApi_ListElevoConversationsRequestParams,\n {\n interceptorParams: {\n ignoreLoadingBar: true,\n },\n }\n ),\n ...(initialRef.current\n ? []\n : [\n new Promise((resolve) => setTimeout(resolve, 500)), // Force a minimum delay\n ]),\n ])\n .then(([data]) => {\n initialRef.current = false;\n setHistoryList((prev) => [\n ...(prev ?? []),\n ...(data.conversations as HistoryItem[]),\n ]);\n setNextToken(data.nextToken);\n })\n .catch((error) => {\n // eslint-disable-next-line no-console\n console.error(\"Error loading chat history:\", error);\n setHistoryList([]);\n setHistoryError(true);\n });\n }, [loadNextToken]);\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 || historyCollapsed) {\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, historyCollapsed]);\n\n const pullIdRef = useRef(0);\n\n const pull = useCallback(async () => {\n try {\n const pullId = ++pullIdRef.current;\n const tempList = await ElevoApi_listElevoConversations(\n {\n limit: 30,\n onlyOwner: true,\n onlyUnrelatedProject: true,\n } as ElevoApi_ListElevoConversationsRequestParams,\n {\n interceptorParams: {\n ignoreLoadingBar: true,\n },\n }\n );\n if (pullId !== pullIdRef.current) {\n // Ignore this pull if a newer one has been triggered\n return;\n }\n setHistoryList((prev) => {\n const prevList = prev ?? [];\n const newList = tempList.conversations as HistoryItem[];\n const newIds = new Set(newList.map((item) => item.conversationId));\n const newItemsMap = new Map(\n newList.map((item) => [item.conversationId, item])\n );\n\n let foundIntersection = false;\n let foundChanged = false;\n let isFirst = true;\n for (const item of prevList) {\n const newItem = newItemsMap.get(item.conversationId);\n if (newItem) {\n foundIntersection = true;\n foundChanged =\n (isFirst && newItem !== newList[0]) || !isEqual(newItem, item);\n if (foundChanged) {\n break;\n }\n } else {\n break;\n }\n isFirst = false;\n }\n\n if (!foundIntersection) {\n setNextToken(tempList.nextToken);\n return newList;\n }\n\n if (foundChanged) {\n return [\n ...newList,\n ...prevList.filter((item) => !newIds.has(item.conversationId)),\n ];\n }\n\n return prev;\n });\n } catch (error) {\n // eslint-disable-next-line no-console\n console.error(\"Error pulling chat history:\", error);\n }\n }, []);\n\n useImperativeHandle(\n ref,\n () => ({\n pull,\n removeProject: (projectId: string) => {\n setProjects((prev) =>\n prev ? prev.filter((p) => p.instanceId !== projectId) : prev\n );\n },\n addProject: (project: Project) => {\n setProjects((prev) => (prev ? [...prev, project] : [project]));\n },\n moveConversation: (conversationId: string) => {\n setMovedConversations((prev) => [...prev, conversationId]);\n },\n }),\n [pull]\n );\n\n const filteredHistoryList = useMemo(() => {\n if (!historyList || !historyList.length) {\n return historyList;\n }\n return historyList.filter(\n (item) => !movedConversations.includes(item.conversationId)\n );\n }, [historyList, movedConversations]);\n\n return (\n <div className=\"history\" ref={rootRef}>\n {myLinks?.length ? (\n <div className={classNames(\"section\", { collapsed: myCollapsed })}>\n <SectionTitle\n rootRef={rootRef}\n title={t(K.MY)}\n collapsed={myCollapsed}\n onToggle={() => setMyCollapsed((prev) => !prev)}\n />\n <ul className=\"items\">\n {myLinks.map((link, index) => (\n <li key={index}>\n <NavLink\n url={link.url}\n activeIncludes={link.activeIncludes}\n render={({ active }) => (\n <WrappedLink\n className={classNames(\"item\", { active })}\n url={link.url}\n >\n <div className=\"item-title\">{link.title}</div>\n </WrappedLink>\n )}\n />\n </li>\n ))}\n </ul>\n </div>\n ) : null}\n {showProjects && (\n <div\n className={classNames(\"section\", { collapsed: projectsCollapsed })}\n >\n <SectionTitle\n rootRef={rootRef}\n title={t(K.PROJECTS)}\n collapsed={projectsCollapsed}\n onToggle={() => setProjectsCollapsed((prev) => !prev)}\n >\n {canAddProject && (\n <WrappedIconButton\n icon={ADD_ICON}\n variant=\"mini-light\"\n tooltip={t(K.CREATE_PROJECT)}\n tooltipHoist={true}\n className=\"button\"\n onClick={onAddProject}\n />\n )}\n </SectionTitle>\n <ul className=\"items\">\n {projectsError ? (\n <li className=\"error\">Failed to load project</li>\n ) : projects ? (\n projects.map((project) => {\n const url = projectUrlTemplate\n ? parseTemplate(projectUrlTemplate, project)\n : undefined;\n return (\n <li key={project.instanceId}>\n <NavLink\n url={url}\n render={({ active }) => (\n <WrappedLink\n className={classNames(\"item\", {\n \"actions-active\":\n project.instanceId === actionsVisible,\n active,\n })}\n onClick={onHistoryClick}\n {...(url ? { url } : null)}\n >\n <div className=\"item-title\" title={project.name}>\n {project.name || t(K.UNNAMED)}\n </div>\n <WrappedMiniActions\n className=\"actions\"\n actions={projectActions}\n themeVariant=\"elevo\"\n onActionClick={(e) => {\n onProjectActionClick({\n action: e.detail,\n project,\n });\n }}\n onVisibleChange={(e) => {\n setActionsVisible(\n e.detail ? project.instanceId : null\n );\n }}\n />\n </WrappedLink>\n )}\n />\n </li>\n );\n })\n ) : (\n <li className=\"loading\">\n <WrappedIcon\n lib=\"antd\"\n theme=\"outlined\"\n icon=\"loading-3-quarters\"\n spinning\n />\n </li>\n )}\n </ul>\n </div>\n )}\n <div className={classNames(\"section\", { collapsed: historyCollapsed })}>\n <SectionTitle\n rootRef={rootRef}\n title={t(K.HISTORY)}\n collapsed={historyCollapsed}\n onToggle={() => setHistoryCollapsed((prev) => !prev)}\n />\n <ul className=\"items\">\n {filteredHistoryList ? (\n filteredHistoryList.map((item) => {\n const url = historyUrlTemplate\n ? parseTemplate(historyUrlTemplate, item)\n : undefined;\n return (\n <li key={item.conversationId}>\n <NavLink\n url={url}\n render={({ active }) => (\n <WrappedLink\n className={classNames(\"item\", {\n \"actions-active\":\n item.conversationId === actionsVisible,\n active,\n })}\n onClick={onHistoryClick}\n {...(historyUrlTemplate\n ? { url: parseTemplate(historyUrlTemplate, item) }\n : null)}\n >\n <div className=\"item-title\" title={item.title}>\n {item.title || t(K.UNTITLED)}\n </div>\n <WrappedMiniActions\n className=\"actions\"\n actions={mergedHistoryActions}\n onActionClick={(e) => {\n onActionClick({\n action: e.detail,\n item,\n project: (e.detail as { project?: Project })\n .project,\n });\n }}\n onVisibleChange={(e) => {\n setActionsVisible(\n e.detail ? item.conversationId : null\n );\n }}\n />\n {!DONE_STATES.includes(item.state!) && (\n <div className=\"working\"></div>\n )}\n </WrappedLink>\n )}\n />\n </li>\n );\n })\n ) : (\n <li className=\"loading\">\n <WrappedIcon\n lib=\"antd\"\n theme=\"outlined\"\n icon=\"loading-3-quarters\"\n spinning\n />\n </li>\n )}\n {historyError ? (\n <li className=\"error\">Failed to load chat history</li>\n ) : null}\n </ul>\n {!historyCollapsed && nextToken && (\n <div className=\"load-more\" ref={nextRef}>\n <WrappedIcon lib=\"antd\" icon=\"loading-3-quarters\" spinning />\n </div>\n )}\n </div>\n </div>\n );\n}\n","import { useEffect, useState } from \"react\";\nimport { getHistory, matchPath } from \"@next-core/runtime\";\nimport type { Location } from \"history\";\n\nexport function useNavLinkActive(\n url: string | null | undefined,\n activeIncludes?: string[]\n) {\n const [active, setActive] = useState(false);\n\n useEffect(() => {\n if (!url) {\n setActive(false);\n return;\n }\n function checkLinkActive(loc: Location) {\n for (const path of [url!, ...(activeIncludes ?? [])]) {\n const matched = matchPath(loc.pathname, { path, exact: false });\n if (matched) {\n setActive(true);\n return;\n }\n }\n setActive(false);\n }\n const history = getHistory();\n checkLinkActive(history.location);\n return history.listen(checkLinkActive);\n }, [url, activeIncludes]);\n\n return active;\n}\n","import React from \"react\";\nimport { useNavLinkActive } from \"./useNavLinkActive\";\n\nexport interface NavLinkProps {\n url?: string;\n activeIncludes?: string[];\n render: (props: { active: boolean }) => React.ReactElement;\n}\n\nexport function NavLink({ url, activeIncludes, render }: NavLinkProps) {\n const active = useNavLinkActive(url, activeIncludes);\n\n return render({ active });\n}\n"],"names":["K","en","NEW_CHAT","LOGOUT","TODAY","YESTERDAY","PREVIOUS_7_DAYS","PREVIOUS_30_DAYS","SWITCH_LANGUAGE","MY","PROJECTS","HISTORY","CREATE_PROJECT","MOVE_TO_PROJECT","UNTITLED","UNNAMED","BUSINESS_OBJECTS","SERVICEFLOWS","COLLABORATION_SPACES","CREATE_SERVICEFLOW","BUSINESS_OBJECT_MODELS","zh","NS","locales","t","i18n","getFixedT","ADD_ICON","lib","icon","MODEL_ICON","SpaceNav","_ref","returnUrl","introUrl","spaceDetail","spaceObjects","spaceServiceflows","spaceLinks","onAddServiceflow","rootRef","useRef","objectsCollapsed","setObjectsCollapsed","useState","serviceflowsCollapsed","setServiceflowsCollapsed","introActive","useNavLinkActive","avatarIcon","avatarColor","color","iconProps","React","WrappedLink","url","className","WrappedIcon","style","name","ref","classNames","collapsed","SectionTitle","title","onToggle","prev","WrappedIconButton","variant","tooltip","tooltipHoist","active","onClick","getHistory","push","map","obj","index","key","NavLink","activeIncludes","render","_ref2","_ref3","length","link","_ref4","_extends","children","stickyActive","setStickyActive","useEffect","parent","current","element","sibling","nextElementSibling","onScroll","throttle","rect","getBoundingClientRect","diff","top","height","addEventListener","removeEventListener","sticky","___CSS_LOADER_EXPORT___","module","id","toString","wrapBrick","WrappedDropdownActions","onActionClick","onVisibleChange","WrappedEasyopsAvatar","WrappedMiniActions","ElevoApi_listElevoConversations","async","params","options","http","get","data","ChatHistory","forwardRef","LowLevelChatHistory","showProjects","historyActions","historyUrlTemplate","projectUrlTemplate","projectActions","canAddProject","myLinks","onHistoryClick","onProjectActionClick","onAddProject","myCollapsed","setMyCollapsed","projects","setProjects","projectsCollapsed","setProjectsCollapsed","projectsError","setProjectsError","historyList","setHistoryList","historyCollapsed","setHistoryCollapsed","nextToken","setNextToken","loadNextToken","setLoadNextToken","historyError","setHistoryError","initialRef","movedConversations","setMovedConversations","mergedHistoryActions","useMemo","isDropdown","text","disabled","items","project","event","instanceId","page","page_size","ElevoApi_getElevoProjects","list","error","console","Promise","all","token","limit","onlyOwner","onlyUnrelatedProject","interceptorParams","ignoreLoadingBar","resolve","setTimeout","then","conversations","catch","actionsVisible","setActionsVisible","nextRef","next","root","observer","IntersectionObserver","entries","entry","isIntersecting","observe","disconnect","pullIdRef","pull","useCallback","pullId","tempList","prevList","newList","newIds","Set","item","conversationId","newItemsMap","Map","foundIntersection","foundChanged","isFirst","newItem","isEqual","filter","has","useImperativeHandle","removeProject","projectId","p","addProject","moveConversation","filteredHistoryList","includes","parseTemplate","undefined","actions","themeVariant","e","action","detail","theme","spinning","_ref5","DONE_STATES","state","setActive","checkLinkActive","loc","path","matchPath","pathname","exact","history","location","listen"],"sourceRoot":""}
@@ -1 +0,0 @@
1
- {"version":3,"file":"chunks/778.850294cf.js","mappings":"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","sources":["webpack:///./src/shared/getFlowOrActivityIcon.ts","webpack:///./src/shared/PlanProgress/PlanProgress.module.css","webpack:///./src/chat-stream/Aside/Aside.module.css?0aa1","webpack:///./src/chat-stream/Aside/FlowApp/FlowApp.module.css?5832","webpack:///./src/chat-stream/Aside/FlowApp/i18n.ts","webpack:///./src/chat-stream/Aside/FlowApp/FlowApp.tsx","webpack:///./src/chat-stream/Aside/Aside.tsx","webpack:///./src/chat-stream/styles.module.css?c00e","webpack:///./src/shared/PlanProgress/PlanProgress.module.css?ebff","webpack:///./src/shared/PlanProgress/i18n.ts","webpack:///./src/shared/PlanProgress/PlanProgress.tsx","webpack:///./src/chat-stream/ChatStream.tsx","webpack:///./src/shared/useServiceFlowPlan.ts","webpack:///./src/chat-stream/styles.module.css","webpack:///./src/chat-stream/Aside/Aside.module.css","webpack:///./src/chat-stream/Aside/FlowApp/FlowApp.module.css"],"sourcesContent":["import type { GeneralIconProps } from \"@next-bricks/icons/general-icon\";\nimport type { ConversationState, JobState, TaskState } from \"./interfaces\";\n\nexport function getFlowOrActivityIcon(\n state: TaskState | JobState | ConversationState | undefined\n): GeneralIconProps {\n switch (state) {\n case \"input-required\":\n return { lib: \"antd\", theme: \"filled\", icon: \"pause-circle\" };\n case \"completed\":\n return { lib: \"antd\", theme: \"filled\", icon: \"check-circle\" };\n case \"failed\":\n return { lib: \"antd\", theme: \"filled\", icon: \"close-circle\" };\n case \"terminated\":\n return { lib: \"antd\", theme: \"filled\", icon: \"stop\" };\n case \"working\":\n return { lib: \"antd\", icon: \"loading-3-quarters\", spinning: true };\n default:\n return { lib: \"antd\", theme: \"filled\", icon: \"clock-circle\" };\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, `.progress--lx8TY1CA{margin-bottom:10px;position:relative}.bar--ApxcfDGj,\n.details--YLrChHBK{background:rgba(255,255,255,0.6);border:1px solid rgba(255,255,255,0.6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.bar--ApxcfDGj{cursor:pointer;display:flex;align-items:center;height:32px;box-shadow:0px 2px 6px 0px rgba(0,0,0,0.04);border-radius:16px;font-size:12px;padding:0 14px}.icon--tQcIUG1N{margin-right:6px;width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;background:linear-gradient(222deg,#abaab7 25%,#fff 75%);color:#4e4d56;font-size:10px;text-shadow:0px 1px 1px #fff}.progress--lx8TY1CA.completed--CRSVMXSS .icon--tQcIUG1N{background:linear-gradient(222deg,#16c661 25%,#fff 75%);color:#055527}.progress--lx8TY1CA.failed--uYq638ML .icon--tQcIUG1N{background:linear-gradient(222deg,#f24c25 25%,#fff 75%);color:#5b1504}.progress--lx8TY1CA.working--vSiJEm6I .icon--tQcIUG1N{background:linear-gradient(222deg,#3e56ff 25%,#fff 75%);color:#0c165d}.progress--lx8TY1CA.input-required--fub8PAf3 .icon--tQcIUG1N{background:linear-gradient(222deg,#12aacc 25%,#fff 75%);color:#0c353e}.progress--lx8TY1CA.canceled--Ew8Xed4m .icon--tQcIUG1N{background:linear-gradient(222deg,#fcaa07 25%,#fff 75%);color:#302206}.text--xtCVQl6G,\n.name--GCO4oNl4{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;min-width:0;flex:1}.stat--vXcz2KIB{margin-left:6px}.expand--euAPifdF{margin-left:6px}.stat--vXcz2KIB,\n.expand--euAPifdF{color:rgba(0,0,0,0.45)}.details--YLrChHBK{position:absolute;left:0;right:0;bottom:40px;box-shadow:0px 3px 6px -4px rgba(0,0,0,0.12);border-radius:12px;list-style:none;margin:0;padding:20px;cursor:auto}.step--WdWDE_I7{--state-color:initial;display:flex;align-items:center;color:var(--state-color,var(--text-color-secondary))}.name--GCO4oNl4{color:var(--state-color,#262626)}.step--WdWDE_I7:not(:last-child){margin-bottom:16px}.step--WdWDE_I7.completed--CRSVMXSS{--state-color:var(--color-success)}.step--WdWDE_I7.failed--uYq638ML{--state-color:var(--color-error)}.step--WdWDE_I7.working--vSiJEm6I{--state-color:var(--color-info)}.step--WdWDE_I7.input-required--fub8PAf3{--state-color:var(--palette-cyan-7)}.step--WdWDE_I7.canceled--Ew8Xed4m{--state-color:#fcaa07}.state--Flb6ddfB{margin-right:10px}.mask--nL2DoW2Q{position:fixed;top:0;right:0;bottom:0;left:0}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"progress\": `progress--lx8TY1CA`,\n\t\"bar\": `bar--ApxcfDGj`,\n\t\"details\": `details--YLrChHBK`,\n\t\"icon\": `icon--tQcIUG1N`,\n\t\"completed\": `completed--CRSVMXSS`,\n\t\"failed\": `failed--uYq638ML`,\n\t\"working\": `working--vSiJEm6I`,\n\t\"input-required\": `input-required--fub8PAf3`,\n\t\"canceled\": `canceled--Ew8Xed4m`,\n\t\"text\": `text--xtCVQl6G`,\n\t\"name\": `name--GCO4oNl4`,\n\t\"stat\": `stat--vXcz2KIB`,\n\t\"expand\": `expand--euAPifdF`,\n\t\"step\": `step--WdWDE_I7`,\n\t\"state\": `state--Flb6ddfB`,\n\t\"mask\": `mask--nL2DoW2Q`\n};\nexport default ___CSS_LOADER_EXPORT___;\n","\n import API from \"!../../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./Aside.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./Aside.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","\n import API from \"!../../../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./FlowApp.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./FlowApp.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","import { i18n } from \"@next-core/i18n\";\n\nexport enum K {\n WAITING = \"WAITING\",\n EXECUTING = \"EXECUTING\",\n PAUSED = \"PAUSED\",\n SUCCEEDED = \"SUCCEEDED\",\n FAILED = \"FAILED\",\n TERMINATED = \"TERMINATED\",\n}\n\nconst en: Locale = {\n WAITING: \"Waiting\",\n EXECUTING: \"Executing\",\n PAUSED: \"Paused\",\n SUCCEEDED: \"Succeeded\",\n FAILED: \"Failed\",\n TERMINATED: \"Terminated\",\n};\n\nconst zh: Locale = {\n WAITING: \"等待中\",\n EXECUTING: \"执行中\",\n PAUSED: \"暂停\",\n SUCCEEDED: \"成功\",\n FAILED: \"失败\",\n TERMINATED: \"已终止\",\n};\n\nexport const NS = \"bricks/ai-portal/FlowApp\";\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, { useContext, useMemo, useRef } from \"react\";\nimport { initializeI18n } from \"@next-core/i18n\";\nimport classNames from \"classnames\";\nimport styles from \"./FlowApp.module.css\";\nimport {\n WrappedBlankState,\n WrappedIcon,\n WrappedRunningFlow,\n} from \"../../../shared/bricks\";\nimport { getFlowOrActivityIcon } from \"../../../shared/getFlowOrActivityIcon\";\nimport type {\n ActivityRun,\n ConversationState,\n JobState,\n ServiceFlowRun,\n TaskState,\n} from \"../../../shared/interfaces\";\nimport { TaskContext } from \"../../../shared/TaskContext\";\nimport { K, locales, NS, t } from \"./i18n\";\nimport { useConversationStream } from \"../../useConversationStream\";\nimport { UserMessage } from \"../../UserMessage/UserMessage\";\nimport { AssistantMessage } from \"../../AssistantMessage/AssistantMessage\";\nimport { useAutoScroll } from \"../../useAutoScroll\";\nimport scrollStyles from \"../../ScrollDownButton.module.css\";\nimport floatingStyles from \"../../../shared/FloatingButton.module.css\";\n\ninitializeI18n(NS, locales);\n\nexport interface FlowAppProps {\n flow: ServiceFlowRun;\n activity?: ActivityRun;\n}\n\nexport function FlowApp({ flow, activity }: FlowAppProps) {\n const { tasks, setActiveDetail } = useContext(TaskContext);\n const flowTask = useMemo(() => {\n return tasks.find((t) => t.id === flow.taskId)!;\n }, [tasks, flow.taskId]);\n\n const runningSpec = useMemo(() => {\n return flow.spec.map((stage) => ({\n ...stage,\n serviceFlowActivities: stage.serviceFlowActivities?.map((activity) => {\n const task = tasks.find((t) => t.id === activity.taskId);\n return {\n name: activity.name,\n taskId: activity.taskId,\n state: task?.state,\n startTime: task?.startTime,\n endTime: task?.endTime,\n };\n }),\n }));\n }, [flow.spec, tasks]);\n\n const flowStatus = useMemo(\n () => getFlowStatusDisplay(flowTask.state),\n [flowTask.state]\n );\n\n return (\n <div className={styles.app}>\n <div className={styles.heading}>\n <div className={styles.header}>\n <div className={classNames(styles.status, flowStatus.className)}>\n <WrappedIcon {...flowStatus.icon} />\n {flowStatus.text}\n </div>\n <div className={styles.title}>\n {`${flow.space?.name ? `${flow.space.name} / ` : \"\"}${flow.name}`}\n </div>\n </div>\n <div className={styles.chart}>\n <WrappedRunningFlow\n spec={runningSpec}\n activeActivityId={activity?.taskId}\n onActiveChange={(e) => {\n if (e.detail) {\n setActiveDetail({ type: \"activity\", id: e.detail });\n }\n }}\n />\n </div>\n </div>\n <div className={styles.body}>\n {activity ? (\n <ActivityDetail activity={activity} />\n ) : (\n <WrappedBlankState\n className={styles.blank}\n description=\"您还未选择活动\"\n illustration=\"serviceflows\"\n />\n )}\n </div>\n </div>\n );\n}\n\ninterface ActivityDetailProps {\n activity: ActivityRun;\n}\n\nfunction ActivityDetail({ activity }: ActivityDetailProps) {\n const { tasks, errors } = useContext(TaskContext);\n const activityTask = useMemo(() => {\n return tasks.find((t) => t.id === activity.taskId)!;\n }, [tasks, activity.taskId]);\n const activityState = activityTask.state;\n\n const { icon, className } = useMemo(\n () => getFlowStatusDisplay(activityState),\n [activityState]\n );\n\n const fixedTasks = useMemo(() => {\n return [\n {\n ...activityTask,\n parent: undefined,\n },\n ];\n }, [activityTask]);\n\n const { messages } = useConversationStream(\n true,\n activityTask.state,\n fixedTasks,\n errors\n );\n\n const scrollContainerRef = useRef<HTMLDivElement>(null);\n const scrollContentRef = useRef<HTMLDivElement>(null);\n\n const { scrollable, scrollToBottom } = useAutoScroll(\n true,\n scrollContainerRef,\n scrollContentRef\n );\n\n return (\n <>\n <div className={styles[\"activity-title\"]}>\n <WrappedIcon {...icon} className={className} />\n {activity.name}\n </div>\n <div className={styles.chat} ref={scrollContainerRef}>\n <div className={styles.messages} ref={scrollContentRef}>\n {messages.map((msg, index, list) => (\n <div className={styles.message} key={index}>\n {msg.role === \"user\" ? (\n <UserMessage\n content={msg.content}\n mentionedAiEmployeeId={msg.mentionedAiEmployeeId}\n cmd={msg.cmd}\n files={msg.files}\n />\n ) : (\n <AssistantMessage\n chunks={msg.chunks}\n scopeState={activityTask.state}\n isLatest={index === list.length - 1}\n isSubTask\n />\n )}\n </div>\n ))}\n </div>\n </div>\n <button\n className={`${scrollStyles[\"scroll-down\"]} ${floatingStyles[\"floating-button\"]}`}\n style={{ bottom: \"30px\" }}\n hidden={!scrollable}\n onClick={scrollToBottom}\n >\n <WrappedIcon lib=\"antd\" icon=\"down\" />\n </button>\n </>\n );\n}\n\nfunction getFlowStatusDisplay(state: TaskState | JobState | ConversationState) {\n const icon = getFlowOrActivityIcon(state);\n let text: string;\n let className: string | undefined;\n\n switch (state) {\n case \"working\":\n text = t(K.EXECUTING);\n className = styles.working;\n break;\n case \"completed\":\n text = t(K.SUCCEEDED);\n className = styles.completed;\n break;\n case \"failed\":\n text = t(K.FAILED);\n className = styles.failed;\n break;\n case \"input-required\":\n text = t(K.PAUSED);\n className = styles.paused;\n break;\n case \"terminated\":\n text = t(K.TERMINATED);\n break;\n default:\n text = state ? t(K.EXECUTING) : t(K.WAITING);\n }\n\n return { icon, text, className };\n}\n","import React, { useContext } from \"react\";\nimport classNames from \"classnames\";\nimport type { GeneralIconProps } from \"@next-bricks/icons/general-icon\";\nimport styles from \"./Aside.module.css\";\nimport sharedStyles from \"../../cruise-canvas/shared.module.css\";\nimport { WrappedCodeBlock, WrappedIconButton } from \"../../shared/bricks\";\nimport { ToolCallStatus } from \"../../cruise-canvas/ToolCallStatus/ToolCallStatus\";\nimport { TaskContext } from \"../../shared/TaskContext\";\nimport { StreamContext } from \"../StreamContext\";\nimport type {\n ActiveDetailOfActivity,\n FulfilledActiveDetail,\n} from \"../../shared/interfaces\";\nimport { FlowApp } from \"./FlowApp/FlowApp\";\nimport { ToolCallDetail } from \"../../cruise-canvas/ToolCallDetail/ToolCallDetail\";\n\nconst ICON_SHRINK: GeneralIconProps = {\n lib: \"easyops\",\n icon: \"shrink\",\n};\n\nexport interface AsideProps {\n detail: FulfilledActiveDetail;\n isSubTask?: boolean;\n faded?: boolean;\n}\n\nexport function Aside({ detail, isSubTask, faded }: AsideProps) {\n const { setActiveDetail, setSubActiveDetail } = useContext(TaskContext);\n const { setUserClosedAside } = useContext(StreamContext);\n\n return (\n <div\n className={classNames(styles.aside, {\n [styles.sub]: isSubTask,\n [styles.faded]: faded,\n })}\n >\n <div className={styles.box}>\n <div className={styles.header}>\n <div className={styles.title}>Elevo&#39;s Computer</div>\n <WrappedIconButton\n icon={ICON_SHRINK}\n variant=\"mini\"\n onClick={() => {\n if (isSubTask) {\n setSubActiveDetail(null);\n } else {\n setActiveDetail(null);\n setUserClosedAside(true);\n }\n }}\n />\n </div>\n <div\n className={classNames(styles.body, {\n [styles.scrollable]:\n detail.type === \"job\" && !detail.job.generatedView,\n })}\n >\n {detail.type === \"job\" ? (\n <>\n <ToolCallStatus job={detail.job} variant=\"read-only\" />\n {detail.job.generatedView ? (\n <EditorApp\n name=\"View\"\n source={detail.job.generatedView.code}\n language=\"jsx\"\n />\n ) : (\n <ToolCallDetail job={detail.job} />\n )}\n </>\n ) : (\n <FlowApp\n flow={detail.flow}\n activity={(detail as ActiveDetailOfActivity).activity}\n />\n )}\n </div>\n </div>\n </div>\n );\n}\n\ninterface EditorAppProps {\n name: string;\n source: string;\n language: string;\n}\n\nfunction EditorApp({ name, source, language }: EditorAppProps) {\n return (\n <div className={classNames(styles.app, styles.editor)}>\n <div className={styles.heading}>{`${name}.${language}`}</div>\n <div className={classNames(styles.content, sharedStyles.markdown)}>\n <div className={styles.scroller}>\n <WrappedCodeBlock\n className={styles[\"code-block\"]}\n source={source}\n language={language}\n themeVariant=\"elevo\"\n />\n </div>\n </div>\n </div>\n );\n}\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./styles.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./styles.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","\n import API from \"!../../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./PlanProgress.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./PlanProgress.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","import { i18n } from \"@next-core/i18n\";\n\nexport enum K {\n PLAN_COMPLETED = \"PLAN_COMPLETED\",\n}\n\nconst en: Locale = {\n PLAN_COMPLETED: \"All tasks are completed\",\n};\n\nconst zh: Locale = {\n PLAN_COMPLETED: \"所有任务已全部完成\",\n};\n\nexport const NS = \"bricks/ai-portal/PlanProgress\";\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, { useCallback, useMemo, useState } from \"react\";\nimport classNames from \"classnames\";\nimport { initializeI18n } from \"@next-core/i18n\";\nimport styles from \"./PlanProgress.module.css\";\nimport type {\n ConversationState,\n JobState,\n PlanProgressStep,\n TaskState,\n} from \"../interfaces\";\nimport { WrappedIcon } from \"../../shared/bricks\";\nimport { K, locales, NS, t } from \"./i18n\";\n\ninitializeI18n(NS, locales);\n\nexport interface PlanProgressProps {\n plan: PlanProgressStep[];\n conversationState?: ConversationState;\n style?: React.CSSProperties;\n}\n\ninterface PlanProgressStat {\n doneCount: number;\n name: string;\n // `state` is undefined when it is not started.\n state: TaskState | undefined;\n}\n\nexport function PlanProgress({\n plan,\n conversationState,\n style,\n}: PlanProgressProps): JSX.Element | null {\n const [expanded, setExpanded] = useState(false);\n\n const { doneCount, state, name } = useMemo(() => {\n return plan.reduce<PlanProgressStat>(\n (acc, step) => {\n if (step.state === \"completed\") {\n return {\n ...acc,\n state: step.state,\n name: step.name,\n doneCount: acc.doneCount + 1,\n };\n } else if (!acc.name || step.state) {\n return {\n ...acc,\n state: step.state,\n name: step.name,\n };\n }\n return acc;\n },\n {\n doneCount: 0,\n name: \"\",\n state: undefined,\n }\n );\n }, [plan]);\n\n const { className, icon } = useMemo(() => {\n return getClassNameAndIconProps(state, conversationState);\n }, [state, conversationState]);\n\n const toggle = useCallback(() => {\n setExpanded((prev) => !prev);\n }, []);\n\n if (!plan?.length) {\n return null;\n }\n\n const allDone =\n doneCount === plan.length && conversationState === \"completed\";\n\n return (\n <>\n {expanded && <div className={styles.mask} onClick={toggle} />}\n <div className={classNames(styles.progress, className)} style={style}>\n <div className={styles.bar} onClick={toggle}>\n <div className={styles.icon}>\n <WrappedIcon {...icon} />\n </div>\n <span className={styles.text} title={allDone ? \"\" : name}>\n {allDone ? t(K.PLAN_COMPLETED) : name}\n </span>\n <span className={styles.stat}>\n {doneCount}/{plan.length}\n </span>\n <WrappedIcon\n className={styles.expand}\n lib=\"antd\"\n theme=\"outlined\"\n icon={expanded ? \"down\" : \"up\"}\n />\n </div>\n {expanded && (\n <ul className={styles.details}>\n {plan.map((step, index) => (\n <PlanProgressStep\n key={index}\n state={step.state}\n conversationState={conversationState}\n name={step.name}\n />\n ))}\n </ul>\n )}\n </div>\n </>\n );\n}\n\ninterface PlanStepProps {\n state?: TaskState;\n conversationState?: ConversationState;\n name: string;\n}\n\nfunction PlanProgressStep({ state, conversationState, name }: PlanStepProps) {\n const { className, icon } = useMemo(() => {\n return getClassNameAndIconProps(state, conversationState);\n }, [state, conversationState]);\n\n return (\n <li className={classNames(styles.step, className)}>\n <WrappedIcon {...icon} className={styles.state} />\n <span className={styles.name} title={name}>\n {name}\n </span>\n </li>\n );\n}\n\nfunction getClassNameAndIconProps(\n state: JobState | TaskState | ConversationState | undefined,\n conversationState?: JobState | TaskState | ConversationState\n) {\n switch (state) {\n case \"completed\":\n return {\n className: styles.completed,\n icon: {\n lib: \"fa\",\n prefix: \"fas\",\n icon: \"check\",\n },\n };\n case \"submitted\":\n case \"working\":\n if (conversationState === \"terminated\") {\n return {\n className: undefined,\n icon: {\n lib: \"fa\",\n prefix: \"far\",\n icon: \"circle-stop\",\n },\n };\n }\n return {\n className: styles.working,\n icon: {\n lib: \"antd\",\n theme: \"outlined\",\n icon: \"loading-3-quarters\",\n spinning: true,\n },\n };\n case \"input-required\":\n return {\n className: styles[\"input-required\"],\n icon: {\n lib: \"fa\",\n prefix: \"far\",\n icon: \"circle-user\",\n },\n };\n case \"failed\":\n return {\n className: styles.failed,\n icon: {\n lib: \"fa\",\n prefix: \"fas\",\n icon: \"xmark\",\n },\n };\n case \"canceled\":\n return {\n className: styles.canceled,\n icon: {\n lib: \"fa\",\n prefix: \"far\",\n icon: \"circle-stop\",\n },\n };\n default:\n return {\n icon: {\n lib: \"fa\",\n prefix: \"far\",\n icon: \"clock\",\n },\n };\n }\n}\n","// istanbul ignore file: experimental\nimport React, {\n useCallback,\n useEffect,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { getBasePath, getRuntime } from \"@next-core/runtime\";\nimport classNames from \"classnames\";\nimport { preloadHighlighter } from \"@next-shared/markdown\";\nimport { useConversationDetail } from \"../cruise-canvas/useConversationDetail.js\";\nimport { useConversationStream } from \"./useConversationStream.js\";\nimport { WrappedIcon, WrappedIconButton } from \"../shared/bricks.js\";\nimport { UserMessage } from \"./UserMessage/UserMessage.js\";\nimport { AssistantMessage } from \"./AssistantMessage/AssistantMessage.js\";\nimport { TaskContext } from \"../shared/TaskContext.js\";\nimport { ChatBox } from \"../shared/ChatBox/ChatBox.js\";\nimport {\n DONE_STATES,\n ICON_CANVAS,\n NON_WORKING_STATES,\n} from \"../shared/constants.js\";\nimport { ExpandedView } from \"../shared/ExpandedView/ExpandedView.js\";\nimport { Aside } from \"./Aside/Aside.js\";\nimport { StreamContext } from \"./StreamContext.js\";\nimport type { FeedbackDetail } from \"../cruise-canvas/interfaces.js\";\nimport { NodeFeedback } from \"../shared/NodeFeedback/NodeFeedback.js\";\nimport type { ChatStreamProps, ChatStreamRef, ConversationDetail } from \".\";\nimport styles from \"./styles.module.css\";\nimport toolbarStyles from \"../cruise-canvas/toolbar.module.css\";\nimport { K, t } from \"./i18n.js\";\nimport { NodeReplay } from \"../cruise-canvas/NodeReplay/NodeReplay.js\";\nimport type {\n ActiveDetail,\n ActiveImages,\n ExtraChatPayload,\n FileInfo,\n} from \"../shared/interfaces.js\";\nimport { useFlowAndActivityMap } from \"../shared/useFlowAndActivityMap.js\";\nimport { useFulfilledActiveDetail } from \"../shared/useFulfilledActiveDetail.js\";\nimport { useAutoScroll } from \"./useAutoScroll.js\";\nimport scrollStyles from \"./ScrollDownButton.module.css\";\nimport floatingStyles from \"../shared/FloatingButton.module.css\";\nimport { PlanProgress } from \"../shared/PlanProgress/PlanProgress.js\";\nimport { useServiceFlowPlan } from \"../shared/useServiceFlowPlan.js\";\nimport { FilePreview } from \"../shared/FilePreview/FilePreview.js\";\nimport { ImagesPreview } from \"../shared/FilePreview/ImagesPreview.js\";\nimport { useHandleEscape } from \"../shared/useHandleEscape.js\";\n\ninterface ChatStreamComponentProps extends ChatStreamProps {\n conversationId: string;\n onShare: () => void;\n onTerminate: () => void;\n onSubmitFeedback: (detail: FeedbackDetail) => void;\n onSwitchToCanvas: () => void;\n onFeedbackOnView: (viewId: string) => void;\n onDetailChange: (detail: ConversationDetail) => void;\n onSplitChange: (split: boolean) => void;\n}\n\nexport function ChatStreamComponent(\n {\n conversationId,\n initialRequest,\n replay,\n replayDelay,\n supports,\n showHumanActions,\n showFeedback: propShowFeedback,\n showFeedbackAfterFailed,\n showFeedbackOnView,\n showUiSwitch,\n previewUrlTemplate,\n showCases,\n exampleProjects,\n tryItOutUrl,\n aiEmployees,\n commands,\n uploadOptions,\n onShare,\n onTerminate,\n onSubmitFeedback,\n onSwitchToCanvas,\n onFeedbackOnView,\n onDetailChange,\n onSplitChange,\n }: ChatStreamComponentProps,\n ref: React.Ref<ChatStreamRef>\n) {\n const {\n conversation,\n tasks,\n serviceFlows,\n errors,\n humanInputRef,\n skipToResults,\n watchAgain,\n } = useConversationDetail(\n conversationId,\n initialRequest,\n replay,\n replayDelay\n );\n const conversationAvailable = !!conversation;\n const pageTitle = conversation?.title ?? \"\";\n const conversationState = conversation?.state;\n const conversationDone = DONE_STATES.includes(conversationState!);\n const canChat = conversationDone || conversationState === \"input-required\";\n const plan = useServiceFlowPlan(serviceFlows, tasks);\n const { flowMap, activityMap } = useFlowAndActivityMap(serviceFlows);\n const { messages, jobMap, lastDetail } = useConversationStream(\n conversationAvailable,\n conversation?.state,\n tasks,\n errors,\n flowMap,\n activityMap,\n { showHumanActions, skipActivitySubTasks: true }\n );\n\n useEffect(() => {\n onDetailChange({\n projectId: conversation?.projectId,\n });\n }, [onDetailChange, conversation?.projectId]);\n\n const views = useMemo(() => {\n if (!jobMap) {\n return [];\n }\n return [...jobMap.values()].flatMap((job) =>\n job.generatedView\n ? {\n id: job.id,\n view: job.generatedView,\n }\n : []\n );\n }, [jobMap]);\n\n const [submittingFeedback, setSubmittingFeedback] = useState(false);\n const [submittedFeedback, setSubmittedFeedback] = useState(false);\n const [showFeedback, setShowFeedback] = useState<boolean>(!!propShowFeedback);\n useEffect(() => {\n setShowFeedback(!!propShowFeedback);\n }, [propShowFeedback]);\n const [feedbackDoneViews, setFeedbackDoneViews] = useState<\n Set<string> | undefined\n >();\n\n const handleSubmitFeedback = useCallback(\n (detail: FeedbackDetail) => {\n setSubmittingFeedback(true);\n onSubmitFeedback(detail);\n },\n [onSubmitFeedback]\n );\n\n useImperativeHandle(\n ref,\n () => ({\n feedbackSubmitDone: () => {\n setSubmittedFeedback(true);\n setTimeout(() => {\n setShowFeedback(false);\n }, 3000);\n },\n feedbackSubmitFailed: () => {\n setSubmittingFeedback(false);\n },\n feedbackOnViewDone: (viewId: string) => {\n setFeedbackDoneViews((prev) => {\n const newSet = new Set(prev);\n newSet.add(viewId);\n return newSet;\n });\n },\n }),\n []\n );\n\n const [activeExpandedViewJobId, setActiveExpandedViewJobId] = useState<\n string | null\n >(null);\n\n const [activeDetail, setActiveDetail] = useState<ActiveDetail | null>(null);\n const [subActiveDetail, setSubActiveDetail] = useState<ActiveDetail | null>(\n null\n );\n const [userClosedAside, setUserClosedAside] = useState(false);\n\n // Delay flag to prevent the aside from being auto-opened for a completed task\n const delayRef = useRef(false);\n useEffect(() => {\n if (conversationAvailable) {\n const timer = setTimeout(() => {\n delayRef.current = true;\n }, 1000);\n return () => {\n clearTimeout(timer);\n };\n }\n }, [conversationAvailable]);\n\n const hasInitialRequest = !!initialRequest;\n useEffect(() => {\n if (\n (delayRef.current || hasInitialRequest) &&\n lastDetail &&\n !userClosedAside\n ) {\n setActiveDetail(lastDetail);\n }\n }, [lastDetail, userClosedAside, hasInitialRequest]);\n\n useEffect(() => {\n getRuntime().applyPageTitle(pageTitle);\n }, [pageTitle]);\n\n const humanInput = useCallback(\n (input: string | null, action?: string, extra?: ExtraChatPayload) => {\n humanInputRef.current?.(input, action, extra);\n },\n [humanInputRef]\n );\n\n const firstMessage = messages[0];\n const userMessage = firstMessage?.role === \"user\" ? firstMessage : null;\n\n const [activeFile, setActiveFile] = useState<FileInfo | null>(null);\n const [activeImages, setActiveImages] = useState<ActiveImages | null>(null);\n\n const workspace = conversationId;\n const taskContextValue = useMemo(\n () => ({\n conversationId,\n conversationState,\n tasks,\n errors,\n workspace,\n previewUrlTemplate,\n replay,\n showCases,\n exampleProjects,\n aiEmployees,\n commands,\n uploadOptions,\n\n humanInput,\n onShare,\n onTerminate,\n supports,\n\n activeExpandedViewJobId,\n setActiveExpandedViewJobId,\n activeDetail,\n setActiveDetail,\n subActiveDetail,\n setSubActiveDetail,\n\n submittingFeedback,\n submittedFeedback,\n onSubmitFeedback: handleSubmitFeedback,\n setShowFeedback,\n showFeedbackOnView,\n onFeedbackOnView,\n feedbackDoneViews,\n\n skipToResults,\n watchAgain,\n tryItOut() {\n const win = window.open(\n `${getBasePath().slice(0, -1)}${tryItOutUrl ?? \"/elevo\"}`,\n \"_blank\"\n );\n if (win) {\n win.__elevo_try_it_out = userMessage\n ? {\n content: userMessage.content,\n cmd: userMessage.cmd,\n mentionedAiEmployeeId: userMessage.mentionedAiEmployeeId,\n }\n : {};\n }\n },\n activeFile,\n setActiveFile,\n activeImages,\n setActiveImages,\n }),\n [\n conversationId,\n conversationState,\n tasks,\n errors,\n workspace,\n previewUrlTemplate,\n replay,\n showCases,\n exampleProjects,\n aiEmployees,\n commands,\n uploadOptions,\n\n humanInput,\n onShare,\n onTerminate,\n supports,\n\n activeExpandedViewJobId,\n activeDetail,\n subActiveDetail,\n\n submittingFeedback,\n submittedFeedback,\n handleSubmitFeedback,\n showFeedbackOnView,\n onFeedbackOnView,\n feedbackDoneViews,\n\n skipToResults,\n watchAgain,\n userMessage,\n tryItOutUrl,\n activeFile,\n activeImages,\n ]\n );\n\n const streamContextValue = useMemo(\n () => ({\n lastDetail,\n setUserClosedAside,\n }),\n [lastDetail]\n );\n\n const [depsReady, setDepsReady] = useState(false);\n useEffect(() => {\n let ignore = false;\n Promise.race([\n preloadHighlighter(\"light-plus\"),\n // Wait at most 5s\n new Promise((resolve) => setTimeout(resolve, 5000)),\n ]).finally(() => {\n if (!ignore) {\n setDepsReady(true);\n }\n });\n return () => {\n ignore = true;\n };\n }, []);\n\n const scrollContainerRef = useRef<HTMLDivElement>(null);\n const scrollContentRef = useRef<HTMLDivElement>(null);\n\n const { scrollable, scrollToBottom } = useAutoScroll(\n conversationAvailable && depsReady,\n scrollContainerRef,\n scrollContentRef\n );\n\n const fulfilledActiveDetail = useFulfilledActiveDetail(\n activeDetail,\n jobMap,\n flowMap,\n activityMap\n );\n\n const fulfilledSubActiveDetail = useFulfilledActiveDetail(\n subActiveDetail,\n jobMap,\n flowMap,\n activityMap\n );\n\n useHandleEscape(taskContextValue);\n\n const split = !!(activeDetail || subActiveDetail);\n useEffect(() => {\n onSplitChange(split);\n }, [onSplitChange, split]);\n\n useEffect(() => {\n scrollContainerRef.current?.focus();\n }, [conversationAvailable, depsReady]);\n\n const earlyFinished =\n !replay &&\n conversation?.finished &&\n !NON_WORKING_STATES.includes(conversationState!);\n\n return (\n <TaskContext.Provider value={taskContextValue}>\n <StreamContext.Provider value={streamContextValue}>\n <div className={styles.container}>\n <div className={styles.header}>\n <h1>{pageTitle}</h1>\n </div>\n {conversationAvailable && depsReady ? (\n <>\n <div\n className={styles.main}\n tabIndex={-1}\n ref={scrollContainerRef}\n >\n <div className={styles.narrow} ref={scrollContentRef}>\n {messages.map((msg, index, list) => (\n <div className={styles.message} key={index}>\n {msg.role === \"user\" ? (\n <UserMessage\n content={msg.content}\n cmd={msg.cmd}\n mentionedAiEmployeeId={msg.mentionedAiEmployeeId}\n files={msg.files}\n />\n ) : (\n <AssistantMessage\n chunks={msg.chunks}\n scopeState={conversationState}\n isLatest={index === list.length - 1 && !earlyFinished}\n finished={conversation.finished}\n />\n )}\n </div>\n ))}\n {earlyFinished && (\n <div className={styles.message}>\n <AssistantMessage earlyFinished />\n </div>\n )}\n {replay\n ? conversation?.finished && (\n <>\n <PlanProgress\n plan={plan}\n conversationState={conversationState}\n style={{ marginTop: 14 }}\n />\n <NodeReplay finished ui=\"chat\" />\n </>\n )\n : showFeedback &&\n (conversationState === \"completed\" ||\n (conversationState === \"failed\" &&\n showFeedbackAfterFailed)) &&\n tasks.length > 0 && (\n <NodeFeedback className={styles.feedback} />\n )}\n </div>\n </div>\n <button\n className={`${scrollStyles[\"scroll-down\"]} ${floatingStyles[\"floating-button\"]}`}\n hidden={!scrollable}\n onClick={scrollToBottom}\n >\n <WrappedIcon lib=\"antd\" icon=\"down\" />\n </button>\n {(replay ? !conversation?.finished : supports?.chat) ? (\n <div className={styles.footer}>\n <div className={styles.narrow}>\n <PlanProgress\n plan={plan}\n conversationState={conversationState}\n />\n {replay ? (\n <NodeReplay />\n ) : (\n <ChatBox state={conversationState} canChat={canChat} />\n )}\n </div>\n </div>\n ) : null}\n </>\n ) : (\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 {\n <div\n className={classNames(styles.aside, {\n [styles.expanded]: !!fulfilledActiveDetail,\n })}\n >\n {fulfilledActiveDetail && (\n <Aside\n detail={fulfilledActiveDetail}\n faded={!!fulfilledSubActiveDetail}\n />\n )}\n {fulfilledSubActiveDetail && (\n <Aside detail={fulfilledSubActiveDetail} isSubTask />\n )}\n </div>\n }\n {activeExpandedViewJobId && <ExpandedView views={views!} />}\n {showUiSwitch && (\n <div className={classNames(toolbarStyles.toolbar, styles.toolbar)}>\n <WrappedIconButton\n icon={ICON_CANVAS}\n variant=\"mini\"\n title={t(K.SWITCH_TO_CANVAS)}\n onClick={onSwitchToCanvas}\n />\n </div>\n )}\n {activeFile && <FilePreview file={activeFile} />}\n {activeImages && <ImagesPreview images={activeImages} />}\n </StreamContext.Provider>\n </TaskContext.Provider>\n );\n}\n","import { useMemo } from \"react\";\nimport type { PlanProgressStep, ServiceFlowRun, Task } from \"./interfaces\";\n\nexport function useServiceFlowPlan(\n serviceFlows: ServiceFlowRun[],\n tasks: Task[]\n): PlanProgressStep[] {\n return useMemo(() => {\n const steps: PlanProgressStep[] = [];\n\n for (const flow of serviceFlows) {\n for (const stage of flow.spec) {\n for (const activity of stage.serviceFlowActivities) {\n if (activity.taskId) {\n const task = tasks.find((t) => t.id === activity.taskId);\n steps.push({\n name: activity.name,\n taskId: activity.taskId,\n state: task?.state,\n });\n } else {\n steps.push({\n name: activity.name,\n });\n }\n }\n }\n }\n\n return steps;\n }, [serviceFlows, tasks]);\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\";\nimport ___CSS_LOADER_GET_URL_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/getUrl.js\";\nvar ___CSS_LOADER_URL_IMPORT_0___ = new URL(\"../home-container/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, `ai-portal\\\\.chat-stream{display:flex;position:relative;width:100%;height:100%;overflow:hidden;background-color:#f3f3f4;background-image:url(${___CSS_LOADER_URL_REPLACEMENT_0___});background-size:cover;background-repeat:no-repeat;background-position:center;background-attachment:fixed;color:rgba(0,0,0,0.88);--cruise-canvas-node-width-small:330px;--cruise-canvas-node-width-medium:453px;--cruise-canvas-node-width-large:800px;--cruise-canvas-primary-color:var(--elevo-color-brand);--cruise-canvas-input-background:rgba(255,255,255,0.8);--cruise-canvas-input-box-shadow:0px 1px 0px 0px #ffffff,inset 0px 2px 4px 0px #b3bcf9}.container--IOwk4fR1{display:flex;flex-direction:column;position:relative;flex:1;min-width:0}.header--O9c4lNA3{height:54px;padding:0 72px;display:flex;align-items:center;justify-content:space-between}.header--O9c4lNA3 h1{font-weight:500;font-size:14px;margin:0;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.main--KDIjetJs{overflow-y:auto;flex:1;padding:20px 24px}.narrow--xWih9UIb{width:100%;max-width:800px;margin:0 auto}.message--YIXGDQNi + .message--YIXGDQNi{margin-top:40px}.loading-icon--lagcmORP{flex:1;display:flex;align-items:center;justify-content:center;font-size:48px;color:#fff}.footer--aLZ8UWjM{padding:0 20px 24px}.aside--Xjd6To2A{width:0%;height:100%;transition:width 0.2s ease-in-out;position:relative}.expanded--xZgk3uBF{width:50%}.feedback--YbYylTcK{margin:24px auto 0}.toolbar--uiLshJmw{left:20px;bottom:20px}@media (max-width: 1123px){div.toolbar--uiLshJmw{display:none}}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"container\": `container--IOwk4fR1`,\n\t\"header\": `header--O9c4lNA3`,\n\t\"main\": `main--KDIjetJs`,\n\t\"narrow\": `narrow--xWih9UIb`,\n\t\"message\": `message--YIXGDQNi`,\n\t\"loading-icon\": `loading-icon--lagcmORP`,\n\t\"footer\": `footer--aLZ8UWjM`,\n\t\"aside\": `aside--Xjd6To2A`,\n\t\"expanded\": `expanded--xZgk3uBF`,\n\t\"feedback\": `feedback--YbYylTcK`,\n\t\"toolbar\": `toolbar--uiLshJmw`\n};\nexport default ___CSS_LOADER_EXPORT___;\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, `.aside--DDIdDtkt{padding:12px 12px 12px 0;height:100%}.faded--AsNxuT2v{opacity:0.4}.sub--d8EpebQt{position:absolute;top:16px;right:16px;left:-16px;height:calc(100% - 16px)}.box--niuFBiiQ{background:#ffffff;box-shadow:1px 1px 10px 0px rgba(0,10,26,0.1);border-radius:12px;height:100%;display:flex;flex-direction:column}.header--DPl_hrTp{height:52px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(0,0,0,0.15);padding:0 20px}.title--HlE9yRcJ{font-weight:500;font-size:16px;color:#262626}.body--OLKz1zeC{flex:1;min-height:0;padding:20px;display:flex;flex-direction:column}.body--OLKz1zeC.scrollable--JydKNhBJ{overflow-y:auto}.app--UanK0TGf{flex:1;min-height:0;background:#ffffff;border-radius:9px;border:1px solid #ccd1de;margin-top:16px;overflow:hidden;display:flex;flex-direction:column}.heading--ngRi_rQ4{background:#e6e9f3;color:#5e6472;padding:5px 14px}.content--I2i0y65v{font-size:12px;flex:1;min-height:0;position:relative}.scroller--mLfznC_I{height:100%;overflow-x:hidden;overflow-y:auto;overflow:hidden auto;padding:10px}.scroller--mLfznC_I.loading--U1GWHEp9{display:flex;align-items:center;justify-content:center}.editor--p_Sqs1os .content--I2i0y65v .code-block--XiUVX7st::part(wrapper){position:static;margin:0}.editor--p_Sqs1os .content--I2i0y65v .code-block--XiUVX7st::part(pre){background:none!important;padding:0;border-radius:0;border:0}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"aside\": `aside--DDIdDtkt`,\n\t\"faded\": `faded--AsNxuT2v`,\n\t\"sub\": `sub--d8EpebQt`,\n\t\"box\": `box--niuFBiiQ`,\n\t\"header\": `header--DPl_hrTp`,\n\t\"title\": `title--HlE9yRcJ`,\n\t\"body\": `body--OLKz1zeC`,\n\t\"scrollable\": `scrollable--JydKNhBJ`,\n\t\"app\": `app--UanK0TGf`,\n\t\"heading\": `heading--ngRi_rQ4`,\n\t\"content\": `content--I2i0y65v`,\n\t\"scroller\": `scroller--mLfznC_I`,\n\t\"loading\": `loading--U1GWHEp9`,\n\t\"editor\": `editor--p_Sqs1os`,\n\t\"code-block\": `code-block--XiUVX7st`\n};\nexport default ___CSS_LOADER_EXPORT___;\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, `.app--qxnx6yuG{border-radius:9px;border:1px solid #ccd1de;flex:1;min-height:0;display:flex;flex-direction:column}.heading--SbCRupnn{border-bottom:1px solid #ccd1de;border-radius:9px 9px 0 0;background-image:radial-gradient(circle at 1px 1px,#ddd 1px,transparent 0px);background-size:25px 25px;background-position:12px;max-height:30%;display:flex;flex-direction:column}.header--LGXNxV5J{display:flex;align-items:center;padding:16px 30px}.status--aqbJGBcl{background:#aeb3bc;border-radius:100px;height:40px;padding:9px 16px;display:flex;align-items:center;gap:8px;font-size:18px;color:#ffffff}.status--aqbJGBcl eo-icon{font-size:22px}.status--aqbJGBcl.paused--U1cc3Ksn{background:#f0a22e}.status--aqbJGBcl.working--f2PYqFo7{background:#4f69ff}.status--aqbJGBcl.completed--Ihiekkve{background:#08bf33}.status--aqbJGBcl.failed--kB8wxIZ0{background:var(--color-error)}.title--IRvB2t7z{font-weight:500;font-size:16px;margin-left:40px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chart--mypbn8pI{padding:8px 22px 18px;overflow:auto;min-height:0}.body--jnk1EIz0{padding:16px 12px 12px;display:flex;flex:1;min-height:0;flex-direction:column;position:relative}.activity-title--hF6stwmT{font-weight:500;font-size:16px;display:flex;align-items:center;gap:6px;margin-bottom:16px}.activity-title--hF6stwmT eo-icon{font-size:20px;color:#8c8c8c}.activity-title--hF6stwmT .paused--U1cc3Ksn{color:#f0a22e}.activity-title--hF6stwmT .working--f2PYqFo7{color:#4f69ff}.activity-title--hF6stwmT .completed--Ihiekkve{color:#08bf33}.activity-title--hF6stwmT .failed--kB8wxIZ0{color:var(--color-error)}.chat--nEzTEXbV{background:rgba(227,228,229,0.4);border:1px solid rgba(0,0,0,0.1);border-radius:8px;padding:16px 20px;flex:1;min-height:0;overflow-y:auto}.messages--vLiwUYSP{width:100%;margin:0 auto}.message--Okzj6NDx + .message--Okzj6NDx{margin-top:40px}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"app\": `app--qxnx6yuG`,\n\t\"heading\": `heading--SbCRupnn`,\n\t\"header\": `header--LGXNxV5J`,\n\t\"status\": `status--aqbJGBcl`,\n\t\"paused\": `paused--U1cc3Ksn`,\n\t\"working\": `working--f2PYqFo7`,\n\t\"completed\": `completed--Ihiekkve`,\n\t\"failed\": `failed--kB8wxIZ0`,\n\t\"title\": `title--IRvB2t7z`,\n\t\"chart\": `chart--mypbn8pI`,\n\t\"body\": `body--jnk1EIz0`,\n\t\"activity-title\": `activity-title--hF6stwmT`,\n\t\"chat\": `chat--nEzTEXbV`,\n\t\"messages\": `messages--vLiwUYSP`,\n\t\"message\": `message--Okzj6NDx`\n};\nexport default ___CSS_LOADER_EXPORT___;\n"],"names":["getFlowOrActivityIcon","state","lib","theme","icon","spinning","___CSS_LOADER_EXPORT___","push","module","id","locals","options","styleTagTransform","setAttributes","insert","domAPI","insertStyleElement","undefined","K","NS","t","i18n","getFixedT","FlowApp","_ref","_flow$space","flow","activity","tasks","setActiveDetail","useContext","TaskContext","flowTask","useMemo","find","taskId","runningSpec","spec","map","stage","_stage$serviceFlowAct","serviceFlowActivities","task","name","startTime","endTime","flowStatus","getFlowStatusDisplay","React","className","styles","app","heading","header","classNames","status","WrappedIcon","text","title","space","chart","WrappedRunningFlow","activeActivityId","onActiveChange","e","detail","type","body","ActivityDetail","WrappedBlankState","blank","description","illustration","_ref2","errors","activityTask","activityState","fixedTasks","parent","messages","useConversationStream","scrollContainerRef","useRef","scrollContentRef","scrollable","scrollToBottom","useAutoScroll","_extends","chat","ref","msg","index","list","message","key","role","UserMessage","content","mentionedAiEmployeeId","cmd","files","AssistantMessage","chunks","scopeState","isLatest","length","isSubTask","scrollStyles","floatingStyles","style","bottom","hidden","onClick","EXECUTING","working","SUCCEEDED","completed","FAILED","failed","PAUSED","paused","TERMINATED","WAITING","initializeI18n","en","zh","ICON_SHRINK","Aside","faded","setSubActiveDetail","setUserClosedAside","StreamContext","aside","sub","box","WrappedIconButton","variant","job","generatedView","ToolCallStatus","EditorApp","source","code","language","ToolCallDetail","editor","sharedStyles","markdown","scroller","WrappedCodeBlock","themeVariant","PlanProgress","plan","conversationState","expanded","setExpanded","useState","doneCount","reduce","acc","step","getClassNameAndIconProps","toggle","useCallback","prev","allDone","mask","progress","bar","PLAN_COMPLETED","stat","expand","details","PlanProgressStep","prefix","canceled","ChatStreamComponent","_conversation$title","conversationId","initialRequest","replay","replayDelay","supports","showHumanActions","showFeedback","propShowFeedback","showFeedbackAfterFailed","showFeedbackOnView","showUiSwitch","previewUrlTemplate","showCases","exampleProjects","tryItOutUrl","aiEmployees","commands","uploadOptions","onShare","onTerminate","onSubmitFeedback","onSwitchToCanvas","onFeedbackOnView","onDetailChange","onSplitChange","conversation","serviceFlows","humanInputRef","skipToResults","watchAgain","useConversationDetail","conversationAvailable","pageTitle","canChat","DONE_STATES","includes","steps","useServiceFlowPlan","flowMap","activityMap","useFlowAndActivityMap","jobMap","lastDetail","skipActivitySubTasks","useEffect","projectId","views","values","flatMap","view","submittingFeedback","setSubmittingFeedback","submittedFeedback","setSubmittedFeedback","setShowFeedback","feedbackDoneViews","setFeedbackDoneViews","handleSubmitFeedback","useImperativeHandle","feedbackSubmitDone","setTimeout","feedbackSubmitFailed","feedbackOnViewDone","viewId","newSet","Set","add","activeExpandedViewJobId","setActiveExpandedViewJobId","activeDetail","subActiveDetail","userClosedAside","delayRef","timer","current","clearTimeout","hasInitialRequest","getRuntime","applyPageTitle","humanInput","input","action","extra","_humanInputRef$curren","call","firstMessage","userMessage","activeFile","setActiveFile","activeImages","setActiveImages","workspace","taskContextValue","tryItOut","win","window","open","getBasePath","slice","__elevo_try_it_out","streamContextValue","depsReady","setDepsReady","ignore","Promise","race","preloadHighlighter","resolve","finally","fulfilledActiveDetail","useFulfilledActiveDetail","fulfilledSubActiveDetail","useHandleEscape","split","_scrollContainerRef$c","focus","earlyFinished","finished","NON_WORKING_STATES","Provider","value","container","main","tabIndex","narrow","marginTop","NodeReplay","ui","NodeFeedback","feedback","footer","ChatBox","ExpandedView","toolbarStyles","toolbar","ICON_CANVAS","SWITCH_TO_CANVAS","FilePreview","file","ImagesPreview","images","___CSS_LOADER_URL_IMPORT_0___","URL","___CSS_LOADER_URL_REPLACEMENT_0___"],"sourceRoot":""}
@@ -1,2 +0,0 @@
1
- "use strict";(globalThis.webpackChunk_next_bricks_ai_portal=globalThis.webpackChunk_next_bricks_ai_portal||[]).push([[288],{8337:(e,t,a)=>{a.d(t,{A:()=>g});var s=a(72591),l=a.n(s),n=a(1740),i=a.n(n),r=a(88128),o=a.n(r),c=a(30855),h=a.n(c),u=a(93051),d=a.n(u),p=a(73656),m=a.n(p),v=a(55111),A={};A.styleTagTransform=m(),A.setAttributes=h(),A.insert=o().bind(null,"head"),A.domAPI=i(),A.insertStyleElement=d(),l()(v.A,A);const g=v.A&&v.A.locals?v.A.locals:void 0},11552:(e,t,a)=>{a.r(t),a.d(t,{ChatPanel:()=>te});var s,l=a(70918),n=a(86121),i=a(70829),r=a(62740),o=a(18769),c=a.n(o),h=a(90870),u=a(30981),d=(a(34419),a(22919)),p=a(18796),m=a(8337),v=a(60128),A=a(67101),g=a(13330),f=a(52208),w=a(40563),E=a(30621),k=a(84766),b=a(9442),y=a(69493),I=a(32360),T=a(40177),C=a(30672),x=a(38717),B=a(6671),N=a(76720);let R,M,W,F,O,S,P,V,_,j,G,Z,D,H,L,U,$,q,K,z;const Q=(0,u.wrapBrick)("eo-modal",{onClose:"close",onConfirm:"confirm",onCancel:"cancel",onOpen:"open"}),{defineElement:J,property:X,method:Y}=(0,h.createDecorators)(),ee=(0,o.forwardRef)(pe);let te;var ae=new WeakMap,se=new WeakMap,le=new WeakMap,ne=new WeakMap,ie=new WeakMap,re=new WeakMap,oe=new WeakMap,ce=new WeakMap,he=new WeakMap,ue=new WeakMap;class de extends u.ReactNextElement{constructor(){super(...arguments),(0,l.A)(this,ae,(R(this),W(this))),(0,l.A)(this,se,(F(this),O(this))),(0,l.A)(this,le,(S(this),P(this))),(0,l.A)(this,ne,(V(this),_(this))),(0,l.A)(this,ie,(j(this),G(this))),(0,l.A)(this,re,(Z(this),D(this))),(0,l.A)(this,oe,(H(this),L(this))),(0,l.A)(this,ce,(U(this),$(this))),(0,l.A)(this,he,(q(this),K(this))),(0,l.A)(this,ue,(z(this),(0,o.createRef)()))}get panelTitle(){return(0,i.A)(ae,this)}set panelTitle(e){(0,n.A)(ae,this,e)}get aiEmployeeId(){return(0,i.A)(se,this)}set aiEmployeeId(e){(0,n.A)(se,this,e)}get cmd(){return(0,i.A)(le,this)}set cmd(e){(0,n.A)(le,this,e)}get width(){return(0,i.A)(ne,this)}set width(e){(0,n.A)(ne,this,e)}get height(){return(0,i.A)(ie,this)}set height(e){(0,n.A)(ie,this,e)}get placeholder(){return(0,i.A)(re,this)}set placeholder(e){(0,n.A)(re,this,e)}get uploadOptions(){return(0,i.A)(oe,this)}set uploadOptions(e){(0,n.A)(oe,this,e)}get help(){return(0,i.A)(ce,this)}set help(e){(0,n.A)(ce,this,e)}get maskClosable(){return(0,i.A)(he,this)}set maskClosable(e){(0,n.A)(he,this,e)}open(){var e;null===(e=(0,i.A)(ue,this).current)||void 0===e||e.open()}close(){var e;null===(e=(0,i.A)(ue,this).current)||void 0===e||e.close()}setInputValue(e){var t;null===(t=(0,i.A)(ue,this).current)||void 0===t||t.setInputValue(e)}send(e){var t;null===(t=(0,i.A)(ue,this).current)||void 0===t||t.send(e)}showFile(e){var t;null===(t=(0,i.A)(ue,this).current)||void 0===t||t.showFile(e)}render(){return c().createElement(ee,{ref:(0,i.A)(ue,this),panelTitle:this.panelTitle,aiEmployeeId:this.aiEmployeeId,cmd:this.cmd,width:this.width,height:this.height,placeholder:this.placeholder,uploadOptions:this.uploadOptions,help:this.help,maskClosable:this.maskClosable})}}function pe(e,t){let{panelTitle:a,aiEmployeeId:s,cmd:l,width:n,height:i,placeholder:r,uploadOptions:h,help:u,maskClosable:R}=e;const M=(0,o.useRef)(null),W=(0,o.useRef)(null),[F,O]=(0,o.useState)(!1),[S,P]=(0,o.useState)(null),[V,_]=(0,o.useState)(null),{conversation:j,tasks:G,errors:Z,humanInputRef:D}=(0,A.u)(S,V),H=!!j,L=null==j?void 0:j.state,U=T.QB.includes(L),$=!S||U||"input-required"===L,{messages:q}=(0,g.p)(H,L,G,Z),K=(0,o.useCallback)(((e,t,a)=>{var s;null===(s=D.current)||void 0===s||s.call(D,e,t,a)}),[D]),[z,J]=(0,o.useState)(!1);(0,o.useEffect)((()=>{let e=!1;return Promise.race([(0,f.L)("light-plus"),new Promise((e=>setTimeout(e,5e3)))]).finally((()=>{e||J(!0)})),()=>{e=!0}}),[]);const X=(0,o.useRef)(null),Y=(0,o.useRef)(null),{scrollable:ee,scrollToBottom:te}=(0,w.i)(H&&z,X,Y),ae=(0,o.useCallback)((async e=>{if(S){const{content:t,...a}=e;K(t,void 0,a)}else{O(!0);try{const t=(await d.http.post("api/gateway/logic.llm.aiops_service/api/v1/elevo/conversations",{})).data.conversationId;P(t),_({...e,...s?{aiEmployeeId:s}:null,...l?{cmd:l}:null,conversationId:t})}catch(e){(0,v.handleHttpError)(e)}finally{O(!1)}}}),[s,l,S,K]),[se,le]=(0,o.useState)(null),[ne,ie]=(0,o.useState)(null),re=(0,o.useMemo)((()=>({conversationState:L,setActiveFile:le,setActiveImages:ie,humanInput:K})),[L,K]);(0,o.useImperativeHandle)(t,(()=>({open:()=>{var e;null===(e=M.current)||void 0===e||e.open()},close:()=>{var e;null===(e=M.current)||void 0===e||e.close()},setInputValue:e=>{var t;null===(t=W.current)||void 0===t||t.setValue(e)},send:e=>{ae(e)},showFile:e=>{le(e)}})),[ae]);const oe=(null==j?void 0:j.finished)&&!T.Z5.includes(L);return c().createElement(N.j.Provider,{value:re},c().createElement(Q,{modalTitle:a,width:n,height:i,themeVariant:"elevo",maskClosable:R,noFooter:!0,headerBordered:!0,fullscreenButton:!0,background:`fixed url(${I}) center center / cover no-repeat`,onOpen:()=>{setTimeout((()=>{var e;null===(e=W.current)||void 0===e||e.focus()}),100)},ref:M},c().createElement("div",{className:m.A.panel},S?H&&z?c().createElement("div",{className:m.A.main},c().createElement("div",{className:m.A.chat,ref:X},c().createElement("div",{className:m.A.narrow},c().createElement("div",{className:m.A.messages,ref:Y},q.map(((e,t,a)=>c().createElement("div",{className:m.A.message,key:t},"user"===e.role?c().createElement(E.R,{content:e.content,files:e.files}):c().createElement(k.G,{chunks:e.chunks,scopeState:j.state,isLatest:t===a.length-1&&!oe,finished:j.finished})))),oe&&c().createElement("div",{className:m.A.message},c().createElement(k.G,{earlyFinished:!0}))))),c().createElement("button",{className:`${b.A["scroll-down"]} ${y.A["floating-button"]}`,style:{bottom:"30px"},hidden:!ee,onClick:te},c().createElement(C.Bj,{lib:"antd",icon:"down"}))):c().createElement("div",{className:m.A["loading-icon"]},c().createElement(C.Bj,{lib:"antd",theme:"outlined",icon:"loading-3-quarters",spinning:!0})):c().createElement("div",{className:m.A.main},c().createElement("div",{className:m.A.chat},c().createElement("div",{className:m.A.narrow},u?c().createElement(p.ReactUseMultipleBricks,{useBrick:u.useBrick}):null))),c().createElement("div",{className:m.A.narrow},c().createElement(C.IV,{ref:W,placeholder:r,suggestionsPlacement:"top",submitDisabled:F||!$,supportsTerminate:!0,uploadOptions:h,onChatSubmit:e=>ae(e.detail)})))),se&&c().createElement(x.d,{file:se,fromModal:!0}),ne&&c().createElement(B.f,{images:ne,fromModal:!0}))}s=de,({e:[W,F,O,S,P,V,_,j,G,Z,D,H,L,U,$,q,K,z,R],c:[te,M]}=(0,r.A)(s,[J("ai-portal.chat-panel",{shadowOptions:!1})],[[X(),1,"panelTitle"],[X(),1,"aiEmployeeId"],[X({attribute:!1}),1,"cmd"],[X({attribute:!1}),1,"width"],[X({attribute:!1}),1,"height"],[X(),1,"placeholder"],[X({attribute:!1}),1,"uploadOptions"],[X({attribute:!1}),1,"help"],[X({type:Boolean}),1,"maskClosable"],[Y(),2,"open"],[Y(),2,"close"],[Y(),2,"setInputValue"],[Y(),2,"send"],[Y(),2,"showFile"]],0,void 0,u.ReactNextElement)),M()},55111:(e,t,a)=>{a.d(t,{A:()=>r});var s=a(36758),l=a.n(s),n=a(40935),i=a.n(n)()(l());i.push([e.id,".panel--ukaGUcR2{display:flex;flex-direction:column;min-height:300px;height:100%}.narrow--NBtGp4vW{width:100%;max-width:800px;margin:0 auto}.main--K5R8dLH9{position:relative;flex:1;min-height:0}.chat--Drl2ThnZ{padding:0 0 20px;height:100%;overflow-y:auto}.messages--Bhaarj69{width:100%;margin:0 auto}.message--TP5bdFpZ + .message--TP5bdFpZ{margin-top:40px}.loading-icon--BjI0pCV1{flex:1;display:flex;align-items:center;justify-content:center;font-size:48px;color:#fff}",""]),i.locals={panel:"panel--ukaGUcR2",narrow:"narrow--NBtGp4vW",main:"main--K5R8dLH9",chat:"chat--Drl2ThnZ",messages:"messages--Bhaarj69",message:"message--TP5bdFpZ","loading-icon":"loading-icon--BjI0pCV1"};const r=i}}]);
2
- //# sourceMappingURL=chat-panel.a3dafde9.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"chunks/chat-panel.a3dafde9.js","mappings":"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","sources":["webpack:///./src/chat-panel/styles.module.css?bf50","webpack:///./src/chat-panel/index.tsx","webpack:///./src/chat-panel/styles.module.css"],"sourcesContent":["\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./styles.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./styles.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, {\n createRef,\n forwardRef,\n useCallback,\n useEffect,\n useImperativeHandle,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { createDecorators } from \"@next-core/element\";\nimport { ReactNextElement, wrapBrick } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport type {\n Modal,\n ModalProps,\n ModalEvents,\n ModalMapEvents,\n} from \"@next-bricks/containers/modal\";\nimport { http } from \"@next-core/http\";\nimport type { UseBrickConf } from \"@next-core/types\";\nimport { ReactUseMultipleBricks } from \"@next-core/react-runtime\";\nimport styles from \"./styles.module.css\";\nimport type { ChatInput } from \"../chat-input\";\nimport type {\n ActiveImages,\n ChatPayload,\n CommandPayload,\n ExtraChatPayload,\n FileInfo,\n RequestStore,\n UploadOptions,\n} from \"../shared/interfaces\";\nimport { handleHttpError } from \"@next-core/runtime\";\nimport { useConversationDetail } from \"../cruise-canvas/useConversationDetail\";\nimport { useConversationStream } from \"../chat-stream/useConversationStream\";\nimport { preloadHighlighter } from \"@next-shared/markdown\";\nimport { useAutoScroll } from \"../chat-stream/useAutoScroll\";\nimport { UserMessage } from \"../chat-stream/UserMessage/UserMessage\";\nimport { AssistantMessage } from \"../chat-stream/AssistantMessage/AssistantMessage\";\nimport scrollStyles from \"../chat-stream/ScrollDownButton.module.css\";\nimport floatingStyles from \"../shared/FloatingButton.module.css\";\nimport backgroundImage from \"../home-container/images/background.png\";\nimport { DONE_STATES, NON_WORKING_STATES } from \"../shared/constants\";\nimport { WrappedChatInput, WrappedIcon } from \"../shared/bricks\";\nimport { FilePreview } from \"../shared/FilePreview/FilePreview.js\";\nimport { ImagesPreview } from \"../shared/FilePreview/ImagesPreview.js\";\nimport { TaskContext, type TaskContextValue } from \"../shared/TaskContext\";\n\nconst WrappedModal = wrapBrick<\n Modal,\n ModalProps & {\n themeVariant?: \"default\" | \"elevo\";\n height?: string | number;\n noFooter?: boolean;\n headerBordered?: boolean;\n background?: string;\n fullscreenButton?: boolean;\n },\n ModalEvents,\n ModalMapEvents\n>(\"eo-modal\", {\n onClose: \"close\",\n onConfirm: \"confirm\",\n onCancel: \"cancel\",\n onOpen: \"open\",\n});\n\nconst { defineElement, property, method } = createDecorators();\n\nexport interface ChatPanelProps {\n panelTitle?: string;\n aiEmployeeId?: string;\n cmd?: CommandPayload;\n width?: string | number;\n height?: string | number;\n placeholder?: string;\n uploadOptions?: UploadOptions;\n help?: { useBrick: UseBrickConf };\n maskClosable?: boolean;\n}\n\nconst ChatPanelComponent = forwardRef(LegacyChatPanelComponent);\n\n/**\n * 弹出式对话面板。\n */\nexport\n@defineElement(\"ai-portal.chat-panel\", {\n shadowOptions: false,\n})\nclass ChatPanel extends ReactNextElement implements ChatPanelProps {\n @property()\n accessor panelTitle: string | undefined;\n\n @property()\n accessor aiEmployeeId: string | undefined;\n\n @property({ attribute: false })\n accessor cmd: CommandPayload | undefined;\n\n @property({ attribute: false }) accessor width: string | number | undefined;\n\n @property({ attribute: false }) accessor height: string | number | undefined;\n\n @property()\n accessor placeholder: string | undefined;\n\n @property({ attribute: false })\n accessor uploadOptions: UploadOptions | undefined;\n\n /**\n * Show help messages when no conversation exists.\n */\n @property({ attribute: false })\n accessor help: { useBrick: UseBrickConf } | undefined;\n\n /**\n * Whether to close the panel when clicking the mask.\n *\n * @default false\n */\n @property({ type: Boolean })\n accessor maskClosable: boolean | undefined;\n\n #ref = createRef<ChatPanelRef>();\n\n @method()\n open() {\n this.#ref.current?.open();\n }\n\n @method()\n close() {\n this.#ref.current?.close();\n }\n\n @method()\n setInputValue(content: string) {\n this.#ref.current?.setInputValue(content);\n }\n\n @method()\n send(payload: ChatPayload) {\n this.#ref.current?.send(payload);\n }\n\n @method()\n showFile(file: FileInfo) {\n this.#ref.current?.showFile(file);\n }\n\n render() {\n return (\n <ChatPanelComponent\n ref={this.#ref}\n panelTitle={this.panelTitle}\n aiEmployeeId={this.aiEmployeeId}\n cmd={this.cmd}\n width={this.width}\n height={this.height}\n placeholder={this.placeholder}\n uploadOptions={this.uploadOptions}\n help={this.help}\n maskClosable={this.maskClosable}\n />\n );\n }\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\ninterface ChatPanelComponentProps extends ChatPanelProps {\n // Define react event handlers here.\n}\n\ninterface ChatPanelRef {\n open: () => void;\n close: () => void;\n setInputValue: (content: string) => void;\n send: (payload: ChatPayload) => void;\n showFile: (file: FileInfo) => void;\n}\n\nfunction LegacyChatPanelComponent(\n {\n panelTitle,\n aiEmployeeId,\n cmd,\n width,\n height,\n placeholder,\n uploadOptions,\n help,\n maskClosable,\n }: ChatPanelComponentProps,\n ref: React.Ref<ChatPanelRef>\n) {\n const modalRef = useRef<Modal>(null);\n const inputRef = useRef<ChatInput>(null);\n\n const [submitDisabled, setSubmitDisabled] = useState(false);\n\n const [conversationId, setConversationId] = useState<string | null>(null);\n const [initialRequest, setInitialRequest] = useState<RequestStore | null>(\n null\n );\n\n const { conversation, tasks, errors, humanInputRef } = useConversationDetail(\n conversationId,\n initialRequest\n );\n const conversationAvailable = !!conversation;\n const conversationState = conversation?.state;\n const conversationDone = DONE_STATES.includes(conversationState!);\n const canChat =\n !conversationId ||\n conversationDone ||\n conversationState === \"input-required\";\n\n const { messages } = useConversationStream(\n conversationAvailable,\n conversationState,\n tasks,\n errors\n );\n\n const humanInput = useCallback(\n (input: string | null, action?: string, extra?: ExtraChatPayload) => {\n humanInputRef.current?.(input, action, extra);\n },\n [humanInputRef]\n );\n\n const [depsReady, setDepsReady] = useState(false);\n useEffect(() => {\n let ignore = false;\n Promise.race([\n preloadHighlighter(\"light-plus\"),\n // Wait at most 5s\n new Promise((resolve) => setTimeout(resolve, 5000)),\n ]).finally(() => {\n if (!ignore) {\n setDepsReady(true);\n }\n });\n return () => {\n ignore = true;\n };\n }, []);\n\n const scrollContainerRef = useRef<HTMLDivElement>(null);\n const scrollContentRef = useRef<HTMLDivElement>(null);\n\n const { scrollable, scrollToBottom } = useAutoScroll(\n conversationAvailable && depsReady,\n scrollContainerRef,\n scrollContentRef\n );\n\n const handleChatSubmit = useCallback(\n async (payload: ChatPayload) => {\n if (conversationId) {\n const { content, ...extra } = payload;\n // For follow-up messages, do not pass aiEmployeeId and cmd again,\n // unless passed explicitly.\n humanInput(content, undefined, extra);\n return;\n }\n setSubmitDisabled(true);\n try {\n const res = await http.post<{\n data: { conversationId: string };\n }>(\n \"api/gateway/logic.llm.aiops_service/api/v1/elevo/conversations\",\n {}\n );\n const conversationId = res.data.conversationId;\n setConversationId(conversationId);\n setInitialRequest({\n ...payload,\n ...(aiEmployeeId ? { aiEmployeeId } : null),\n ...(cmd ? { cmd } : null),\n conversationId: conversationId,\n });\n } catch (e) {\n handleHttpError(e);\n } finally {\n setSubmitDisabled(false);\n }\n },\n [aiEmployeeId, cmd, conversationId, humanInput]\n );\n\n const [activeFile, setActiveFile] = useState<FileInfo | null>(null);\n const [activeImages, setActiveImages] = useState<ActiveImages | null>(null);\n\n const taskContextValue = useMemo(\n () =>\n ({\n conversationState,\n setActiveFile,\n setActiveImages,\n humanInput,\n }) as TaskContextValue,\n [conversationState, humanInput]\n );\n\n useImperativeHandle(\n ref,\n () => ({\n open: () => {\n modalRef.current?.open();\n },\n close: () => {\n modalRef.current?.close();\n },\n setInputValue: (content: string) => {\n inputRef.current?.setValue(content);\n },\n send: (payload: ChatPayload) => {\n handleChatSubmit(payload);\n },\n showFile: (file: FileInfo) => {\n setActiveFile(file);\n },\n }),\n [handleChatSubmit]\n );\n\n const earlyFinished =\n conversation?.finished && !NON_WORKING_STATES.includes(conversationState!);\n\n return (\n <TaskContext.Provider value={taskContextValue}>\n <WrappedModal\n modalTitle={panelTitle}\n width={width}\n height={height}\n themeVariant=\"elevo\"\n maskClosable={maskClosable}\n noFooter\n headerBordered\n fullscreenButton\n background={`fixed url(${backgroundImage}) center center / cover no-repeat`}\n onOpen={() => {\n setTimeout(() => {\n inputRef.current?.focus();\n }, 100);\n }}\n ref={modalRef}\n >\n <div className={styles.panel}>\n {!conversationId ? (\n <div className={styles.main}>\n <div className={styles.chat}>\n <div className={styles.narrow}>\n {help ? (\n <ReactUseMultipleBricks useBrick={help.useBrick} />\n ) : null}\n </div>\n </div>\n </div>\n ) : conversationAvailable && depsReady ? (\n <div className={styles.main}>\n <div className={styles.chat} ref={scrollContainerRef}>\n <div className={styles.narrow}>\n <div className={styles.messages} ref={scrollContentRef}>\n {messages.map((msg, index, list) => (\n <div className={styles.message} key={index}>\n {msg.role === \"user\" ? (\n <UserMessage\n content={msg.content}\n files={msg.files}\n />\n ) : (\n <AssistantMessage\n chunks={msg.chunks}\n scopeState={conversation.state}\n isLatest={\n index === list.length - 1 && !earlyFinished\n }\n finished={conversation.finished}\n />\n )}\n </div>\n ))}\n {earlyFinished && (\n <div className={styles.message}>\n <AssistantMessage earlyFinished />\n </div>\n )}\n </div>\n </div>\n </div>\n <button\n className={`${scrollStyles[\"scroll-down\"]} ${floatingStyles[\"floating-button\"]}`}\n style={{ bottom: \"30px\" }}\n hidden={!scrollable}\n onClick={scrollToBottom}\n >\n <WrappedIcon lib=\"antd\" icon=\"down\" />\n </button>\n </div>\n ) : (\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 className={styles.narrow}>\n <WrappedChatInput\n ref={inputRef}\n placeholder={placeholder}\n suggestionsPlacement=\"top\"\n submitDisabled={submitDisabled || !canChat}\n supportsTerminate\n uploadOptions={uploadOptions}\n onChatSubmit={(e) => handleChatSubmit(e.detail)}\n />\n </div>\n </div>\n </WrappedModal>\n {activeFile && <FilePreview file={activeFile} fromModal />}\n {activeImages && <ImagesPreview images={activeImages} fromModal />}\n </TaskContext.Provider>\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, `.panel--ukaGUcR2{display:flex;flex-direction:column;min-height:300px;height:100%}.narrow--NBtGp4vW{width:100%;max-width:800px;margin:0 auto}.main--K5R8dLH9{position:relative;flex:1;min-height:0}.chat--Drl2ThnZ{padding:0 0 20px;height:100%;overflow-y:auto}.messages--Bhaarj69{width:100%;margin:0 auto}.message--TP5bdFpZ + .message--TP5bdFpZ{margin-top:40px}.loading-icon--BjI0pCV1{flex:1;display:flex;align-items:center;justify-content:center;font-size:48px;color:#fff}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"panel\": `panel--ukaGUcR2`,\n\t\"narrow\": `narrow--NBtGp4vW`,\n\t\"main\": `main--K5R8dLH9`,\n\t\"chat\": `chat--Drl2ThnZ`,\n\t\"messages\": `messages--Bhaarj69`,\n\t\"message\": `message--TP5bdFpZ`,\n\t\"loading-icon\": `loading-icon--BjI0pCV1`\n};\nexport default ___CSS_LOADER_EXPORT___;\n"],"names":["options","styleTagTransform","setAttributes","insert","domAPI","insertStyleElement","locals","undefined","WrappedModal","wrapBrick","onClose","onConfirm","onCancel","onOpen","defineElement","property","method","createDecorators","ChatPanelComponent","forwardRef","LegacyChatPanelComponent","_ChatPanel","_A","WeakMap","_B","_C","_D","_E","_F","_G","_H","_I","_ref","ChatPanel","ReactNextElement","constructor","arguments","_classPrivateFieldInitSpec","_initProto","_init_panelTitle","_init_extra_panelTitle","_init_aiEmployeeId","_init_extra_aiEmployeeId","_init_cmd","_init_extra_cmd","_init_width","_init_extra_width","_init_height","_init_extra_height","_init_placeholder","_init_extra_placeholder","_init_uploadOptions","_init_extra_uploadOptions","_init_help","_init_extra_help","_init_maskClosable","_init_extra_maskClosable","createRef","panelTitle","_classPrivateFieldGet","v","_classPrivateFieldSet","aiEmployeeId","cmd","width","height","placeholder","uploadOptions","help","maskClosable","open","_classPrivateFieldGet2","this","current","close","_classPrivateFieldGet3","setInputValue","content","_classPrivateFieldGet4","send","payload","_classPrivateFieldGet5","showFile","file","_classPrivateFieldGet6","render","React","ref","_ref2","modalRef","useRef","inputRef","submitDisabled","setSubmitDisabled","useState","conversationId","setConversationId","initialRequest","setInitialRequest","conversation","tasks","errors","humanInputRef","useConversationDetail","conversationAvailable","conversationState","state","conversationDone","DONE_STATES","includes","canChat","messages","useConversationStream","humanInput","useCallback","input","action","extra","_humanInputRef$curren","call","depsReady","setDepsReady","useEffect","ignore","Promise","race","preloadHighlighter","resolve","setTimeout","finally","scrollContainerRef","scrollContentRef","scrollable","scrollToBottom","useAutoScroll","handleChatSubmit","async","http","post","data","e","handleHttpError","activeFile","setActiveFile","activeImages","setActiveImages","taskContextValue","useMemo","useImperativeHandle","_modalRef$current","_modalRef$current2","_inputRef$current","setValue","earlyFinished","finished","NON_WORKING_STATES","TaskContext","Provider","value","modalTitle","themeVariant","noFooter","headerBordered","fullscreenButton","background","backgroundImage","_inputRef$current2","focus","className","styles","panel","main","chat","narrow","map","msg","index","list","message","key","role","UserMessage","files","AssistantMessage","chunks","scopeState","isLatest","length","scrollStyles","floatingStyles","style","bottom","hidden","onClick","WrappedIcon","lib","icon","theme","spinning","ReactUseMultipleBricks","useBrick","WrappedChatInput","suggestionsPlacement","supportsTerminate","onChatSubmit","detail","FilePreview","fromModal","ImagesPreview","images","_ChatPanel2","c","_initClass","_applyDecs","shadowOptions","attribute","type","Boolean","___CSS_LOADER_EXPORT___","push","module","id"],"sourceRoot":""}