@flowfuse/flowfuse 2.31.4-e2bf6b7-202606161801.0 → 2.31.4-e2bf6b7-202606161814.0

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.
@@ -1 +1 @@
1
- try{let e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},t=(new e.Error).stack;t&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[t]="5f38bfdd-d1ea-4d7e-9ed9-23794a1e4cb5",e._sentryDebugIdIdentifier="sentry-dbid-5f38bfdd-d1ea-4d7e-9ed9-23794a1e4cb5")}catch(e){}("undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{}).SENTRY_RELEASE={id:"e2bf6b7dacf90be6c1290bafb557acca1c6682a6"},(self.webpackChunk_flowfuse_flowfuse=self.webpackChunk_flowfuse_flowfuse||[]).push([[259,810],{6259:function(e,t,s){s.d(t,{default:function(){return b}});var a=s(41425);const n={ref:"drawer",class:"ff-expert-drawer","data-el":"expert-drawer",tabindex:"-1"},o={class:"header"},r={key:0,class:"agent-mode"},l={class:"header-actions"},i=["title"];var c=s(13020),d=s(39312),u=s(51580),m=s(10810),p=s(2808),h=s(13810),g=s(26460),f=s(96825),k=s(28409),v={name:"ExpertDrawer",components:{ToggleButtonGroup:p.A,ExpertPanel:h.default,XMarkIcon:c.A,LockClosedIcon:d.A,LockOpenIcon:u.A},inject:["togglePinWithWidth","shouldAllowPinning"],computed:{...(0,m.aH)(k.W,["rightDrawer"]),...(0,m.aH)(f.i,["agentMode"]),...(0,m.aH)(g.n,["featuresCheck"]),agentModeButtons(){return[{title:"Support",value:"support-agent"},{title:"Insights",value:"insights-agent"}]},isAssistantModeEnabled(){return!!this.featuresCheck?.isExpertAssistantFeatureEnabled},isInsightsModeEnabled(){return!!this.featuresCheck?.isExpertInsightsFeatureEnabled},isPinned(){return this.rightDrawer.fixed},agentModeWrapper:{get(){return this.agentMode},set(e){this.setAgentMode(e)}}},mounted(){setTimeout(()=>{this.$refs.drawer?.focus()},350)},methods:{...(0,m.i0)(k.W,["closeRightDrawer"]),...(0,m.i0)(f.i,["setAgentMode"]),closeDrawer(){this.closeRightDrawer()},togglePin(){this.togglePinWithWidth()}}},b=(0,s(66262).A)(v,[["render",function(e,t,s,c,d,u){const m=(0,a.g2)("toggle-button-group"),p=(0,a.g2)("LockClosedIcon"),h=(0,a.g2)("LockOpenIcon"),g=(0,a.g2)("XMarkIcon"),f=(0,a.g2)("ExpertPanel");return(0,a.openBlock)(),(0,a.CE)("div",n,[(0,a.Lk)("div",o,[t[3]||(t[3]=(0,a.Lk)("div",{class:"flex items-center gap-1.5"},[(0,a.Lk)("img",{src:"/ff-minimal-red.svg",alt:"FlowFuse",class:"w-5 h-5 shrink-0"}),(0,a.Lk)("h2",{class:"title"},"Expert")],-1)),u.isInsightsModeEnabled&&u.isAssistantModeEnabled?((0,a.openBlock)(),(0,a.CE)("div",r,[(0,a.createVNode)(m,{modelValue:u.agentModeWrapper,"onUpdate:modelValue":t[0]||(t[0]=e=>u.agentModeWrapper=e),buttons:u.agentModeButtons,usesLinks:!1,"visually-hide-title":!0},null,8,["modelValue","buttons"])])):(0,a.Q3)("v-if",!0),(0,a.Lk)("div",l,[u.shouldAllowPinning()?((0,a.openBlock)(),(0,a.CE)("button",{key:0,class:(0,a.C4)(["header-button pin-button",{"is-pinned":u.isPinned}]),title:u.isPinned?"Unpin drawer":"Pin drawer open","data-el":"expert-drawer-pin-button",onClick:t[1]||(t[1]=(...e)=>u.togglePin&&u.togglePin(...e))},[u.isPinned?((0,a.openBlock)(),(0,a.createBlock)(p,{key:0,class:"ff-icon"})):((0,a.openBlock)(),(0,a.createBlock)(h,{key:1,class:"ff-icon"}))],10,i)):(0,a.Q3)("v-if",!0),(0,a.Lk)("button",{class:"header-button",title:"Close Expert","data-el":"expert-drawer-close-button",onClick:t[2]||(t[2]=(...e)=>u.closeDrawer&&u.closeDrawer(...e))},[(0,a.createVNode)(g,{class:"ff-icon"})])])]),(0,a.createVNode)(f)],512)}],["__scopeId","data-v-83bf8a2c"]])},13810:function(e,t,s){s.r(t),s.d(t,{default:function(){return Ws}});var a=s(41425);const n={class:"ff-expert"},o={ref:"scrollAnchor",class:"scroll-anchor"};var r=s(10810);const l={class:"action-buttons"},i=["disabled"],c={class:"right-buttons"},d=["placeholder","disabled"],u={class:"actions"},m={class:"left overflow-hidden"},p={class:"right"},h=["disabled"];var g=s(82287);const f={class:"capabilities-selector"},k={style:{"min-width":"300px"}},v={class:"flex flex-col gap-1 flex-1 min-w-0"},b={class:"truncate",style:{"line-height":"16px"}},S={key:0,class:"text-gray-400 text-sm truncate leading-4"},C={class:"tool-count-badge self-start",title:"Tools"};var w=s(20487),y=s(34904),x=s(31911),B=s(63391),I={name:"CapabilitiesSelector",components:{FfCheckbox:y.A,ListboxOption:w.h7,FfListbox:x.A},computed:{...(0,r.aH)(B.W,["selectedCapabilities","capabilities"]),hasCapabilities(){return this.capabilities&&this.capabilities.length>0},capabilitiesHandler:{get(){return this.selectedCapabilities},set(e){this.setSelectedCapabilities(e)}}},methods:{...(0,r.i0)(B.W,["setSelectedCapabilities"]),onCheckboxClick(e){const t=e=>`${e.instance}::${e.mcpServerUrl}`,s=this.selectedCapabilities||[],a=s.some(s=>t(s)===t(e));this.capabilitiesHandler=a?s.filter(s=>t(s)!==t(e)):[...s,e]},getResourceTooltip(e){return[["MCP Server:",e.mcpServerName],["Instance:",e.instanceName],e.title?["Title:",e.title]:[],e.description?["Description:",e.description]:[],e.tools?.length?["Tools:",...e.tools.map(e=>e.name)]:null,e.resources?.length?["Resources:",...e.resources.map(e=>e.name)]:null,e.resourceTemplates?.length?["Resource Templates:",...e.resourceTemplates.map(e=>e.name)]:null].filter(Boolean).map(e=>e.join("\n")).join("\n\n")}}},A=s(66262),E=(0,A.A)(I,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("ff-checkbox"),i=(0,a.g2)("ListboxOption"),c=(0,a.g2)("ff-listbox");return(0,a.openBlock)(),(0,a.CE)("div",f,[(0,a.createVNode)(c,{modelValue:r.capabilitiesHandler,"onUpdate:modelValue":t[0]||(t[0]=e=>r.capabilitiesHandler=e),options:e.capabilities,disabled:!r.hasCapabilities,"return-model":"",multiple:"","label-key":"name","value-key":["instance","mcpServerUrl"],placeholder:"Resources","open-above":"","options-min-width":280,"align-right":""},{options:(0,a.k6)(({options:e})=>[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(e,e=>((0,a.openBlock)(),(0,a.createBlock)(i,{key:e.mcpServerName,as:"template",value:e,class:"ff-option ff-team-selection-option","data-option":e.mcpServerName,title:r.getResourceTooltip(e)},{default:(0,a.k6)(({active:t,selected:s})=>[(0,a.Lk)("li",k,[(0,a.Lk)("div",{class:(0,a.C4)(["ff-option-content flex truncate justify-start items-start! gap-2! p-2!",{active:t}]),"data-click-exclude":"right-drawer"},[(0,a.Lk)("div",null,[(0,a.createVNode)(l,{modelValue:s,onClick:(0,a.D$)(t=>r.onCheckboxClick(e),["stop","prevent"])},null,8,["modelValue","onClick"])]),(0,a.Lk)("div",v,[(0,a.Lk)("span",b,(0,a.v_)(e.title),1),e.title?((0,a.openBlock)(),(0,a.CE)("p",S,(0,a.v_)(e.mcpServerName),1)):(0,a.Q3)("v-if",!0)]),(0,a.Lk)("span",C,(0,a.v_)(e.toolCount),1)],2)])]),_:2},1032,["value","data-option","title"]))),128))]),_:1},8,["modelValue","options","disabled"])])}]]);const L={class:"context-selector-container"};var T=s(22511);const _=["title"],V={class:"text"},M={class:"icon-wrapper"};var P=s(52725),R=s(65428),O={name:"DefaultChip",components:{XMarkIcon:P.A,PlusIcon:R.A},props:{modelValue:{type:Boolean,required:!1,default:!0},text:{type:String,required:!1,default:""},title:{type:String,required:!1,default:""}},emits:["toggle"],methods:{pluralize:T.td}},N=(0,A.A)(O,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("XMarkIcon"),i=(0,a.g2)("PlusIcon");return(0,a.openBlock)(),(0,a.CE)("div",{class:(0,a.C4)(["chip",{active:s.modelValue}]),title:s.title,onClick:t[0]||(t[0]=t=>e.$emit("toggle"))},[(0,a.Lk)("div",V,[(0,a.RG)(e.$slots,"text",{},()=>[(0,a.Lk)("span",null,(0,a.v_)(s.text),1)],!0)]),t[1]||(t[1]=(0,a.Lk)("span",{class:"separator"},null,-1)),(0,a.Lk)("div",M,[s.modelValue?((0,a.openBlock)(),(0,a.createBlock)(l,{key:0,class:"ff-icon ff-icon-sm"})):((0,a.openBlock)(),(0,a.createBlock)(i,{key:1,class:"ff-icon ff-icon-sm"}))])],10,_)}],["__scopeId","data-v-3c33e421"]]),F=s(78721),U={name:"ContextChip",components:{DefaultChip:N},props:{contextItem:{type:Object,required:!1,default:()=>({})}},computed:{...(0,r.aH)(F.u,["getSelectedContext"]),selectedContext(){return this.getSelectedContext},text(){return this.contextItem.name||"Unnamed Context"},title(){return this.contextItem.title||`Include ${this.contextItem.name} in context`}},methods:{...(0,r.i0)(F.u,["setSelectedContext"]),pluralize:T.td,toggleSelection(){const e=this.selectedContext.filter(e=>e.name!==this.contextItem.name);this.setSelectedContext(e)}}},$=(0,A.A)(U,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("default-chip");return(0,a.openBlock)(),(0,a.createBlock)(l,{modelValue:!!s.contextItem,text:r.text,title:r.title,onToggle:r.toggleSelection},null,8,["modelValue","text","title","onToggle"])}]]);const W=["title"];var H={name:"DebugChip",components:{DefaultChip:N},props:{modelValue:{type:Boolean,required:!1,default:!0}},emits:["update:modelValue"],computed:{...(0,r.aH)(F.u,["debugLog"]),selectedCounter(){return this.debugLog.length},selectionTitle(){const e={};return this.debugLog.forEach(t=>{e[t.type]=(e[t.type]??0)+1}),`Selected Logs: \n${this.debugLog.map((e,t)=>{const s=(e=e||{}).level||"",a="debug"!==s?s:"",n=e.metadata?.topic||"",o=e.source?.name||e.source?.id||e.metadata?.path||"",r=e.metadata?.format||"",l=e.source?.type||"",i=e.metadata?.property||"",c=[];return o&&c.push(`node: ${o}`),n&&c.push(`topic: ${n}`),a&&l&&c.push(`${l} : (${a})`),i&&(r?c.push(`property: ${i} ${r}`):c.push(`property: ${i}`)),`${t+1}: ${c.join(", ")}`}).join("\n")}`}},methods:{...(0,r.i0)(F.u,["resetDebugLogContext"]),pluralize:T.td,toggleSelection(){this.$emit("update:modelValue",!this.modelValue),this.resetDebugLogContext()}}},Q=(0,A.A)(H,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("default-chip");return(0,a.openBlock)(),(0,a.createBlock)(l,{class:"flow-selection-button",modelValue:s.modelValue,onToggle:r.toggleSelection},{text:(0,a.k6)(()=>[t[0]||(t[0]=(0,a.Lk)("span",null,"Debug",-1)),(0,a.Lk)("span",{class:"counter italic",title:r.selectionTitle},"( "+(0,a.v_)(r.selectedCounter)+" "+(0,a.v_)(r.pluralize("log",r.selectedCounter))+" )",9,W)]),_:1},8,["modelValue","onToggle"])}]]);const D=["title"];var q={name:"SelectionChip",components:{DefaultChip:N},props:{modelValue:{type:Boolean,required:!1,default:!0}},emits:["update:modelValue"],computed:{...(0,r.aH)(F.u,["selectedNodes"]),filteredSelectedNodes(){return this.selectedNodes.filter(e=>!["global-config"].includes(e.type))},selectedCounter(){return this.filteredSelectedNodes.length},selectionTitle(){const e={};return this.filteredSelectedNodes.forEach(t=>{e[t.type]=(e[t.type]??0)+1}),`Selected nodes: \n${Object.keys(e).map(t=>`${e[t]} x ${t}`).join("\n")}`}},methods:{...(0,r.i0)(F.u,["setSelectedNodes"]),pluralize:T.td,toggleSelection(){this.$emit("update:modelValue",!this.modelValue),this.setSelectedNodes([])}}},z=(0,A.A)(q,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("default-chip");return(0,a.openBlock)(),(0,a.createBlock)(l,{class:"flow-selection-button",modelValue:s.modelValue,onToggle:r.toggleSelection},{text:(0,a.k6)(()=>[t[0]||(t[0]=(0,a.Lk)("span",null,"Selection",-1)),(0,a.Lk)("span",{class:"counter italic",title:r.selectionTitle},"( "+(0,a.v_)(r.selectedCounter)+" "+(0,a.v_)(r.pluralize("node",r.selectedCounter))+" )",9,D)]),_:1},8,["modelValue","onToggle"])}]]);const j={class:"context-selector mr-2"};var K=s(9080),G=s(81429),J=s(41541),Y=s(26218),X={name:"ContextSelectorButton",components:{PaperClipIcon:K.A},data(){return{selectedContextItems:[]}},computed:{...(0,r.aH)(F.u,["availableContextOptions","getSelectedContext"]),hasContextOptions(){return this.contextOptions?.length>0},hasSelection(){return this.selectedContext?.length>0},selectedContext(){return this.getSelectedContext},contextOptions:{get(){return this.availableContextOptions.map(e=>{let t=G.A;return"CubeIcon"===e.menuIcon?t=J.A:"Bars4Icon"===e.menuIcon&&(t=Y.A),{...e,icon:t}})}}},methods:{pluralize:T.td,...(0,r.i0)(F.u,["setSelectedContext"]),selectItem(e){if(e.onSelectAction)(0,F.u)()[e.onSelectAction]();else{const t=e=>({value:e.value,name:e.name,label:e.label,icon:e.icon}),s=t(e),a=this.selectedContext||[];if(a.some(e=>e.value===s.value))return;this.setSelectedContext([...a,s].filter(Boolean))}}}},Z=(0,A.A)(X,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("PaperClipIcon"),i=(0,a.g2)("ff-listbox");return(0,a.openBlock)(),(0,a.CE)("div",j,[(0,a.createVNode)(i,{modelValue:o.selectedContextItems,"onUpdate:modelValue":t[0]||(t[0]=e=>o.selectedContextItems=e),class:(0,a.C4)(["context-selector",r.hasSelection?"active":""]),options:r.contextOptions,disabled:!r.hasContextOptions,"hide-chevron":!0,"icon-only":!0,"return-model":"","label-key":"label",placeholder:"Context","open-above":"","options-min-width":250,"align-right":"",onOptionSelected:r.selectItem},{icon:(0,a.k6)(()=>[(0,a.createVNode)(l,{class:"icon ff-icon ff-icon-sm"})]),_:1},8,["modelValue","class","options","disabled","onOptionSelected"])])}]]),ee=s(96825),te={name:"ContextSelector",components:{ContextChip:$,DebugChip:Q,SelectionChip:z,ContextSelectorButton:Z},computed:{...(0,r.aH)(F.u,["getSelectedContext","hasDebugLogsSelected","hasUserSelection"]),...(0,r.aH)(ee.i,["isInsightsAgent"]),selectedContext(){return this.isInsightsAgent?[]:this.getSelectedContext},selectedContextFiltered(){return this.selectedContext.filter(e=>!1!==e.showAsChip)}},methods:{horizontalScrolling(e){const t=e.currentTarget;0!==e.deltaY&&(e.preventDefault(),t.scrollLeft+=e.deltaY/2)}}},se=(0,A.A)(te,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("context-selector-button"),i=(0,a.g2)("context-chip"),c=(0,a.g2)("debug-chip"),d=(0,a.g2)("selection-chip");return(0,a.openBlock)(),(0,a.CE)("div",L,[e.isInsightsAgent?(0,a.Q3)("v-if",!0):((0,a.openBlock)(),(0,a.createBlock)(l,{key:0})),(0,a.Lk)("div",{class:"chips-container",onWheel:t[0]||(t[0]=(...e)=>r.horizontalScrolling&&r.horizontalScrolling(...e))},[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(r.selectedContextFiltered,(e,t)=>((0,a.openBlock)(),(0,a.createBlock)(i,{key:t,contextItem:e},null,8,["contextItem"]))),128)),e.hasDebugLogsSelected&&!e.isInsightsAgent?((0,a.openBlock)(),(0,a.createBlock)(c,{key:0})):(0,a.Q3)("v-if",!0),e.hasUserSelection&&!e.isInsightsAgent?((0,a.openBlock)(),(0,a.createBlock)(d,{key:1})):(0,a.Q3)("v-if",!0)],32)])}],["__scopeId","data-v-104983ce"]]),ae=s(28409),ne={name:"ExpertChatInput",components:{CapabilitiesSelector:E,ContextSelector:se,ResizeBar:g.A},inject:{togglePinWithWidth:{from:"togglePinWithWidth",default:()=>()=>{}}},emits:["send","stop"],setup(){const{startResize:e,heightStyle:t,bindResizer:s,isResizing:n}=function(){const e=(0,a.KR)(window.innerWidth),t=(0,a.KR)(window.innerHeight),s=(0,a.KR)(0),n=(0,a.KR)(0),o=(0,a.KR)(0),r=(0,a.KR)(0),l=(0,a.KR)(0),i=(0,a.KR)(1),c=(0,a.KR)(1),d=(0,a.KR)(!1);let u=0,m=0,p=0,h=0;const g=(0,a.KR)(0),f=(0,a.KR)(0);function k(){d.value=!1,document.removeEventListener("mousemove",v),document.removeEventListener("mouseup",k)}function v(a){if(d.value){const l=a.clientX-u,i=a.clientY-m,c=p+l,d=h-i;g.value=Math.min(Math.max(s.value,c),e.value-o.value),f.value=Math.min(Math.max(n.value,d),t.value-r.value)}}return{heightStyle:(0,a.EW)(()=>t.value<l.value?`${Math.min(f.value,t.value)}px`:`${Math.min(f.value,t.value*c.value)}px`),widthStyle:(0,a.EW)(()=>e.value<l.value?`${Math.min(g.value,e.value)}px`:`${Math.min(g.value,e.value*i.value)}px`),isResizing:(0,a.EW)(()=>d.value),startResize:function(e){d.value=!0,u=e.clientX,m=e.clientY,p=g.value,h=f.value,document.addEventListener("mousemove",v),document.addEventListener("mouseup",k)},stopResize:k,bindResizer:function({component:e=null,initialWidth:t=0,initialHeight:a=0,minWidth:d,minHeight:u,maxViewportMarginX:m,maxViewportMarginY:p,mobileBreakpoint:h=640,maxWidthRatio:k,maxHeightRatio:v}={}){let b=t,S=a;if(e){const s=e.$el||e;if(s&&s.getBoundingClientRect){const e=s.getBoundingClientRect();b=t||e.width,S=a||e.height}}f.value=S,g.value=b,s.value=d,n.value=u,o.value=m,r.value=p,l.value=h??0,i.value=k??1,c.value=v??1},setWidth:function(e){g.value=e},setHeight:function(e){f.value=e}}}();return{startResize:e,bindResizer:s,heightStyle:t,isInputResizing:n}},data(){return{inputText:"",includeSelection:!0,isTextareaFocused:!1}},computed:{...(0,r.aH)(F.u,["isImmersiveInstance","isImmersiveDevice"]),...(0,r.aH)(ae.W,["rightDrawer"]),...(0,r.aH)(ee.i,["messages","isSessionExpired","isInsightsAgent","hasSelectedCapabilities","hasMessages","isWaitingForResponse"]),isInputDisabled(){return!!this.isSessionExpired||!!this.isWaitingForResponse||this.isInsightsAgent&&!this.hasSelectedCapabilities},isDrawerPinned(){return this.rightDrawer.fixed},canSend(){return this.inputText.trim().length>0&&!this.isInputDisabled},placeholderText(){return this.isInsightsAgent&&!this.hasSelectedCapabilities?"Select a resource to get started":this.isInsightsAgent?"Tell us what you want to know about":"Tell us what you need help with"},isImmersive(){return this.isImmersiveDevice||this.isImmersiveInstance}},mounted(){this.bindResizer({component:this.$refs.resizeTarget,maxHeightRatio:.9,minHeight:120,maxViewportMarginY:80})},methods:{...(0,r.i0)(F.u,["resetContextSelection"]),...(0,r.i0)(ee.i,["startOver","handleQuery","handleMessageResponse"]),async handleSend(){if(!this.canSend)return;const e=this.inputText.trim();this.isDrawerPinned||0!==this.messages.length||this.togglePinWithWidth(),this.handleQuery({query:e}).then(e=>this.handleMessageResponse(e)).then(()=>{this.$nextTick(()=>{this.$refs.textarea.focus()})}).catch(e=>e),this.inputText=""},handleStop(){this.$emit("stop")},handleStartOver(){this.hasMessages&&(this.inputText="",this.isInsightsAgent||this.resetContextSelection(),this.startOver())},handleKeydown(e){"Enter"!==e.key||e.shiftKey||(e.preventDefault(),this.handleSend())}}},oe=(0,A.A)(ne,[["render",function(e,t,s,n,o,r){const g=(0,a.g2)("resize-bar"),f=(0,a.g2)("capabilities-selector"),k=(0,a.g2)("context-selector");return(0,a.openBlock)(),(0,a.CE)("div",{ref:"resizeTarget",class:"ff-expert-input",style:(0,a.Tr)({height:n.heightStyle})},[(0,a.createVNode)(g,{"is-resizing":n.isInputResizing,direction:"horizontal",onMousedown:n.startResize},null,8,["is-resizing","onMousedown"]),(0,a.Q3)(" Action buttons row "),(0,a.Lk)("div",l,[(0,a.Lk)("button",{type:"button",class:"btn-start-over",disabled:e.isWaitingForResponse&&!e.isSessionExpired,onClick:t[0]||(t[0]=(...e)=>r.handleStartOver&&r.handleStartOver(...e))}," Start over ",8,i),(0,a.Lk)("div",c,[e.isInsightsAgent?((0,a.openBlock)(),(0,a.createBlock)(f,{key:0})):(0,a.Q3)("v-if",!0)])]),(0,a.Lk)("div",{class:(0,a.C4)(["input-wrapper",{focused:o.isTextareaFocused}])},[(0,a.Q3)(" Textarea "),(0,a.bo)((0,a.Lk)("textarea",{ref:"textarea","onUpdate:modelValue":t[1]||(t[1]=e=>o.inputText=e),class:"chat-input",placeholder:r.placeholderText,disabled:r.isInputDisabled,onKeydown:t[2]||(t[2]=(...e)=>r.handleKeydown&&r.handleKeydown(...e)),onFocus:t[3]||(t[3]=e=>o.isTextareaFocused=!0),onBlur:t[4]||(t[4]=e=>o.isTextareaFocused=!1)},null,40,d),[[a.Jo,o.inputText]]),(0,a.Lk)("div",u,[(0,a.Lk)("div",m,[r.isImmersive&&!e.isInsightsAgent?((0,a.openBlock)(),(0,a.createBlock)(k,{key:0})):(0,a.Q3)("v-if",!0)]),(0,a.Lk)("div",p,[e.isWaitingForResponse&&!e.isSessionExpired?((0,a.openBlock)(),(0,a.CE)("button",{key:0,type:"button",class:"btn-stop",onClick:t[5]||(t[5]=(...e)=>r.handleStop&&r.handleStop(...e))}," Stop ")):e.isSessionExpired?(0,a.Q3)("v-if",!0):((0,a.openBlock)(),(0,a.CE)("button",{key:1,type:"button",class:"btn-send",disabled:!r.canSend,onClick:t[6]||(t[6]=(...e)=>r.handleSend&&r.handleSend(...e))}," Send ",8,h))])])],2)],4)}],["__scopeId","data-v-6e8fca3f"]]);const re={ref:"messagesWrapper",class:"messages-wrapper"},le={class:"flex flex-col gap-3"},ie={key:0},ce={class:"ff-expert-loading"},de={key:0,class:"loading-message"};var ue=s(2e3),me={name:"ExpertLoadingIndicator",data(){return{showMessage:!1,currentMessageIndex:0,messageVariants:{[ue.C]:["Ingesting the docs...","Reading the blog...","Searching through FlowFuse knowledge base","Analyzing your question...","Finding the best answer..."],[ue.q]:["Connecting to MCP resources...","Querying your Node-RED instances...","Instructing MCP tooling...","Ingesting responses...","Gathering insights...","Considering instructions...","Processing user response..."],transfer:["Catching up with new context...","Syncing your conversation...","Loading existing history...","Preparing your chat..."]},messageTimer:null,rotationTimer:null}},computed:{...(0,r.aH)(ee.i,["loadingVariant","inFlightUpdates"]),messages(){return this.inFlightUpdates.length>0?this.inFlightUpdates:this.messageVariants[this.loadingVariant]},currentMessage(){return this.messages[this.currentMessageIndex]}},mounted(){this.messageTimer=setTimeout(()=>{this.showMessage=!0,this.rotationTimer=setInterval(()=>{this.currentMessageIndex=(this.currentMessageIndex+1)%this.messages.length},3e3)},5e3)},beforeUnmount(){this.messageTimer&&clearTimeout(this.messageTimer),this.rotationTimer&&clearInterval(this.rotationTimer)}},pe=(0,A.A)(me,[["render",function(e,t,s,n,o,r){return(0,a.openBlock)(),(0,a.CE)("div",ce,[t[0]||(t[0]=(0,a.Lk)("div",{class:"loading-dots"},[(0,a.Lk)("div",{class:"loading-dot"}),(0,a.Lk)("div",{class:"loading-dot"}),(0,a.Lk)("div",{class:"loading-dot"})],-1)),o.showMessage?((0,a.openBlock)(),(0,a.CE)("div",de,(0,a.v_)(r.currentMessage),1)):(0,a.Q3)("v-if",!0)])}],["__scopeId","data-v-987264e4"]]);const he={class:"flex flex-col gap-3"};var ge=s(99900);const fe={class:"guide-badge"};var ke={name:"AnswerBadge",props:{kind:{required:!0,type:String}},computed:{title(){return"resources"===this.kind?"Resources":"Setup Guide"}}},ve=(0,A.A)(ke,[["render",function(e,t,s,n,o,r){return(0,a.openBlock)(),(0,a.CE)("div",fe,[(0,a.Lk)("span",null,(0,a.v_)(r.title),1)])}],["__scopeId","data-v-7d8bb1a7"]]);const be={key:0,class:"guide-header"},Se={class:"guide-title"},Ce={key:0,class:"guide-summary"},we=["innerHTML"];var ye=s(50011),xe=s(69510),Be=s(92753),Ie=s(27402),Ae=s(85262),Ee=s(95387),Le=s(69359),Te=s(60023);ye.A.registerLanguage("bash",xe.A),ye.A.registerLanguage("shell",xe.A),ye.A.registerLanguage("css",Be.A),ye.A.registerLanguage("javascript",Ee.A),ye.A.registerLanguage("js",Ee.A),ye.A.registerLanguage("json",Ie.A),ye.A.registerLanguage("python",Ae.A),ye.A.registerLanguage("py",Ae.A),ye.A.registerLanguage("typescript",Ee.A),ye.A.registerLanguage("ts",Ee.A),ye.A.registerLanguage("xml",Le.A),ye.A.registerLanguage("html",Le.A);const _e='<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" aria-hidden="true"><path stroke-linecap="round" stroke-linejoin="round" d="M8 16H6a2 2 0 01-2-2V6a2 2 0 012-2h8a2 2 0 012 2v2m-6 12h8a2 2 0 002-2v-8a2 2 0 00-2-2h-8a2 2 0 00-2 2v8a2 2 0 002 2z"/></svg>',Ve=_e;function Me({delayMs:e=30,splitRegex:t=/\s+/,joinWith:s=" "}={}){const n=(0,a.KR)(""),o=(0,a.KR)(!1);let r=null,l=[],i=0;const c=()=>{r&&clearTimeout(r),r=null,o.value=!1,l=[],i=0};return(0,a.xo)(c),{text:n,isStreaming:o,stream:(d="")=>(c(),n.value="",l=String(d).trim().split(t).filter(Boolean),i=0,o.value=!0,new Promise(t=>{const c=async()=>o.value?i>=l.length?(await(0,a.dY)(),o.value=!1,t()):(n.value+=(n.value?s:"")+l[i],i+=1,void(r=setTimeout(c,e))):t();c()})),stop:c}}var Pe={name:"StreamableContent",props:{modelValue:{type:Object,required:!1,default:null,validate(e,t){return t.string||e?!(!e||"object"!=typeof e)&&"string"==typeof e.streamable&&"boolean"==typeof e.streamed:(console.warn("StreamableContent: string prop is required when modelValue is null"),!1)}},string:{required:!1,type:String,default:null,validator(e,t){return!(!t.modelValue&&!e&&(console.warn("StreamableContent: string prop is required when modelValue is null"),1))}},shouldStream:{required:!1,type:Boolean,default:!0},richContent:{type:Boolean,required:!1,default:!1}},emits:["streaming-complete","update:modelValue"],setup(){const{stream:e,text:t,isStreaming:s}=Me({delayMs:30}),{markedInstance:a}=function(){const e=new Te.Dz({breaks:!0,gfm:!0});return e.use({renderer:{code({text:e,lang:t}){const s=t?t.split(/\s/)[0].toLowerCase():"";let a;return a=s&&ye.A.getLanguage(s)?ye.A.highlight(e,{language:s}).value:ye.A.highlightAuto(e).value,`<div class="ff-code-block"><div class="ff-code-block--header">${s?`<span class="ff-code-block--lang">${s}</span>`:""}<button class="ff-code-block--copy">${_e}</button></div><pre><code class="hljs">${a.replace(/\n/g,"&#10;")}</code></pre></div>`}}}),{markedInstance:e}}();return{stream:e,streamedText:t,isStreaming:s,sanitize:T.aj,markedInstance:a}},computed:{...(0,r.aH)(F.u,["supportedActions"]),rawText(){const e=this.modelValue?this.modelValue.streamable:this.string;return this.richContent?this.markedInstance.parse(e||""):e},text(){const e=this.shouldStream?this.streamedText:this.rawText;return this.sanitize(e,{supportedActions:this.supportedActions,targetBlank:!0,appendQueryParameters:{utm_source:"flowfuse-expert",utm_medium:"assistant",utm_campaign:"expert-chat"}})}},watch:{isStreaming(e){e||(this.$emit("streaming-complete"),this.modelValue&&this.$emit("update:modelValue",{...this.modelValue,streamed:!0}))}},mounted(){this.shouldStream&&this.stream(this.rawText)},methods:{handleClick(e){const t=e.target.closest(".ff-code-block--copy");if(!t)return;const s=t.closest(".ff-code-block")?.querySelector("pre code");s&&navigator.clipboard.writeText(s.textContent||"").then(()=>{t.innerHTML='<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" aria-hidden="true"><path stroke-linecap="round" stroke-linejoin="round" d="M5 13l4 4L19 7"/></svg>',setTimeout(()=>{t.innerHTML=Ve},2e3)}).catch(()=>{const e=document.createElement("textarea");e.value=s.textContent||"",e.style.position="fixed",e.style.left="-999999px",document.body.appendChild(e),e.select(),document.execCommand("copy"),document.body.removeChild(e)})}}},Re=(0,A.A)(Pe,[["render",function(e,t,s,n,o,r){return(0,a.openBlock)(),(0,a.CE)("div",(0,a.v6)({class:"streamable-content"},(0,a.Tb)(s.richContent?{click:r.handleClick}:{},!0)),[s.richContent?((0,a.openBlock)(),(0,a.CE)(a.FK,{key:1},[(0,a.Q3)(" eslint-disable-next-line vue/no-v-html "),((0,a.openBlock)(),(0,a.CE)("div",{key:r.text,innerHTML:r.text},null,8,we))],64)):((0,a.openBlock)(),(0,a.CE)("span",{key:r.text},(0,a.v_)(r.text),1))],16)}],["__scopeId","data-v-e45de422"]]),Oe={name:"GuideHeader",components:{StreamableContent:Re},props:{title:{type:String,required:!0},summary:{type:[String,null],required:!1,default:null},shouldStream:{type:Boolean,default:!1}},emits:["streaming-complete"],data(){return{streamableSummary:{streamable:this.summary,streamed:!1},streamableTitle:{streamable:this.title,streamed:!1}}},watch:{streamableSummary(e){e.streamed&&this.$emit("streaming-complete")},streamableTitle(e){!this.summary&&e.streamed&&this.$emit("streaming-complete")}}},Ne=(0,A.A)(Oe,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content");return(0,a.openBlock)(),(0,a.CE)(a.FK,null,[(0,a.Q3)(" Title and Summary "),s.title?((0,a.openBlock)(),(0,a.CE)("div",be,[(0,a.Lk)("h3",Se,[(0,a.createVNode)(l,{modelValue:o.streamableTitle,"onUpdate:modelValue":t[0]||(t[0]=e=>o.streamableTitle=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])]),s.summary?((0,a.openBlock)(),(0,a.CE)("p",Ce,[!s.shouldStream||o.streamableTitle.streamed?((0,a.openBlock)(),(0,a.createBlock)(l,{key:0,modelValue:o.streamableSummary,"onUpdate:modelValue":t[1]||(t[1]=e=>o.streamableSummary=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])):(0,a.Q3)("v-if",!0)])):(0,a.Q3)("v-if",!0)])):(0,a.Q3)("v-if",!0)],2112)}],["__scopeId","data-v-7fe35b3c"]]),Fe={name:"MessageBubble",props:{type:{required:!0,type:String},variant:{required:!1,type:String,default:null}},computed:{isAiMessage(){return"ai"===this.type},isHumanMessage(){return"human"===this.type},isSystemMessage(){return"system"===this.type}}},Ue=(0,A.A)(Fe,[["render",function(e,t,s,n,o,r){return(0,a.openBlock)(),(0,a.CE)("div",{class:(0,a.C4)(["message-bubble flex flex-col gap-1",{"ai-message":r.isAiMessage,"human-message":r.isHumanMessage,"system-message":r.isSystemMessage,[`system-${s.variant}`]:s.variant}])},[(0,a.RG)(e.$slots,"default",{},void 0,!0)],2)}],["__scopeId","data-v-087440d9"]]);const $e={class:"guide-flows"},We={class:"section-title"},He={key:0,class:"resources-grid"};function Qe({intervalMs:e=350,shallow:t=!1}={}){const s=(0,a.KR)([]),n=(0,a.KR)([]),{doWhile:o}=(0,ge.A)(),r=(0,a.KR)(!1);async function l(a=[]){s.value=t?a.map(u):a,await o(()=>s.value.length!==n.value.length,async()=>{if(!Array.isArray(s.value)||0===s.value.length)return;const e=u(s.value[n.value.length]),a=c(),o=t?!!a?.streamed:Object.values(a??{}).every(e=>e.streamed);a?o&&n.value.push(e):n.value.push(e),n.value.length===s.value.length&&(r.value=!0)},{intervalMs:e})}function i(e){e.value=e,n.value=e.map(u),r.value=!1}function c(){return n.value[n.value.length-1]}function d(e,s){t?n.value[e].streamed=!0:n.value[e][s].streamed=!0}function u(e={}){return t?{...e,streamed:!1}:Object.fromEntries(Object.entries(e).map(([e,t])=>[e,{streamable:t,streamed:!1}]))}return{addItemsSequentially:l,addItems:i,initStreamer:async function(e,{shouldStream:t=!1}={}){if(!t)return i(e),Promise.resolve();await l(e)},hasFinishedStreaming:r,items:s,getLastVisibleItem:c,setSubItemStreamedState:d,updateCardStreamingState:function(e,t){Object.keys(e).forEach(e=>{d(t,e)})},visibleItems:n}}const De={class:"flex flex-col gap-3 p-3 bg-white border border-gray-200 rounded-lg"},qe={class:"flex items-start gap-2"},ze={class:"flex-1 flex flex-col gap-1 min-w-0"},je={class:"flex items-start justify-between gap-2"},Ke={class:"text-sm font-medium text-gray-900 overflow-hidden text-ellipsis whitespace-nowrap flex-1 min-w-0"},Ge={class:"flex items-start gap-2 shrink-0 -mt-1"},Je={key:0,class:"text-xs text-gray-500 overflow-hidden text-ellipsis whitespace-nowrap"};var Ye=s(72615),Xe=s(22118),Ze=s(45964),et=s(60926),tt={name:"StandardResourceCard",components:{StreamableContent:Re,TextCopier:Ze.A,FlowViewer:et.A,ChevronUpIcon:Ye.A,ChevronDownIcon:Xe.A},props:{flow:{type:Object,required:!0},shouldStream:{type:Boolean,required:!1,default:!1}},emits:["streaming-complete"],data(){return{flowsExpanded:!0,flowTitle:this.flow.title,flowUrl:this.flow.url,flowMetadata:this.flow.metadata}},computed:{...(0,r.aH)(ee.i,["canImportFlows"]),flowsJson(){return this.flowMetadata?JSON.stringify(this.flowMetadata.streamable.flows,null,2):""}},watch:{flowMetadata(e){e.streamed&&this.$emit("streaming-complete")}},methods:{...(0,r.i0)(F.u,["sendFlowsToImport"]),importFlows(){this.sendFlowsToImport(this.flowsJson)},completeStreaming(){this.flowMetadata&&(this.flowMetadata.streamed=!0),this.$emit("streaming-complete")}}},st={name:"ListFlows",components:{StreamableContent:Re,FlowResourceCard:(0,A.A)(tt,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content"),i=(0,a.g2)("chevron-down-icon"),c=(0,a.g2)("chevron-up-icon"),d=(0,a.g2)("text-copier"),u=(0,a.g2)("ff-button"),m=(0,a.g2)("flow-viewer");return(0,a.openBlock)(),(0,a.CE)("div",De,[(0,a.Lk)("div",qe,[t[4]||(t[4]=(0,a.Fv)('<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="none" viewBox="0 0 24 24" class="shrink-0 w-4 h-4 mt-0.5" data-v-7fbd3436><rect width="24" height="24" fill="var(--ff-color-icon-flow-bg)" rx="4" data-v-7fbd3436></rect><g clip-path="url(#a)" data-v-7fbd3436><path fill="var(--ff-color-icon-flow-fg)" d="M0 12v-1.647c5.09 0 5.81-.9 6.44-1.695.72-.9 1.46-1.6 3.88-1.6v1.648c-1.76 0-2.04.354-2.51.948C6.79 10.937 5.5 12 0 12Z" data-v-7fbd3436></path><path fill="var(--ff-color-icon-flow-fg)" d="M8.6 16.941c-2.9 0-3.47-1.513-3.88-2.614C4.25 13.072 3.85 12 0 12v-1.647c4.67 0 5.67 1.618 6.34 3.419.38 1.015.57 1.522 2.26 1.522v1.647Z" data-v-7fbd3436></path><path fill="var(--ff-color-icon-flow-fg)" d="M16.78 19H9.9c-.95 0-1.72-.737-1.72-1.647v-2.47c0-.91.77-1.648 1.72-1.648h6.88c.95 0 1.72.738 1.72 1.647v2.47c0 .91-.77 1.648-1.72 1.648Zm0-4.118H9.9v2.47h6.88v-2.47Zm1.5-4.117H11.4c-.95 0-1.72-.738-1.72-1.647v-2.47c0-.91.77-1.648 1.72-1.648h6.88c.95 0 1.72.737 1.72 1.647v2.47c0 .91-.77 1.648-1.72 1.648Zm0-4.118H11.4v2.47h6.88v-2.47Z" data-v-7fbd3436></path></g><defs data-v-7fbd3436><clipPath id="a" data-v-7fbd3436><path fill="var(--ff-color-icon-flow-fg)" d="M0 5h20v14H0z" data-v-7fbd3436></path></clipPath></defs></svg>',1)),(0,a.Lk)("div",ze,[(0,a.Lk)("div",je,[(0,a.Lk)("div",Ke,[(0,a.createVNode)(l,{modelValue:o.flowTitle,"onUpdate:modelValue":t[0]||(t[0]=e=>o.flowTitle=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])]),(0,a.Lk)("div",Ge,[(0,a.Lk)("button",{class:"text-gray-600 hover:text-indigo-600 hover:bg-indigo-50 flex items-center transition-colors duration-200 rounded-sm px-2 py-1",onClick:t[1]||(t[1]=e=>o.flowsExpanded=!o.flowsExpanded)},[t[2]||(t[2]=(0,a.Lk)("span",null,"Preview",-1)),o.flowsExpanded?((0,a.openBlock)(),(0,a.createBlock)(i,{key:0,class:"h-4 w-4"})):(0,a.Q3)("v-if",!0),o.flowsExpanded?(0,a.Q3)("v-if",!0):((0,a.openBlock)(),(0,a.createBlock)(c,{key:1,class:"h-4 w-4"}))]),e.canImportFlows?((0,a.openBlock)(),(0,a.createBlock)(u,{key:1,size:"small",kind:"secondary",onClick:r.importFlows},{default:(0,a.k6)(()=>[...t[3]||(t[3]=[(0,a.eW)("Import",-1)])]),_:1},8,["onClick"])):((0,a.openBlock)(),(0,a.createBlock)(d,{key:0,text:r.flowsJson,showText:!1},null,8,["text"]))])]),o.flowMetadata?((0,a.openBlock)(),(0,a.CE)("div",Je,[!s.shouldStream||o.flowTitle.streamed?((0,a.openBlock)(),(0,a.createBlock)(l,{key:0,string:o.flowMetadata.streamable.category,"should-stream":s.shouldStream,onStreamingComplete:r.completeStreaming},null,8,["string","should-stream","onStreamingComplete"])):(0,a.Q3)("v-if",!0)])):(0,a.Q3)("v-if",!0)])]),o.flowMetadata?((0,a.openBlock)(),(0,a.CE)("div",{key:0,class:(0,a.C4)(["flex overflow-auto ml-8 max-h-[500px] flex-col relative",{hidden:o.flowsExpanded}])},[o.flowsExpanded?(0,a.Q3)("v-if",!0):((0,a.openBlock)(),(0,a.createBlock)(m,{key:0,flow:s.flow.metadata.streamable.flows},null,8,["flow"]))],2)):(0,a.Q3)("v-if",!0)])}],["__scopeId","data-v-7fbd3436"]])},props:{flows:{type:Array,required:!0},shouldStream:{type:Boolean,default:!1}},emits:["streaming-complete"],setup(){const{initStreamer:e,updateCardStreamingState:t,visibleItems:s,items:a}=Qe();return{initStreamer:e,updateCardStreamingState:t,visibleItems:s,items:a}},data(){return{streamingTitle:{streamable:"Related Flows",streamed:!1}}},async mounted(){const e=this.flows.map(e=>({title:e.title,url:e.url,metadata:e.metadata}));await this.initStreamer(e,{shouldStream:this.shouldStream}),this.$emit("streaming-complete")}},at=(0,A.A)(st,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content"),i=(0,a.g2)("FlowResourceCard");return(0,a.openBlock)(),(0,a.CE)(a.FK,null,[(0,a.Q3)(" Resources Section "),(0,a.Lk)("div",$e,[(0,a.Lk)("h4",We,[(0,a.createVNode)(l,{modelValue:o.streamingTitle,"onUpdate:modelValue":t[0]||(t[0]=e=>o.streamingTitle=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])]),o.streamingTitle.streamed?((0,a.openBlock)(),(0,a.CE)("div",He,[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(n.visibleItems,(e,t)=>((0,a.openBlock)(),(0,a.createBlock)(i,{key:t,flow:e,"should-stream":s.shouldStream,onStreamingComplete:s=>n.updateCardStreamingState(e,t)},null,8,["flow","should-stream","onStreamingComplete"]))),128))])):(0,a.Q3)("v-if",!0)])],2112)}],["__scopeId","data-v-67b38b2a"]]);const nt={class:"guide-steps"},ot={class:"section-title"},rt={class:"steps-list"},lt={class:"step-number"},it={class:"step-content"},ct={class:"step-title"},dt={key:0,class:"step-detail"};var ut={name:"GuideStepsList",components:{StreamableContent:Re},props:{steps:{required:!0,type:Array},shouldStream:{type:Boolean,default:!1}},emits:["streaming-complete"],setup(){const{initStreamer:e,visibleItems:t}=Qe();return{initStreamer:e,visibleItems:t}},async mounted(){await this.initStreamer(this.steps,{shouldStream:this.shouldStream}),this.$emit("streaming-complete")}},mt=(0,A.A)(ut,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content");return(0,a.openBlock)(),(0,a.CE)("div",nt,[(0,a.Lk)("h4",ot,[(0,a.createVNode)(l,{string:"Steps:","should-stream":s.shouldStream},null,8,["should-stream"])]),(0,a.Lk)("ol",rt,[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(n.visibleItems,(e,t)=>((0,a.openBlock)(),(0,a.CE)("li",{key:t,class:"step-item"},[(0,a.Lk)("div",lt,(0,a.v_)(t+1),1),(0,a.Lk)("div",it,[(0,a.Lk)("h5",ct,[(0,a.createVNode)(l,{modelValue:e.title,"onUpdate:modelValue":t=>e.title=t,"should-stream":s.shouldStream},null,8,["modelValue","onUpdate:modelValue","should-stream"])]),!s.shouldStream||e.title.streamed?((0,a.openBlock)(),(0,a.CE)("p",dt,[(0,a.createVNode)(l,{modelValue:e.detail,"onUpdate:modelValue":t=>e.detail=t,"should-stream":s.shouldStream},null,8,["modelValue","onUpdate:modelValue","should-stream"])])):(0,a.Q3)("v-if",!0)])]))),128))])])}],["__scopeId","data-v-d910bc14"]]);const pt={class:"issues"};var ht={name:"IssuesList",components:{StreamableContent:Re},props:{issues:{type:Array,required:!0},shouldStream:{type:Boolean,default:!1}},emits:["streaming-complete"],setup(){const{initStreamer:e,setSubItemStreamedState:t,visibleItems:s,items:a}=Qe();return{initStreamer:e,setSubItemStreamedState:t,visibleItems:s,items:a,sanitize:T.aj}},data(){return{streamedTitle:{streamable:"Issues",streamed:!1}}},async mounted(){const e=this.issues.map(e=>({content:e}));await this.initStreamer(e,{shouldStream:this.shouldStream}),this.$emit("streaming-complete")}},gt=(0,A.A)(ht,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("exclamation-icon"),i=(0,a.g2)("streamable-content");return(0,a.openBlock)(),(0,a.CE)("div",pt,[(0,a.Lk)("h4",null,[(0,a.createVNode)(l,{class:"ff-icon"}),(0,a.createVNode)(i,{modelValue:o.streamedTitle,"onUpdate:modelValue":t[0]||(t[0]=e=>o.streamedTitle=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])]),(0,a.Lk)("ul",null,[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(n.visibleItems,(e,t)=>((0,a.openBlock)(),(0,a.CE)("li",{key:t},[(0,a.createVNode)(i,{"rich-content":!0,string:e.content.streamable,"should-stream":s.shouldStream,onStreamingComplete:e=>n.setSubItemStreamedState(t,"content")},null,8,["string","should-stream","onStreamingComplete"])]))),128))])])}],["__scopeId","data-v-95f9e4ca"]]);const ft={class:"guide-packages"},kt={class:"section-title"},vt={key:0,class:"packages-list"},bt=["href"],St=["src"],Ct={class:"package-info"},wt={class:"package-text"},yt=["title"],xt={class:"package-url"},Bt={class:"package-actions"};var It={name:"PackageResourceCard",components:{StreamableContent:Re},props:{nodePackage:{type:Object,required:!0},shouldStream:{type:Boolean,default:!1}},emits:["streaming-complete"],setup(e){const t=(0,a.EW)(()=>{const t=e.nodePackage;return"object"==typeof t?t.id.streamable||t.name.streamable:t}),s=(0,a.EW)(()=>{const s=e.nodePackage;return s?s.url.streamable||s.metadata?.streamable?.source||s.metadata?.streamable?.url||`https://flows.nodered.org/node/${t.value}`:"https://flows.nodered.org/"});return{packageName:t,packageUrl:s}},data(){return{streamablePackageName:{streamable:this.packageName,streamed:!1},streamablePackageUrl:{streamable:this.packageUrl,streamed:!1}}},computed:{...(0,r.aH)(ee.i,["canManagePalette"]),...(0,r.aH)(F.u,["palette"]),packageFaviconUrl(){const e=this.nodePackage.metadata?.streamable?.source||this.nodePackage.url.streamable;try{return`https://www.google.com/s2/favicons?domain=${new URL(e).hostname}`}catch(e){return"flows.nodered.org"}},isCorePackage(){return"core-node"===this.nodePackage.type.streamable||this.packageName.startsWith("node-red:")},isPackageInstalled(){const e=this.nodePackage;return!!this.palette?.[e.id.streamable]},urlWithUTMTracking(){const e=this.packageUrl;try{const t=new URL(e);return t.searchParams.set("utm_source","flowfuse-expert"),t.searchParams.set("utm_medium","assistant"),t.searchParams.set("utm_campaign","expert-chat"),t.toString()}catch(t){return e}}},watch:{streamablePackageUrl(e){e.streamed&&this.$emit("streaming-complete")}},methods:{...(0,r.i0)(F.u,["installNodePackage","manageNodePackage"]),handleImageError(e){e.target.style.display="none"},installPackage(){this.installNodePackage(this.packageName)},managePackage(){this.manageNodePackage(this.packageName)}}},At={name:"ListPackages",components:{StreamableContent:Re,PackageResourceCard:(0,A.A)(It,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content"),i=(0,a.g2)("ff-button");return(0,a.openBlock)(),(0,a.CE)("a",{href:r.urlWithUTMTracking,target:"_blank",rel:"noopener noreferrer",class:"package-card"},[(0,a.Lk)("img",{src:r.packageFaviconUrl,alt:"Node-RED",class:"package-favicon",onError:t[0]||(t[0]=(...e)=>r.handleImageError&&r.handleImageError(...e))},null,40,St),(0,a.Lk)("div",Ct,[(0,a.Lk)("div",wt,[(0,a.Lk)("div",{class:"package-name",title:n.packageName},[(0,a.createVNode)(l,{modelValue:o.streamablePackageName,"onUpdate:modelValue":t[1]||(t[1]=e=>o.streamablePackageName=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])],8,yt),(0,a.Lk)("div",xt,[!s.shouldStream||o.streamablePackageName.streamed?((0,a.openBlock)(),(0,a.createBlock)(l,{key:0,modelValue:o.streamablePackageUrl,"onUpdate:modelValue":t[2]||(t[2]=e=>o.streamablePackageUrl=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])):(0,a.Q3)("v-if",!0)])]),(0,a.Lk)("div",Bt,[e.canManagePalette&&!r.isCorePackage?((0,a.openBlock)(),(0,a.CE)(a.FK,{key:0},[r.isPackageInstalled?((0,a.openBlock)(),(0,a.createBlock)(i,{key:0,class:"w-20",size:"small",kind:"secondary",onClick:t[3]||(t[3]=(0,a.D$)(e=>r.managePackage(s.nodePackage),["stop","prevent"]))},{default:(0,a.k6)(()=>[...t[5]||(t[5]=[(0,a.eW)("Manage ",-1)])]),_:1})):((0,a.openBlock)(),(0,a.createBlock)(i,{key:1,class:"w-20",size:"small",kind:"secondary",onClick:t[4]||(t[4]=(0,a.D$)(e=>r.installPackage(s.nodePackage),["stop","prevent"]))},{default:(0,a.k6)(()=>[...t[6]||(t[6]=[(0,a.eW)("Install ",-1)])]),_:1}))],64)):(0,a.Q3)("v-if",!0)])])],8,bt)}],["__scopeId","data-v-2c4e6fb7"]])},props:{packages:{required:!0,type:Array},shouldStream:{type:Boolean,default:!1}},emits:["streaming-complete"],setup(){const{initStreamer:e,updateCardStreamingState:t,visibleItems:s,items:a}=Qe();return{initStreamer:e,updateCardStreamingState:t,visibleItems:s,items:a}},data(){return{packagesTitle:{streamable:"Required Node Packages",streamed:!1}}},async mounted(){const e=this.packages.map(e=>({id:e.id,name:e.name,title:e.title,url:e.url,type:e.type,metadata:e.metadata,hostname:e.hostname}));await this.initStreamer(e,{shouldStream:this.shouldStream}),this.$emit("streaming-complete")}},Et=(0,A.A)(At,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content"),i=(0,a.g2)("PackageResourceCard");return(0,a.openBlock)(),(0,a.CE)("div",ft,[(0,a.Lk)("h4",kt,[(0,a.createVNode)(l,{modelValue:o.packagesTitle,"onUpdate:modelValue":t[0]||(t[0]=e=>o.packagesTitle=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])]),!s.shouldStream||o.packagesTitle.streamed?((0,a.openBlock)(),(0,a.CE)("div",vt,[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(n.visibleItems,(e,t)=>((0,a.openBlock)(),(0,a.createBlock)(i,{key:t,nodePackage:e,"should-stream":s.shouldStream,onStreamingComplete:s=>n.updateCardStreamingState(e,t)},null,8,["nodePackage","should-stream","onStreamingComplete"]))),128))])):(0,a.Q3)("v-if",!0)])}],["__scopeId","data-v-3402c91e"]]);const Lt={key:0,class:"guide-resources"},Tt={class:"section-title"},_t={key:0,class:"resources-grid"},Vt=["href"],Mt=["src","alt"],Pt={class:"resource-info"},Rt=["title"],Ot={key:0,class:"resource-url"};var Nt={name:"StandardResourceCard",components:{StreamableContent:Re},props:{resource:{type:Object,required:!0},shouldStream:{type:Boolean,required:!1,default:!1}},emits:["streaming-complete"],data(){return{resourceUrl:this.resource.metadata?.streamable.source||this.resource.streamable.url,resourceTitle:{...this.resource.title},resourceMetadataSource:this.resource.metadata?.source}},computed:{favIconUrl(){const e=this.resourceUrl;try{return`https://www.google.com/s2/favicons?domain=${new URL(e).hostname}`}catch(e){return""}},urlWithUtmTracking(){const e=this.resourceUrl;try{const t=new URL(e);return t.searchParams.set("utm_source","flowfuse-expert"),t.searchParams.set("utm_medium","assistant"),t.searchParams.set("utm_campaign","expert-chat"),t.toString()}catch(t){return e}}},watch:{resourceTitle(e){e.streamed&&this.$emit("streaming-complete")}},methods:{handleImageError(e){e.target.style.display="none"}}},Ft={name:"ListResources",components:{StreamableContent:Re,StandardResourceCard:(0,A.A)(Nt,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content");return(0,a.openBlock)(),(0,a.CE)(a.FK,null,[(0,a.Q3)(" todo clean resource.url references after transitioning to v4 api "),(0,a.Lk)("a",{href:r.urlWithUtmTracking,target:"_blank",rel:"noopener noreferrer",class:"resource-card"},[(0,a.Lk)("img",{src:r.favIconUrl,alt:s.resource.type,class:"resource-icon",onError:t[0]||(t[0]=(...e)=>r.handleImageError&&r.handleImageError(...e))},null,40,Mt),(0,a.Lk)("div",Pt,[(0,a.Lk)("div",{class:"resource-title",title:o.resourceTitle.streamable},[(0,a.createVNode)(l,{modelValue:o.resourceTitle,"onUpdate:modelValue":t[1]||(t[1]=e=>o.resourceTitle=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])],8,Rt),!s.shouldStream||o.resourceTitle.streamed?((0,a.openBlock)(),(0,a.CE)("div",Ot,[o.resourceMetadataSource?((0,a.openBlock)(),(0,a.createBlock)(l,{key:0,modelValue:o.resourceMetadataSource,"onUpdate:modelValue":t[2]||(t[2]=e=>o.resourceMetadataSource=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])):s.resource.url?((0,a.openBlock)(),(0,a.createBlock)(l,{key:1,string:o.resourceUrl,"should-stream":s.shouldStream},null,8,["string","should-stream"])):(0,a.Q3)("v-if",!0)])):(0,a.Q3)("v-if",!0)])],8,Vt)],2112)}],["__scopeId","data-v-7aeaa1eb"]])},props:{resources:{type:Array,required:!0},shouldStream:{type:Boolean,default:!1}},emits:["streaming-complete"],setup(){const{initStreamer:e,updateCardStreamingState:t,visibleItems:s,items:a}=Qe();return{initStreamer:e,updateCardStreamingState:t,visibleItems:s,items:a}},data(){return{resourceTitle:{streamable:"Related Resources",streamed:!1}}},async mounted(){const e=this.resources.map(e=>({title:e.title,url:e.url,metadata:e.metadata}));await this.initStreamer(e,{shouldStream:this.shouldStream}),this.$emit("streaming-complete")}},Ut=(0,A.A)(Ft,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content"),i=(0,a.g2)("StandardResourceCard");return s.resources&&s.resources.length>0?((0,a.openBlock)(),(0,a.CE)("div",Lt,[(0,a.Lk)("h4",Tt,[(0,a.createVNode)(l,{modelValue:o.resourceTitle,"onUpdate:modelValue":t[0]||(t[0]=e=>o.resourceTitle=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])]),!s.shouldStream||o.resourceTitle.streamed?((0,a.openBlock)(),(0,a.CE)("div",_t,[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(n.visibleItems,(e,t)=>((0,a.openBlock)(),(0,a.createBlock)(i,{key:t,resource:e,"should-stream":s.shouldStream,onStreamingComplete:s=>n.updateCardStreamingState(e,t)},null,8,["resource","should-stream","onStreamingComplete"]))),128))])):(0,a.Q3)("v-if",!0)])):(0,a.Q3)("v-if",!0)}],["__scopeId","data-v-e0cd57b2"]]),$t={name:"RichContent",components:{StreamableContent:Re},props:{content:{required:!0,type:String},messageUuid:{required:!0,type:String},answerUuid:{required:!0,type:String},shouldStream:{required:!0,type:Boolean}},emits:["streaming-complete"],setup(){const{text:e,isStreaming:t,stream:s,stop:a}=Me({delayMs:30});return{sanitize:T.aj,text:e,isStreaming:t,stream:s,stop:a}},async mounted(){this.shouldStream||await this.onStreamComplete()},methods:{...(0,r.i0)(ee.i,["updateAnswerStreamedState"]),async onStreamComplete(){await this.updateAnswerStreamedState({messageUuid:this.messageUuid,answerUuid:this.answerUuid}),this.$emit("streaming-complete")}}},Wt=(0,A.A)($t,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content");return(0,a.openBlock)(),(0,a.createBlock)(l,{string:s.content,"should-stream":s.shouldStream,"rich-content":!0,onStreamingComplete:r.onStreamComplete},null,8,["string","should-stream","onStreamingComplete"])}]]);const Ht={class:"suggestions"},Qt={key:0};var Dt={name:"SuggestionsList",components:{StreamableContent:Re,InformationCircleIcon:s(14811).A},props:{suggestions:{type:Array,required:!0},shouldStream:{type:Boolean,default:!1}},emits:["streaming-complete"],setup(){const{initStreamer:e,setSubItemStreamedState:t,visibleItems:s,items:a}=Qe();return{initStreamer:e,setSubItemStreamedState:t,visibleItems:s,items:a}},data(){return{streamingTitle:{streamable:"Suggestions",streamed:!1}}},async mounted(){const e=this.suggestions.map(e=>({content:e}));await this.initStreamer(e,{shouldStream:this.shouldStream}),this.$emit("streaming-complete")}},qt={name:"AnswerWrapper",components:{SuggestionsList:(0,A.A)(Dt,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("information-circle-icon"),i=(0,a.g2)("streamable-content");return(0,a.openBlock)(),(0,a.CE)("div",Ht,[(0,a.Lk)("h4",null,[(0,a.createVNode)(l,{class:"ff-icon"}),(0,a.createVNode)(i,{modelValue:o.streamingTitle,"onUpdate:modelValue":t[0]||(t[0]=e=>o.streamingTitle=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])]),!s.shouldStream||o.streamingTitle.streamed?((0,a.openBlock)(),(0,a.CE)("ul",Qt,[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(n.visibleItems,(e,t)=>((0,a.openBlock)(),(0,a.CE)("li",{key:t},[(0,a.createVNode)(i,{"rich-content":!0,string:e.content.streamable,"should-stream":s.shouldStream,onStreamingComplete:e=>n.setSubItemStreamedState(t,"content")},null,8,["string","should-stream","onStreamingComplete"])]))),128))])):(0,a.Q3)("v-if",!0)])}],["__scopeId","data-v-be07e6bc"]]),RichContent:Wt,PackagesList:Et,FlowsList:at,AnswerBadge:ve,ResourcesList:Ut,GuideStepsList:mt,MessageBubble:Ue,GuideHeader:Ne,IssuesList:gt},props:{answer:{type:Object,required:!0},messageUuid:{type:String,required:!0}},emits:["streaming-complete"],setup(){const{waitFor:e}=(0,ge.A)();return{waitFor:e}},data(){return{componentStreamingOrder:[],streamedComponents:[]}},computed:{...(0,r.aH)(F.u,["supportedActions"]),...(0,r.aH)(ee.i,["agentMode"]),hasGuideHeader(){return!(!this.answer.title||this.isChatAnswer)},hasGuideSteps(){return Object.hasOwnProperty.call(this.answer,"steps")&&this.answer.steps.length>0},hasResources(){return Object.hasOwnProperty.call(this.answer,"resources")&&this.answer.resources.length>0},hasNodePackages(){return this.answer.nodePackages&&this.answer.nodePackages.length>0},hasFlows(){return this.answer.flows&&this.answer.flows.length>0},hasSuggestions(){return this.answer.suggestions&&this.answer.suggestions.length>0},hasIssues(){return this.answer.issues&&this.answer.issues.length>0},hasPlainContent(){return this.answer.content&&this.answer.content.length>0},isChatAnswer(){return!Object.hasOwnProperty.call(this.answer,"kind")||"chat"===this.answer.kind},isEditorContext(){return this.$route?.name?.includes("editor")||!1},shouldShowRichContent(){const e="rich-content";return!!this.componentStreamingOrder.includes(e)&&!!this.hasPlainContent&&(0===this.componentStreamingOrder.indexOf(e)||this.streamedComponents.length>=this.componentStreamingOrder.indexOf(e))},shouldShowGuideHeader(){const e="guide-header";return!!this.componentStreamingOrder.includes(e)&&!!this.hasGuideHeader&&(0===this.componentStreamingOrder.indexOf(e)||this.streamedComponents.length>=this.componentStreamingOrder.indexOf(e))},shouldShowGuideStepList(){const e="guide-steps-list";return!!this.componentStreamingOrder.includes(e)&&!!this.hasGuideSteps&&(0===this.componentStreamingOrder.indexOf(e)||this.streamedComponents.length>=this.componentStreamingOrder.indexOf(e))},shouldShowResourcesList(){const e="resources-list";return!!this.componentStreamingOrder.includes(e)&&!!this.hasResources&&(0===this.componentStreamingOrder.indexOf(e)||this.streamedComponents.length>=this.componentStreamingOrder.indexOf(e))},shouldShowFlowsList(){const e="flows-list";return!!this.componentStreamingOrder.includes(e)&&!!this.hasFlows&&(0===this.componentStreamingOrder.indexOf(e)||this.streamedComponents.length>=this.componentStreamingOrder.indexOf(e))},shouldShowPackagesList(){const e="packages-list";return!!this.componentStreamingOrder.includes(e)&&!!this.hasNodePackages&&(0===this.componentStreamingOrder.indexOf(e)||this.streamedComponents.length>=this.componentStreamingOrder.indexOf(e))},shouldShowSuggestionsList(){const e="suggestions-list";return!!this.componentStreamingOrder.includes(e)&&!!this.hasSuggestions&&(0===this.componentStreamingOrder.indexOf(e)||this.streamedComponents.length>=this.componentStreamingOrder.indexOf(e))},shouldShowIssuesList(){const e="issues-list";return!!this.componentStreamingOrder.includes(e)&&!!this.hasIssues&&(0===this.componentStreamingOrder.indexOf(e)||this.streamedComponents.length>=this.componentStreamingOrder.indexOf(e))},shouldStream(){return!this.answer._streamed}},watch:{streamedComponents(){this.componentStreamingOrder.length===this.streamedComponents.length&&(this.updateAnswerStreamedState({messageUuid:this.messageUuid,answerUuid:this.answer._uuid}),this.$emit("streaming-complete"))}},beforeUnmount(){this.updateAnswerStreamedState({messageUuid:this.messageUuid,answerUuid:this.answer._uuid,agent:this.agentMode}),this.isEditorContext&&this.$refs.messageBubble.$el.removeEventListener("click",this.handleClick)},mounted(){this.buildStreamingOrder(),this.isEditorContext&&this.$refs.messageBubble.$el.addEventListener("click",this.handleClick)},methods:{...(0,r.i0)(ee.i,["updateAnswerStreamedState"]),buildStreamingOrder(){this.hasPlainContent&&this.componentStreamingOrder.push("rich-content"),this.hasGuideHeader&&this.componentStreamingOrder.push("guide-header"),this.hasGuideSteps&&this.componentStreamingOrder.push("guide-steps-list"),this.hasResources&&this.componentStreamingOrder.push("resources-list"),this.hasFlows&&this.componentStreamingOrder.push("flows-list"),this.hasNodePackages&&this.componentStreamingOrder.push("packages-list"),this.hasIssues&&this.componentStreamingOrder.push("issues-list"),this.hasSuggestions&&this.componentStreamingOrder.push("suggestions-list")},async onComponentComplete(e){this.shouldStream||await this.waitFor(200),this.streamedComponents.push(e)},handleClick(e){const t=e.target;if(!this.isEditorContext)return;if(!t)return;if("A"!==t.nodeName)return;if(!t.classList.contains("assistant-action-link"))return;if(!t.getAttribute("data-assistant-action-href"))return;if(!t.getAttribute("data-action"))return;const s=t.getAttribute("data-action"),a=this.supportedActions?.[s];if(!a)return;e.preventDefault(),e.stopPropagation();const n={};for(const e of t.attributes)if(e.name.startsWith("data-param-")){const t=e.name.replace("data-param-",""),s=a.params?.properties?.[t];if(!s)continue;const o=s.type;let r=e.value;"boolean"===o?r="true"===r:"number"===o&&(r=+r),n[t]=r}(0,F.u)().invokeAction({action:s,params:n})}}},zt=(0,A.A)(qt,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("answer-badge"),i=(0,a.g2)("rich-content"),c=(0,a.g2)("guide-header"),d=(0,a.g2)("guide-steps-list"),u=(0,a.g2)("resources-list"),m=(0,a.g2)("flows-list"),p=(0,a.g2)("packages-list"),h=(0,a.g2)("issues-list"),g=(0,a.g2)("suggestions-list"),f=(0,a.g2)("message-bubble");return(0,a.openBlock)(),(0,a.createBlock)(f,{ref:"messageBubble",type:"ai"},{default:(0,a.k6)(()=>[r.isChatAnswer?(0,a.Q3)("v-if",!0):((0,a.openBlock)(),(0,a.createBlock)(l,{key:0,kind:s.answer.kind},null,8,["kind"])),r.shouldShowRichContent?((0,a.openBlock)(),(0,a.createBlock)(i,{key:1,content:s.answer.content,"message-uuid":s.messageUuid,"answer-uuid":s.answer._uuid,"should-stream":r.shouldStream,class:"mb-3",onStreamingComplete:t[0]||(t[0]=e=>r.onComponentComplete("rich-content"))},null,8,["content","message-uuid","answer-uuid","should-stream"])):(0,a.Q3)("v-if",!0),r.shouldShowGuideHeader?((0,a.openBlock)(),(0,a.createBlock)(c,{key:2,title:s.answer.title,summary:s.answer.summary,"should-stream":r.shouldStream,class:"mt-3",onStreamingComplete:t[1]||(t[1]=e=>r.onComponentComplete("guide-header"))},null,8,["title","summary","should-stream"])):(0,a.Q3)("v-if",!0),r.shouldShowGuideStepList?((0,a.openBlock)(),(0,a.createBlock)(d,{key:3,steps:s.answer.steps,"should-stream":r.shouldStream,class:"mb-3",onStreamingComplete:t[2]||(t[2]=e=>r.onComponentComplete("guide-steps-list"))},null,8,["steps","should-stream"])):(0,a.Q3)("v-if",!0),r.shouldShowResourcesList?((0,a.openBlock)(),(0,a.createBlock)(u,{key:4,resources:s.answer.resources,"should-stream":r.shouldStream,class:"mb-3",onStreamingComplete:t[3]||(t[3]=e=>r.onComponentComplete("resources-list"))},null,8,["resources","should-stream"])):(0,a.Q3)("v-if",!0),r.shouldShowFlowsList?((0,a.openBlock)(),(0,a.createBlock)(m,{key:5,flows:s.answer.flows,"should-stream":r.shouldStream,class:"mb-3",onStreamingComplete:t[4]||(t[4]=e=>r.onComponentComplete("flows-list"))},null,8,["flows","should-stream"])):(0,a.Q3)("v-if",!0),r.shouldShowPackagesList?((0,a.openBlock)(),(0,a.createBlock)(p,{key:6,packages:s.answer.nodePackages,"should-stream":r.shouldStream,class:"mb-3",onStreamingComplete:t[5]||(t[5]=e=>r.onComponentComplete("packages-list"))},null,8,["packages","should-stream"])):(0,a.Q3)("v-if",!0),r.shouldShowIssuesList?((0,a.openBlock)(),(0,a.createBlock)(h,{key:7,issues:s.answer.issues,"should-stream":r.shouldStream,onStreamingComplete:t[6]||(t[6]=e=>r.onComponentComplete("issues-list"))},null,8,["issues","should-stream"])):(0,a.Q3)("v-if",!0),r.shouldShowSuggestionsList?((0,a.openBlock)(),(0,a.createBlock)(g,{key:8,suggestions:s.answer.suggestions,"should-stream":r.shouldStream,onStreamingComplete:t[7]||(t[7]=e=>r.onComponentComplete("suggestions-list"))},null,8,["suggestions","should-stream"])):(0,a.Q3)("v-if",!0)]),_:1},512)}]]);const jt={class:"ff-expert-tool-call"},Kt={class:"ff-expert-tool-call--count"},Gt={class:"ff-expert-tool-call--duration"};var Jt=s(23084);const Yt={class:"ff-expert-tool-call--item"},Xt={class:"ff-expert-tool-call--title"},Zt={class:"ff-expert-tool-call--name"},es=["title"],ts={class:"ff-expert-tool-call--section-duration"},ss={key:0,class:"ff-expert-tool-call--details"},as={key:0,class:"ff-expert-tool-call--section"},ns={key:0,class:"ff-expert-tool-call--code"},os=["innerHTML"],rs={key:1,class:"ff-expert-tool-call--section"},ls={key:0,class:"ff-expert-tool-call--code"},is=["innerHTML"];ye.A.registerLanguage("json",Ie.A);var cs={name:"ToolCallItem",components:{ChevronRightIcon:Jt.A},props:{tool:{type:Object,required:!0},expanded:{type:Boolean,default:!1}},data(){return{inputExpanded:!1,outputExpanded:!1}},methods:{formatKindBadge(e){return{mcp_tool:"T",mcp_resource:"R",mcp_resource_template:"RT",mcp_prompt:"P"}[e]||"?"},formatKindFull(e){return{mcp_tool:"MCP Tool",mcp_resource:"MCP Resource",mcp_resource_template:"MCP Resource Template",mcp_prompt:"MCP Prompt"}[e]||e||"Unknown"},hasContent(e){return null!=e&&(Array.isArray(e)?e.length>0:"object"==typeof e?Object.keys(e).length>0:"string"!=typeof e||""!==e.trim())},highlightJson(e){let t;if("string"==typeof e)try{t=JSON.stringify(JSON.parse(e),null,2)}catch{t=e}else t=JSON.stringify(e,null,2);return ye.A.highlight(t,{language:"json"}).value}}},ds=(0,A.A)(cs,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("ChevronRightIcon");return(0,a.openBlock)(),(0,a.CE)("div",Yt,[(0,a.Lk)("div",Xt,(0,a.v_)(s.tool.title||s.tool.name),1),(0,a.Lk)("div",Zt,[(0,a.Lk)("div",null,[(0,a.Lk)("span",{class:"ff-expert-tool-call--badge",title:r.formatKindFull(s.tool.kind)},(0,a.v_)(r.formatKindBadge(s.tool.kind)),9,es),(0,a.eW)(" "+(0,a.v_)(s.tool.name),1)]),(0,a.Lk)("span",ts,(0,a.v_)(s.tool.durationMs||0)+" ms",1)]),s.expanded?((0,a.openBlock)(),(0,a.CE)("div",ss,[(0,a.Q3)(" Input section (collapsible, expanded by default) "),r.hasContent(s.tool.args)?((0,a.openBlock)(),(0,a.CE)("div",as,[(0,a.Lk)("div",{class:"ff-expert-tool-call--section-header",onClick:t[0]||(t[0]=(0,a.D$)(e=>o.inputExpanded=!o.inputExpanded,["stop"]))},[(0,a.createVNode)(l,{class:(0,a.C4)(["ff-icon-small",{rotated:o.inputExpanded}])},null,8,["class"]),t[2]||(t[2]=(0,a.Lk)("span",{class:"ff-expert-tool-call--section-label"},"Input",-1))]),o.inputExpanded?((0,a.openBlock)(),(0,a.CE)("div",ns,[(0,a.Q3)(" eslint-disable-next-line vue/no-v-html "),(0,a.Lk)("pre",null,[(0,a.Lk)("code",{innerHTML:r.highlightJson(s.tool.args)},null,8,os)])])):(0,a.Q3)("v-if",!0)])):(0,a.Q3)("v-if",!0),(0,a.Q3)(" Output section (collapsible, collapsed by default) "),r.hasContent(s.tool.output)?((0,a.openBlock)(),(0,a.CE)("div",rs,[(0,a.Lk)("div",{class:"ff-expert-tool-call--section-header",onClick:t[1]||(t[1]=(0,a.D$)(e=>o.outputExpanded=!o.outputExpanded,["stop"]))},[(0,a.createVNode)(l,{class:(0,a.C4)(["ff-icon-small",{rotated:o.outputExpanded}])},null,8,["class"]),t[3]||(t[3]=(0,a.Lk)("span",{class:"ff-expert-tool-call--section-label"},"Output",-1))]),o.outputExpanded?((0,a.openBlock)(),(0,a.CE)("div",ls,[(0,a.Q3)(" eslint-disable-next-line vue/no-v-html "),(0,a.Lk)("pre",null,[(0,a.Lk)("code",{innerHTML:r.highlightJson(s.tool.output)},null,8,is)])])):(0,a.Q3)("v-if",!0)])):(0,a.Q3)("v-if",!0)])):(0,a.Q3)("v-if",!0)])}],["__scopeId","data-v-3f837657"]]),us={name:"ToolCalls",components:{ChevronRightIcon:Jt.A,ToolCallItem:ds},props:{message:{type:Object,required:!0,validator:e=>Array.isArray(e.toolCalls)}},data(){return{expanded:!1}},computed:{toolCalls(){return this.message.toolCalls||[]},toolCallCount(){return this.toolCalls.length},formattedDuration(){const e=this.message.duration;if(null==e)return 0;const t="string"==typeof e?parseFloat(e):e;return Math.round(1e3*t)}},methods:{toggleExpanded(){this.expanded=!this.expanded}}},ms={name:"AiMessage",components:{ToolCalls:(0,A.A)(us,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("ChevronRightIcon"),i=(0,a.g2)("ToolCallItem");return(0,a.openBlock)(),(0,a.CE)("div",jt,[(0,a.Lk)("div",{class:"ff-expert-tool-call--header",onClick:t[0]||(t[0]=(...e)=>r.toggleExpanded&&r.toggleExpanded(...e))},[(0,a.createVNode)(l,{class:(0,a.C4)(["ff-icon",{rotated:o.expanded}])},null,8,["class"]),(0,a.Lk)("span",Kt,(0,a.v_)(r.toolCallCount)+" tool call"+(0,a.v_)(r.toolCallCount>1?"s":""),1),(0,a.Lk)("span",Gt,(0,a.v_)(r.formattedDuration)+" ms ",1)]),(0,a.Lk)("div",{class:(0,a.C4)(["ff-expert-tool-call--body",{"is-expanded":o.expanded}])},[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(r.toolCalls,e=>((0,a.openBlock)(),(0,a.createBlock)(i,{key:e.id,tool:e,expanded:o.expanded},null,8,["tool","expanded"]))),128))],2)])}],["__scopeId","data-v-741c64ce"]]),AnswerWrapper:zt},props:{query:{type:String,required:!1,default:null},answer:{type:Object,required:!0},timings:{required:!1,default:null,type:Object},_type:{type:String,required:!0},_timestamp:{required:!0,type:Number},_uuid:{required:!0,type:String},_streamed:{required:!0,type:Boolean}},setup(){const{initStreamer:e,setSubItemStreamedState:t,visibleItems:s,items:a}=Qe({shallow:!0});return{initStreamer:e,setSubItemStreamedState:t,visibleItems:s,items:a}},computed:{toolCalls(){const e=this.answer.filter(e=>["mcp_tool","mcp_resource","mcp_resource_template","mcp_prompt"].includes(e.kind));if(e.length>0){const t=e.map(e=>({id:e.toolId,name:e.toolName,title:e.toolTitle||e.toolName,kind:e.kind,args:e.input,output:e.output,durationMs:e.durationMs}));return{type:"ai",kind:"tool_calls",toolCalls:t,duration:(e.reduce((e,t)=>e+(t.durationMs||0),0)/1e3).toFixed(2),content:`${t.length} tool call(s)`,timestamp:Date.now()}}return null},filteredAnswers(){return this.answer.filter(e=>!["mcp_tool","mcp_resource","mcp_resource_template","mcp_prompt"].includes(e.kind))}},async mounted(){await this.initStreamer(this.filteredAnswers,{shouldStream:!this._streamed})},methods:{slugify:T.Yv}},ps=(0,A.A)(ms,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("tool-calls"),i=(0,a.g2)("answer-wrapper");return(0,a.openBlock)(),(0,a.CE)("div",he,[r.toolCalls?((0,a.openBlock)(),(0,a.createBlock)(l,{key:0,message:r.toolCalls},null,8,["message"])):(0,a.Q3)("v-if",!0),((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(n.visibleItems,(e,t)=>((0,a.openBlock)(),(0,a.createBlock)(i,{key:r.slugify(`${e.kind}-${e.title}-${e.summary}-${e._uuid}`),"message-uuid":s._uuid,answer:e,onStreamingComplete:e=>n.setSubItemStreamedState(t)},null,8,["message-uuid","answer","onStreamingComplete"]))),128))])}]]),hs={name:"HumanMessage",components:{StreamableContent:Re,MessageBubble:Ue},props:{content:{required:!0,type:String},_timestamp:{required:!0,type:Number},_type:{required:!0,type:String}}},gs=(0,A.A)(hs,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content"),i=(0,a.g2)("message-bubble");return(0,a.openBlock)(),(0,a.createBlock)(i,{type:"human"},{default:(0,a.k6)(()=>[(0,a.createVNode)(l,{string:s.content,"rich-content":!0,"should-stream":!1},null,8,["string"])]),_:1})}]]),fs={name:"SystemMessage",components:{MessageBubble:Ue},props:{_type:{type:String,required:!0},_variant:{type:String,required:!0},message:{type:String,required:!0},_timestamp:{type:Number,required:!0}}},ks=(0,A.A)(fs,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("message-bubble");return(0,a.openBlock)(),(0,a.createBlock)(l,{type:"system",variant:s._variant},{default:(0,a.k6)(()=>[(0,a.eW)((0,a.v_)(s.message),1)]),_:1},8,["variant"])}]]),vs=s(66461),bs={name:"ExpertMessages",components:{ExpertLoadingIndicator:pe},emits:["resizing"],data(){return{resizeObserver:null,lastHeight:null}},computed:{...(0,r.aH)(ee.i,["messages","isWaitingForResponse"]),messageTypes(){return{ai:(0,a.IG)(ps),human:(0,a.IG)(gs),system:(0,a.IG)(ks)}}},mounted(){this.mountResizeObserver(),window.addEventListener("keydown",this.onKeyDown)},beforeUnmount(){this.unmountResizeObserver(),window.removeEventListener("keydown",this.onKeyDown)},methods:{onKeyDown(e){e.altKey&&e.shiftKey&&"d"===e.key.toLowerCase()&&(e.preventDefault(),(0,vs.X)(this.messages,"expert-messages.json"))},mountResizeObserver(){const e=this.$refs.messagesWrapper;e&&(this.lastHeight=e.offsetHeight,this.resizeObserver=new ResizeObserver(([e])=>{const t=e.contentRect.height;t!==this.lastHeight&&(this.lastHeight=t,this.$emit("resizing"))}),this.resizeObserver.observe(e))},unmountResizeObserver(){this.resizeObserver?.disconnect()}}},Ss=(0,A.A)(bs,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("expert-loading-indicator");return(0,a.openBlock)(),(0,a.CE)("div",re,[(0,a.Lk)("ul",le,[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(e.messages,e=>((0,a.openBlock)(),(0,a.CE)("li",{key:e._uuid,class:"flex flex-col gap-3"},[r.messageTypes[e._type]?((0,a.openBlock)(),(0,a.createBlock)((0,a.$y)(r.messageTypes[e._type]),(0,a.v6)({key:0,ref_for:!0},{...e}),null,16)):(0,a.Q3)("v-if",!0)]))),128)),e.isWaitingForResponse?((0,a.openBlock)(),(0,a.CE)("li",ie,[(0,a.createVNode)(l)])):(0,a.Q3)("v-if",!0)])],512)}],["__scopeId","data-v-8cb7c522"]]),Cs={name:"ExpertModeSwitcher",components:{ToggleButtonGroup:s(2808).A},props:{isFloating:{required:!1,type:Boolean,default:!1}},computed:{...(0,r.aH)(ee.i,["agentMode"]),agentModeButtons(){return[{title:"Support",value:"support-agent"},{title:"Insights",value:"insights-agent"}]},agentModeWrapper:{get(){return this.agentMode},set(e){this.setAgentMode(e)}}},methods:{...(0,r.i0)(ee.i,["setAgentMode"])}},ws=(0,A.A)(Cs,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("toggle-button-group");return(0,a.openBlock)(),(0,a.CE)("div",{class:(0,a.C4)({"mode-switcher-floating":s.isFloating})},[(0,a.createVNode)(l,{modelValue:r.agentModeWrapper,"onUpdate:modelValue":t[0]||(t[0]=e=>r.agentModeWrapper=e),buttons:r.agentModeButtons,"uses-links":!1,"visually-hide-title":!0},null,8,["modelValue","buttons"])],2)}],["__scopeId","data-v-0d66f778"]]);const ys={class:"info-banner"},xs={key:0,class:"info-text"},Bs={key:1,class:"info-text"};var Is={name:"InfoBanner",computed:{...(0,r.aH)(ee.i,["isSupportAgent","isInsightsAgent"])}},As=(0,A.A)(Is,[["render",function(e,t,s,n,o,r){return(0,a.openBlock)(),(0,a.CE)(a.FK,null,[(0,a.Q3)(" Info Banner "),(0,a.Lk)("div",ys,[e.isSupportAgent?((0,a.openBlock)(),(0,a.CE)("p",xs,[...t[0]||(t[0]=[(0,a.eW)(" AI agent has access to all of FlowFuse's ",-1),(0,a.Lk)("a",{href:"https://flowfuse.com/docs",target:"_blank",rel:"noopener noreferrer",class:"info-link"},"documentation and knowledge",-1),(0,a.eW)(", ",-1),(0,a.Lk)("a",{href:"https://flowfuse.com/blog",target:"_blank",rel:"noopener noreferrer",class:"info-link"},"blogposts",-1),(0,a.eW)(", and more. ",-1)])])):(0,a.Q3)("v-if",!0),e.isInsightsAgent?((0,a.openBlock)(),(0,a.CE)("p",Bs,[...t[1]||(t[1]=[(0,a.Lk)("span",{title:"This feature is still under development",class:"beta-badge"},"BETA",-1),(0,a.eW)(" AI agent can access ",-1),(0,a.Lk)("a",{href:"https://flowfuse.com/node-red/flowfuse/mcp/",target:"_blank",rel:"noopener noreferrer",class:"info-link"},"MCP server tools",-1),(0,a.eW)(" configured in your hosted Node-RED instances. ",-1)])])):(0,a.Q3)("v-if",!0)])],2112)}],["__scopeId","data-v-234efe2c"]]);const Es={class:"update-banner-text update-banner-header flex items-center justify-between"},Ls=["title"],Ts={class:"update-banner-badge ml-4 shrink-0"},_s={class:"update-banner-text update-banner-body",tabindex:"0"},Vs={class:"mb-2"},Ms={class:"flex justify-end"};var Ps=s(99589),Rs=s.n(Ps);const Os="0.11.0";var Ns={name:"UpdateBanner",computed:{...(0,r.aH)(F.u,["palette","editorState","version","nodeRedVersion","supportedActions","isEditorRunning"]),assistantLoaded(){return!!(this.version||this.nodeRedVersion||this.palette)},assistantPackage(){return this.palette&&0!==Object.keys(this.palette).length?this.palette?.["@flowfuse/nr-assistant"]?{installed:!0,...this.palette["@flowfuse/nr-assistant"]}:{installed:!1}:null},availableUpdate(){return Array.isArray(this.editorState?.updatesAvailable?.palette)?this.editorState?.updatesAvailable?.palette?.find(e=>"@flowfuse/nr-assistant"===e.package):null},assistantState(){if(!this.version||Rs().lt(this.version,"0.10.1"));else if(!this.isEditorRunning)return{show:!1};const e=!1!==this.assistantPackage?.enabled,t=this.assistantPackage?.installed??this.assistantLoaded,s=(t?this.assistantPackage?.version:"")||this.version||"0.0.0",a=Rs().gte(this.nodeRedVersion||"0.0.0","4.1.6")&&!!this.availableUpdate;let n=!!this.availableUpdate?.latest;this.assistantLoaded&&!a&&(n=Rs().lt(s,Os));const o={show:!t||!e||n,statusClass:"",expectedVersion:this.availableUpdate?.latest||Os,installedVersion:s,installed:t,enabled:e,chip:"",title:"",body:"",buttonText:"",buttonAction:null};return t?e?n?(o.statusClass="",o.chip=this.availableUpdate?.latest?`V${this.availableUpdate.latest} available`:"Update available",o.title="New FlowFuse Expert Version Available",o.body="There is an update available for FlowFuse Expert in the Node-RED palette. Please update to the latest version to enjoy new features and improvements.",o.buttonText="Update...",o.buttonAction=this.manageAssistantPackage):o.show=!1:(o.statusClass="warning",o.chip="Not enabled",o.title="FlowFuse Expert Not Enabled",o.body="FlowFuse Expert is installed but not enabled in the Node-RED palette. Please enable it to access its features.",o.buttonText="Enable...",o.buttonAction=this.manageAssistantPackage):(o.statusClass="warning",o.chip="Not installed",o.title="FlowFuse Expert Not Installed",o.body="FlowFuse Expert is not installed in the Node-RED palette. Please install it to access its features.",o.buttonText="Install...",o.buttonAction=this.installAssistantPackage),o}},methods:{...(0,r.i0)(F.u,["manageNodePackage","installNodePackage"]),onButtonClick(){"function"==typeof this.assistantState?.buttonAction&&this.assistantState.buttonAction()},manageAssistantPackage(){this.manageNodePackage("@flowfuse/nr-assistant")},installAssistantPackage(){this.installNodePackage("@flowfuse/nr-assistant")}}},Fs=(0,A.A)(Ns,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("ff-button");return r.assistantState.show?((0,a.openBlock)(),(0,a.CE)("div",{key:0,class:(0,a.C4)(["info-banner update-banner",r.assistantState.statusClass])},[(0,a.Lk)("div",Es,[(0,a.Lk)("span",{class:"truncate flex-1 pr-4",title:r.assistantState.title},(0,a.v_)(r.assistantState.title),9,Ls),(0,a.Lk)("span",Ts,(0,a.v_)(r.assistantState.chip),1)]),(0,a.Lk)("div",_s,[(0,a.Lk)("p",Vs,(0,a.v_)(r.assistantState.body),1),(0,a.Lk)("div",Ms,[(0,a.createVNode)(l,{kind:"secondary",size:"small",onClick:r.onButtonClick},{default:(0,a.k6)(()=>[(0,a.eW)((0,a.v_)(r.assistantState.buttonText),1)]),_:1},8,["onClick"])])])],2)):(0,a.Q3)("v-if",!0)}],["__scopeId","data-v-3ebf57bc"]]),Us=s(26460),$s={name:"ExpertPanel",components:{ExpertModeSwitcher:ws,InfoBanner:As,ExpertMessages:Ss,ExpertChatInput:oe,UpdateBanner:Fs},inject:{togglePinWithWidth:{from:"togglePinWithWidth",default:()=>()=>{}}},props:{instance:{type:Object,required:!1,default:null},device:{type:Object,required:!1,default:null}},data(){return{scrollCheckDebounce:null,autoScroll:!0}},computed:{...(0,r.aH)(ee.i,["abortController","agentMode","messages","isInsightsAgent"]),...(0,r.aH)(ae.W,{isPinned:e=>e.rightDrawer.fixed}),...(0,r.aH)(Us.n,["featuresCheck"]),isEditorContext(){return this.$route?.name?.includes("editor")||!1},isInsightsModeEnabled(){return!!this.featuresCheck?.isExpertInsightsFeatureEnabled},agentModeWrapper:{get(){return this.agentMode},set(e){this.setAgentMode(e)}},isInstanceRunning(){const e="running"===this.instance?.meta?.state,t="running"===this.device?.status;return e||t}},watch:{agentMode:{immediate:!0,async handler(){this.isInsightsAgent&&await this.getCapabilities(),this.addWelcomeMessageIfNeeded()}},"instance.meta.state":{handler(e){this.isEditorContext&&"running"!==e&&this.reset()}},"device.status":{handler(e){this.isEditorContext&&"running"!==e&&this.reset()}}},mounted(){this.isEditorContext&&setTimeout(()=>{this.addWelcomeMessageIfNeeded()},1e3)},beforeUnmount(){this.scrollCheckDebounce&&clearTimeout(this.scrollCheckDebounce),this.resetSessionTimer()},methods:{...(0,r.i0)(ee.i,["setAgentMode","setAbortController","resetSessionTimer","addWelcomeMessageIfNeeded","stopInflightChat"]),...(0,r.i0)(B.W,["getCapabilities"]),...(0,r.i0)(F.u,["reset"]),handleStopGeneration(){this.abortController&&(this.abortController.abort(),this.setAbortController(null)),this.stopInflightChat()},handleScroll(){this.scrollCheckDebounce&&clearTimeout(this.scrollCheckDebounce),this.scrollCheckDebounce=setTimeout(()=>{const e=this.$refs.messagesContainer;if(!e)return;const t=e.scrollHeight-e.scrollTop-e.clientHeight<100;t&&!this.autoScroll?this.autoScroll=!0:!t&&this.autoScroll&&(this.autoScroll=!1)},100)},scrollToBottom(){this.autoScroll&&this.$nextTick(()=>{if(this.$refs.scrollAnchor){const e=this.$refs.messagesContainer;if(!e)return;e.scrollTo({top:e.scrollHeight,behavior:"smooth"})}})}}},Ws=(0,A.A)($s,[["render",function(e,t,s,r,l,i){const c=(0,a.g2)("expert-mode-switcher"),d=(0,a.g2)("info-banner"),u=(0,a.g2)("expert-messages"),m=(0,a.g2)("update-banner"),p=(0,a.g2)("expert-chat-input");return(0,a.openBlock)(),(0,a.CE)("div",n,[i.isInsightsModeEnabled&&i.isEditorContext?((0,a.openBlock)(),(0,a.createBlock)(c,{key:0,isFloating:!0})):(0,a.Q3)("v-if",!0),(0,a.Lk)("div",{ref:"messagesContainer",class:(0,a.C4)(["messages-container",{"has-mode-switcher":i.isInsightsModeEnabled&&i.isEditorContext}]),onScroll:t[0]||(t[0]=(...e)=>i.handleScroll&&i.handleScroll(...e))},[(0,a.createVNode)(d),(0,a.createVNode)(u,{onResizing:i.scrollToBottom},null,8,["onResizing"]),(0,a.Lk)("div",o,null,512)],34),(0,a.Q3)(" Updates Available Banner "),i.isEditorContext&&i.isInstanceRunning?((0,a.openBlock)(),(0,a.createBlock)(m,{key:1})):(0,a.Q3)("v-if",!0),(0,a.createVNode)(p,{onStop:i.handleStopGeneration},null,8,["onStop"])])}],["__scopeId","data-v-fe3acece"]])}}]);
1
+ try{let e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{},t=(new e.Error).stack;t&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[t]="07b82428-d877-4872-9c7b-032a635fdbb5",e._sentryDebugIdIdentifier="sentry-dbid-07b82428-d877-4872-9c7b-032a635fdbb5")}catch(e){}("undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof globalThis?globalThis:"undefined"!=typeof self?self:{}).SENTRY_RELEASE={id:"e2bf6b7dacf90be6c1290bafb557acca1c6682a6"},(self.webpackChunk_flowfuse_flowfuse=self.webpackChunk_flowfuse_flowfuse||[]).push([[259,810],{6259:function(e,t,s){s.d(t,{default:function(){return b}});var a=s(41425);const n={ref:"drawer",class:"ff-expert-drawer","data-el":"expert-drawer",tabindex:"-1"},o={class:"header"},r={key:0,class:"agent-mode"},l={class:"header-actions"},i=["title"];var c=s(13020),d=s(39312),u=s(51580),m=s(10810),p=s(2808),h=s(13810),g=s(26460),f=s(96825),k=s(28409),v={name:"ExpertDrawer",components:{ToggleButtonGroup:p.A,ExpertPanel:h.default,XMarkIcon:c.A,LockClosedIcon:d.A,LockOpenIcon:u.A},inject:["togglePinWithWidth","shouldAllowPinning"],computed:{...(0,m.aH)(k.W,["rightDrawer"]),...(0,m.aH)(f.i,["agentMode"]),...(0,m.aH)(g.n,["featuresCheck"]),agentModeButtons(){return[{title:"Support",value:"support-agent"},{title:"Insights",value:"insights-agent"}]},isAssistantModeEnabled(){return!!this.featuresCheck?.isExpertAssistantFeatureEnabled},isInsightsModeEnabled(){return!!this.featuresCheck?.isExpertInsightsFeatureEnabled},isPinned(){return this.rightDrawer.fixed},agentModeWrapper:{get(){return this.agentMode},set(e){this.setAgentMode(e)}}},mounted(){setTimeout(()=>{this.$refs.drawer?.focus()},350)},methods:{...(0,m.i0)(k.W,["closeRightDrawer"]),...(0,m.i0)(f.i,["setAgentMode"]),closeDrawer(){this.closeRightDrawer()},togglePin(){this.togglePinWithWidth()}}},b=(0,s(66262).A)(v,[["render",function(e,t,s,c,d,u){const m=(0,a.g2)("toggle-button-group"),p=(0,a.g2)("LockClosedIcon"),h=(0,a.g2)("LockOpenIcon"),g=(0,a.g2)("XMarkIcon"),f=(0,a.g2)("ExpertPanel");return(0,a.openBlock)(),(0,a.CE)("div",n,[(0,a.Lk)("div",o,[t[3]||(t[3]=(0,a.Lk)("div",{class:"flex items-center gap-1.5"},[(0,a.Lk)("img",{src:"/ff-minimal-red.svg",alt:"FlowFuse",class:"w-5 h-5 shrink-0"}),(0,a.Lk)("h2",{class:"title"},"Expert")],-1)),u.isInsightsModeEnabled&&u.isAssistantModeEnabled?((0,a.openBlock)(),(0,a.CE)("div",r,[(0,a.createVNode)(m,{modelValue:u.agentModeWrapper,"onUpdate:modelValue":t[0]||(t[0]=e=>u.agentModeWrapper=e),buttons:u.agentModeButtons,usesLinks:!1,"visually-hide-title":!0},null,8,["modelValue","buttons"])])):(0,a.Q3)("v-if",!0),(0,a.Lk)("div",l,[u.shouldAllowPinning()?((0,a.openBlock)(),(0,a.CE)("button",{key:0,class:(0,a.C4)(["header-button pin-button",{"is-pinned":u.isPinned}]),title:u.isPinned?"Unpin drawer":"Pin drawer open","data-el":"expert-drawer-pin-button",onClick:t[1]||(t[1]=(...e)=>u.togglePin&&u.togglePin(...e))},[u.isPinned?((0,a.openBlock)(),(0,a.createBlock)(p,{key:0,class:"ff-icon"})):((0,a.openBlock)(),(0,a.createBlock)(h,{key:1,class:"ff-icon"}))],10,i)):(0,a.Q3)("v-if",!0),(0,a.Lk)("button",{class:"header-button",title:"Close Expert","data-el":"expert-drawer-close-button",onClick:t[2]||(t[2]=(...e)=>u.closeDrawer&&u.closeDrawer(...e))},[(0,a.createVNode)(g,{class:"ff-icon"})])])]),(0,a.createVNode)(f)],512)}],["__scopeId","data-v-83bf8a2c"]])},13810:function(e,t,s){s.r(t),s.d(t,{default:function(){return Ws}});var a=s(41425);const n={class:"ff-expert"},o={ref:"scrollAnchor",class:"scroll-anchor"};var r=s(10810);const l={class:"action-buttons"},i=["disabled"],c={class:"right-buttons"},d=["placeholder","disabled"],u={class:"actions"},m={class:"left overflow-hidden"},p={class:"right"},h=["disabled"];var g=s(82287);const f={class:"capabilities-selector"},k={style:{"min-width":"300px"}},v={class:"flex flex-col gap-1 flex-1 min-w-0"},b={class:"truncate",style:{"line-height":"16px"}},S={key:0,class:"text-gray-400 text-sm truncate leading-4"},C={class:"tool-count-badge self-start",title:"Tools"};var w=s(20487),y=s(34904),x=s(31911),B=s(63391),I={name:"CapabilitiesSelector",components:{FfCheckbox:y.A,ListboxOption:w.h7,FfListbox:x.A},computed:{...(0,r.aH)(B.W,["selectedCapabilities","capabilities"]),hasCapabilities(){return this.capabilities&&this.capabilities.length>0},capabilitiesHandler:{get(){return this.selectedCapabilities},set(e){this.setSelectedCapabilities(e)}}},methods:{...(0,r.i0)(B.W,["setSelectedCapabilities"]),onCheckboxClick(e){const t=e=>`${e.instance}::${e.mcpServerUrl}`,s=this.selectedCapabilities||[],a=s.some(s=>t(s)===t(e));this.capabilitiesHandler=a?s.filter(s=>t(s)!==t(e)):[...s,e]},getResourceTooltip(e){return[["MCP Server:",e.mcpServerName],["Instance:",e.instanceName],e.title?["Title:",e.title]:[],e.description?["Description:",e.description]:[],e.tools?.length?["Tools:",...e.tools.map(e=>e.name)]:null,e.resources?.length?["Resources:",...e.resources.map(e=>e.name)]:null,e.resourceTemplates?.length?["Resource Templates:",...e.resourceTemplates.map(e=>e.name)]:null].filter(Boolean).map(e=>e.join("\n")).join("\n\n")}}},A=s(66262),E=(0,A.A)(I,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("ff-checkbox"),i=(0,a.g2)("ListboxOption"),c=(0,a.g2)("ff-listbox");return(0,a.openBlock)(),(0,a.CE)("div",f,[(0,a.createVNode)(c,{modelValue:r.capabilitiesHandler,"onUpdate:modelValue":t[0]||(t[0]=e=>r.capabilitiesHandler=e),options:e.capabilities,disabled:!r.hasCapabilities,"return-model":"",multiple:"","label-key":"name","value-key":["instance","mcpServerUrl"],placeholder:"Resources","open-above":"","options-min-width":280,"align-right":""},{options:(0,a.k6)(({options:e})=>[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(e,e=>((0,a.openBlock)(),(0,a.createBlock)(i,{key:e.mcpServerName,as:"template",value:e,class:"ff-option ff-team-selection-option","data-option":e.mcpServerName,title:r.getResourceTooltip(e)},{default:(0,a.k6)(({active:t,selected:s})=>[(0,a.Lk)("li",k,[(0,a.Lk)("div",{class:(0,a.C4)(["ff-option-content flex truncate justify-start items-start! gap-2! p-2!",{active:t}]),"data-click-exclude":"right-drawer"},[(0,a.Lk)("div",null,[(0,a.createVNode)(l,{modelValue:s,onClick:(0,a.D$)(t=>r.onCheckboxClick(e),["stop","prevent"])},null,8,["modelValue","onClick"])]),(0,a.Lk)("div",v,[(0,a.Lk)("span",b,(0,a.v_)(e.title),1),e.title?((0,a.openBlock)(),(0,a.CE)("p",S,(0,a.v_)(e.mcpServerName),1)):(0,a.Q3)("v-if",!0)]),(0,a.Lk)("span",C,(0,a.v_)(e.toolCount),1)],2)])]),_:2},1032,["value","data-option","title"]))),128))]),_:1},8,["modelValue","options","disabled"])])}]]);const L={class:"context-selector-container"};var T=s(22511);const _=["title"],V={class:"text"},M={class:"icon-wrapper"};var P=s(52725),R=s(65428),O={name:"DefaultChip",components:{XMarkIcon:P.A,PlusIcon:R.A},props:{modelValue:{type:Boolean,required:!1,default:!0},text:{type:String,required:!1,default:""},title:{type:String,required:!1,default:""}},emits:["toggle"],methods:{pluralize:T.td}},N=(0,A.A)(O,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("XMarkIcon"),i=(0,a.g2)("PlusIcon");return(0,a.openBlock)(),(0,a.CE)("div",{class:(0,a.C4)(["chip",{active:s.modelValue}]),title:s.title,onClick:t[0]||(t[0]=t=>e.$emit("toggle"))},[(0,a.Lk)("div",V,[(0,a.RG)(e.$slots,"text",{},()=>[(0,a.Lk)("span",null,(0,a.v_)(s.text),1)],!0)]),t[1]||(t[1]=(0,a.Lk)("span",{class:"separator"},null,-1)),(0,a.Lk)("div",M,[s.modelValue?((0,a.openBlock)(),(0,a.createBlock)(l,{key:0,class:"ff-icon ff-icon-sm"})):((0,a.openBlock)(),(0,a.createBlock)(i,{key:1,class:"ff-icon ff-icon-sm"}))])],10,_)}],["__scopeId","data-v-3c33e421"]]),F=s(78721),U={name:"ContextChip",components:{DefaultChip:N},props:{contextItem:{type:Object,required:!1,default:()=>({})}},computed:{...(0,r.aH)(F.u,["getSelectedContext"]),selectedContext(){return this.getSelectedContext},text(){return this.contextItem.name||"Unnamed Context"},title(){return this.contextItem.title||`Include ${this.contextItem.name} in context`}},methods:{...(0,r.i0)(F.u,["setSelectedContext"]),pluralize:T.td,toggleSelection(){const e=this.selectedContext.filter(e=>e.name!==this.contextItem.name);this.setSelectedContext(e)}}},$=(0,A.A)(U,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("default-chip");return(0,a.openBlock)(),(0,a.createBlock)(l,{modelValue:!!s.contextItem,text:r.text,title:r.title,onToggle:r.toggleSelection},null,8,["modelValue","text","title","onToggle"])}]]);const W=["title"];var H={name:"DebugChip",components:{DefaultChip:N},props:{modelValue:{type:Boolean,required:!1,default:!0}},emits:["update:modelValue"],computed:{...(0,r.aH)(F.u,["debugLog"]),selectedCounter(){return this.debugLog.length},selectionTitle(){const e={};return this.debugLog.forEach(t=>{e[t.type]=(e[t.type]??0)+1}),`Selected Logs: \n${this.debugLog.map((e,t)=>{const s=(e=e||{}).level||"",a="debug"!==s?s:"",n=e.metadata?.topic||"",o=e.source?.name||e.source?.id||e.metadata?.path||"",r=e.metadata?.format||"",l=e.source?.type||"",i=e.metadata?.property||"",c=[];return o&&c.push(`node: ${o}`),n&&c.push(`topic: ${n}`),a&&l&&c.push(`${l} : (${a})`),i&&(r?c.push(`property: ${i} ${r}`):c.push(`property: ${i}`)),`${t+1}: ${c.join(", ")}`}).join("\n")}`}},methods:{...(0,r.i0)(F.u,["resetDebugLogContext"]),pluralize:T.td,toggleSelection(){this.$emit("update:modelValue",!this.modelValue),this.resetDebugLogContext()}}},Q=(0,A.A)(H,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("default-chip");return(0,a.openBlock)(),(0,a.createBlock)(l,{class:"flow-selection-button",modelValue:s.modelValue,onToggle:r.toggleSelection},{text:(0,a.k6)(()=>[t[0]||(t[0]=(0,a.Lk)("span",null,"Debug",-1)),(0,a.Lk)("span",{class:"counter italic",title:r.selectionTitle},"( "+(0,a.v_)(r.selectedCounter)+" "+(0,a.v_)(r.pluralize("log",r.selectedCounter))+" )",9,W)]),_:1},8,["modelValue","onToggle"])}]]);const D=["title"];var q={name:"SelectionChip",components:{DefaultChip:N},props:{modelValue:{type:Boolean,required:!1,default:!0}},emits:["update:modelValue"],computed:{...(0,r.aH)(F.u,["selectedNodes"]),filteredSelectedNodes(){return this.selectedNodes.filter(e=>!["global-config"].includes(e.type))},selectedCounter(){return this.filteredSelectedNodes.length},selectionTitle(){const e={};return this.filteredSelectedNodes.forEach(t=>{e[t.type]=(e[t.type]??0)+1}),`Selected nodes: \n${Object.keys(e).map(t=>`${e[t]} x ${t}`).join("\n")}`}},methods:{...(0,r.i0)(F.u,["setSelectedNodes"]),pluralize:T.td,toggleSelection(){this.$emit("update:modelValue",!this.modelValue),this.setSelectedNodes([])}}},z=(0,A.A)(q,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("default-chip");return(0,a.openBlock)(),(0,a.createBlock)(l,{class:"flow-selection-button",modelValue:s.modelValue,onToggle:r.toggleSelection},{text:(0,a.k6)(()=>[t[0]||(t[0]=(0,a.Lk)("span",null,"Selection",-1)),(0,a.Lk)("span",{class:"counter italic",title:r.selectionTitle},"( "+(0,a.v_)(r.selectedCounter)+" "+(0,a.v_)(r.pluralize("node",r.selectedCounter))+" )",9,D)]),_:1},8,["modelValue","onToggle"])}]]);const j={class:"context-selector mr-2"};var K=s(9080),G=s(81429),J=s(41541),Y=s(26218),X={name:"ContextSelectorButton",components:{PaperClipIcon:K.A},data(){return{selectedContextItems:[]}},computed:{...(0,r.aH)(F.u,["availableContextOptions","getSelectedContext"]),hasContextOptions(){return this.contextOptions?.length>0},hasSelection(){return this.selectedContext?.length>0},selectedContext(){return this.getSelectedContext},contextOptions:{get(){return this.availableContextOptions.map(e=>{let t=G.A;return"CubeIcon"===e.menuIcon?t=J.A:"Bars4Icon"===e.menuIcon&&(t=Y.A),{...e,icon:t}})}}},methods:{pluralize:T.td,...(0,r.i0)(F.u,["setSelectedContext"]),selectItem(e){if(e.onSelectAction)(0,F.u)()[e.onSelectAction]();else{const t=e=>({value:e.value,name:e.name,label:e.label,icon:e.icon}),s=t(e),a=this.selectedContext||[];if(a.some(e=>e.value===s.value))return;this.setSelectedContext([...a,s].filter(Boolean))}}}},Z=(0,A.A)(X,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("PaperClipIcon"),i=(0,a.g2)("ff-listbox");return(0,a.openBlock)(),(0,a.CE)("div",j,[(0,a.createVNode)(i,{modelValue:o.selectedContextItems,"onUpdate:modelValue":t[0]||(t[0]=e=>o.selectedContextItems=e),class:(0,a.C4)(["context-selector",r.hasSelection?"active":""]),options:r.contextOptions,disabled:!r.hasContextOptions,"hide-chevron":!0,"icon-only":!0,"return-model":"","label-key":"label",placeholder:"Context","open-above":"","options-min-width":250,"align-right":"",onOptionSelected:r.selectItem},{icon:(0,a.k6)(()=>[(0,a.createVNode)(l,{class:"icon ff-icon ff-icon-sm"})]),_:1},8,["modelValue","class","options","disabled","onOptionSelected"])])}]]),ee=s(96825),te={name:"ContextSelector",components:{ContextChip:$,DebugChip:Q,SelectionChip:z,ContextSelectorButton:Z},computed:{...(0,r.aH)(F.u,["getSelectedContext","hasDebugLogsSelected","hasUserSelection"]),...(0,r.aH)(ee.i,["isInsightsAgent"]),selectedContext(){return this.isInsightsAgent?[]:this.getSelectedContext},selectedContextFiltered(){return this.selectedContext.filter(e=>!1!==e.showAsChip)}},methods:{horizontalScrolling(e){const t=e.currentTarget;0!==e.deltaY&&(e.preventDefault(),t.scrollLeft+=e.deltaY/2)}}},se=(0,A.A)(te,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("context-selector-button"),i=(0,a.g2)("context-chip"),c=(0,a.g2)("debug-chip"),d=(0,a.g2)("selection-chip");return(0,a.openBlock)(),(0,a.CE)("div",L,[e.isInsightsAgent?(0,a.Q3)("v-if",!0):((0,a.openBlock)(),(0,a.createBlock)(l,{key:0})),(0,a.Lk)("div",{class:"chips-container",onWheel:t[0]||(t[0]=(...e)=>r.horizontalScrolling&&r.horizontalScrolling(...e))},[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(r.selectedContextFiltered,(e,t)=>((0,a.openBlock)(),(0,a.createBlock)(i,{key:t,contextItem:e},null,8,["contextItem"]))),128)),e.hasDebugLogsSelected&&!e.isInsightsAgent?((0,a.openBlock)(),(0,a.createBlock)(c,{key:0})):(0,a.Q3)("v-if",!0),e.hasUserSelection&&!e.isInsightsAgent?((0,a.openBlock)(),(0,a.createBlock)(d,{key:1})):(0,a.Q3)("v-if",!0)],32)])}],["__scopeId","data-v-104983ce"]]),ae=s(28409),ne={name:"ExpertChatInput",components:{CapabilitiesSelector:E,ContextSelector:se,ResizeBar:g.A},inject:{togglePinWithWidth:{from:"togglePinWithWidth",default:()=>()=>{}}},emits:["send","stop"],setup(){const{startResize:e,heightStyle:t,bindResizer:s,isResizing:n}=function(){const e=(0,a.KR)(window.innerWidth),t=(0,a.KR)(window.innerHeight),s=(0,a.KR)(0),n=(0,a.KR)(0),o=(0,a.KR)(0),r=(0,a.KR)(0),l=(0,a.KR)(0),i=(0,a.KR)(1),c=(0,a.KR)(1),d=(0,a.KR)(!1);let u=0,m=0,p=0,h=0;const g=(0,a.KR)(0),f=(0,a.KR)(0);function k(){d.value=!1,document.removeEventListener("mousemove",v),document.removeEventListener("mouseup",k)}function v(a){if(d.value){const l=a.clientX-u,i=a.clientY-m,c=p+l,d=h-i;g.value=Math.min(Math.max(s.value,c),e.value-o.value),f.value=Math.min(Math.max(n.value,d),t.value-r.value)}}return{heightStyle:(0,a.EW)(()=>t.value<l.value?`${Math.min(f.value,t.value)}px`:`${Math.min(f.value,t.value*c.value)}px`),widthStyle:(0,a.EW)(()=>e.value<l.value?`${Math.min(g.value,e.value)}px`:`${Math.min(g.value,e.value*i.value)}px`),isResizing:(0,a.EW)(()=>d.value),startResize:function(e){d.value=!0,u=e.clientX,m=e.clientY,p=g.value,h=f.value,document.addEventListener("mousemove",v),document.addEventListener("mouseup",k)},stopResize:k,bindResizer:function({component:e=null,initialWidth:t=0,initialHeight:a=0,minWidth:d,minHeight:u,maxViewportMarginX:m,maxViewportMarginY:p,mobileBreakpoint:h=640,maxWidthRatio:k,maxHeightRatio:v}={}){let b=t,S=a;if(e){const s=e.$el||e;if(s&&s.getBoundingClientRect){const e=s.getBoundingClientRect();b=t||e.width,S=a||e.height}}f.value=S,g.value=b,s.value=d,n.value=u,o.value=m,r.value=p,l.value=h??0,i.value=k??1,c.value=v??1},setWidth:function(e){g.value=e},setHeight:function(e){f.value=e}}}();return{startResize:e,bindResizer:s,heightStyle:t,isInputResizing:n}},data(){return{inputText:"",includeSelection:!0,isTextareaFocused:!1}},computed:{...(0,r.aH)(F.u,["isImmersiveInstance","isImmersiveDevice"]),...(0,r.aH)(ae.W,["rightDrawer"]),...(0,r.aH)(ee.i,["messages","isSessionExpired","isInsightsAgent","hasSelectedCapabilities","hasMessages","isWaitingForResponse"]),isInputDisabled(){return!!this.isSessionExpired||!!this.isWaitingForResponse||this.isInsightsAgent&&!this.hasSelectedCapabilities},isDrawerPinned(){return this.rightDrawer.fixed},canSend(){return this.inputText.trim().length>0&&!this.isInputDisabled},placeholderText(){return this.isInsightsAgent&&!this.hasSelectedCapabilities?"Select a resource to get started":this.isInsightsAgent?"Tell us what you want to know about":"Tell us what you need help with"},isImmersive(){return this.isImmersiveDevice||this.isImmersiveInstance}},mounted(){this.bindResizer({component:this.$refs.resizeTarget,maxHeightRatio:.9,minHeight:120,maxViewportMarginY:80})},methods:{...(0,r.i0)(F.u,["resetContextSelection"]),...(0,r.i0)(ee.i,["startOver","handleQuery","handleMessageResponse"]),async handleSend(){if(!this.canSend)return;const e=this.inputText.trim();this.isDrawerPinned||0!==this.messages.length||this.togglePinWithWidth(),this.handleQuery({query:e}).then(e=>this.handleMessageResponse(e)).then(()=>{this.$nextTick(()=>{this.$refs.textarea.focus()})}).catch(e=>e),this.inputText=""},handleStop(){this.$emit("stop")},handleStartOver(){this.hasMessages&&(this.inputText="",this.isInsightsAgent||this.resetContextSelection(),this.startOver())},handleKeydown(e){"Enter"!==e.key||e.shiftKey||(e.preventDefault(),this.handleSend())}}},oe=(0,A.A)(ne,[["render",function(e,t,s,n,o,r){const g=(0,a.g2)("resize-bar"),f=(0,a.g2)("capabilities-selector"),k=(0,a.g2)("context-selector");return(0,a.openBlock)(),(0,a.CE)("div",{ref:"resizeTarget",class:"ff-expert-input",style:(0,a.Tr)({height:n.heightStyle})},[(0,a.createVNode)(g,{"is-resizing":n.isInputResizing,direction:"horizontal",onMousedown:n.startResize},null,8,["is-resizing","onMousedown"]),(0,a.Q3)(" Action buttons row "),(0,a.Lk)("div",l,[(0,a.Lk)("button",{type:"button",class:"btn-start-over",disabled:e.isWaitingForResponse&&!e.isSessionExpired,onClick:t[0]||(t[0]=(...e)=>r.handleStartOver&&r.handleStartOver(...e))}," Start over ",8,i),(0,a.Lk)("div",c,[e.isInsightsAgent?((0,a.openBlock)(),(0,a.createBlock)(f,{key:0})):(0,a.Q3)("v-if",!0)])]),(0,a.Lk)("div",{class:(0,a.C4)(["input-wrapper",{focused:o.isTextareaFocused}])},[(0,a.Q3)(" Textarea "),(0,a.bo)((0,a.Lk)("textarea",{ref:"textarea","onUpdate:modelValue":t[1]||(t[1]=e=>o.inputText=e),class:"chat-input",placeholder:r.placeholderText,disabled:r.isInputDisabled,onKeydown:t[2]||(t[2]=(...e)=>r.handleKeydown&&r.handleKeydown(...e)),onFocus:t[3]||(t[3]=e=>o.isTextareaFocused=!0),onBlur:t[4]||(t[4]=e=>o.isTextareaFocused=!1)},null,40,d),[[a.Jo,o.inputText]]),(0,a.Lk)("div",u,[(0,a.Lk)("div",m,[r.isImmersive&&!e.isInsightsAgent?((0,a.openBlock)(),(0,a.createBlock)(k,{key:0})):(0,a.Q3)("v-if",!0)]),(0,a.Lk)("div",p,[e.isWaitingForResponse&&!e.isSessionExpired?((0,a.openBlock)(),(0,a.CE)("button",{key:0,type:"button",class:"btn-stop",onClick:t[5]||(t[5]=(...e)=>r.handleStop&&r.handleStop(...e))}," Stop ")):e.isSessionExpired?(0,a.Q3)("v-if",!0):((0,a.openBlock)(),(0,a.CE)("button",{key:1,type:"button",class:"btn-send",disabled:!r.canSend,onClick:t[6]||(t[6]=(...e)=>r.handleSend&&r.handleSend(...e))}," Send ",8,h))])])],2)],4)}],["__scopeId","data-v-6e8fca3f"]]);const re={ref:"messagesWrapper",class:"messages-wrapper"},le={class:"flex flex-col gap-3"},ie={key:0},ce={class:"ff-expert-loading"},de={key:0,class:"loading-message"};var ue=s(2e3),me={name:"ExpertLoadingIndicator",data(){return{showMessage:!1,currentMessageIndex:0,messageVariants:{[ue.C]:["Ingesting the docs...","Reading the blog...","Searching through FlowFuse knowledge base","Analyzing your question...","Finding the best answer..."],[ue.q]:["Connecting to MCP resources...","Querying your Node-RED instances...","Instructing MCP tooling...","Ingesting responses...","Gathering insights...","Considering instructions...","Processing user response..."],transfer:["Catching up with new context...","Syncing your conversation...","Loading existing history...","Preparing your chat..."]},messageTimer:null,rotationTimer:null}},computed:{...(0,r.aH)(ee.i,["loadingVariant","inFlightUpdates"]),messages(){return this.inFlightUpdates.length>0?this.inFlightUpdates:this.messageVariants[this.loadingVariant]},currentMessage(){return this.messages[this.currentMessageIndex]}},mounted(){this.messageTimer=setTimeout(()=>{this.showMessage=!0,this.rotationTimer=setInterval(()=>{this.currentMessageIndex=(this.currentMessageIndex+1)%this.messages.length},3e3)},5e3)},beforeUnmount(){this.messageTimer&&clearTimeout(this.messageTimer),this.rotationTimer&&clearInterval(this.rotationTimer)}},pe=(0,A.A)(me,[["render",function(e,t,s,n,o,r){return(0,a.openBlock)(),(0,a.CE)("div",ce,[t[0]||(t[0]=(0,a.Lk)("div",{class:"loading-dots"},[(0,a.Lk)("div",{class:"loading-dot"}),(0,a.Lk)("div",{class:"loading-dot"}),(0,a.Lk)("div",{class:"loading-dot"})],-1)),o.showMessage?((0,a.openBlock)(),(0,a.CE)("div",de,(0,a.v_)(r.currentMessage),1)):(0,a.Q3)("v-if",!0)])}],["__scopeId","data-v-987264e4"]]);const he={class:"flex flex-col gap-3"};var ge=s(99900);const fe={class:"guide-badge"};var ke={name:"AnswerBadge",props:{kind:{required:!0,type:String}},computed:{title(){return"resources"===this.kind?"Resources":"Setup Guide"}}},ve=(0,A.A)(ke,[["render",function(e,t,s,n,o,r){return(0,a.openBlock)(),(0,a.CE)("div",fe,[(0,a.Lk)("span",null,(0,a.v_)(r.title),1)])}],["__scopeId","data-v-7d8bb1a7"]]);const be={key:0,class:"guide-header"},Se={class:"guide-title"},Ce={key:0,class:"guide-summary"},we=["innerHTML"];var ye=s(50011),xe=s(69510),Be=s(92753),Ie=s(27402),Ae=s(85262),Ee=s(95387),Le=s(69359),Te=s(60023);ye.A.registerLanguage("bash",xe.A),ye.A.registerLanguage("shell",xe.A),ye.A.registerLanguage("css",Be.A),ye.A.registerLanguage("javascript",Ee.A),ye.A.registerLanguage("js",Ee.A),ye.A.registerLanguage("json",Ie.A),ye.A.registerLanguage("python",Ae.A),ye.A.registerLanguage("py",Ae.A),ye.A.registerLanguage("typescript",Ee.A),ye.A.registerLanguage("ts",Ee.A),ye.A.registerLanguage("xml",Le.A),ye.A.registerLanguage("html",Le.A);const _e='<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" aria-hidden="true"><path stroke-linecap="round" stroke-linejoin="round" d="M8 16H6a2 2 0 01-2-2V6a2 2 0 012-2h8a2 2 0 012 2v2m-6 12h8a2 2 0 002-2v-8a2 2 0 00-2-2h-8a2 2 0 00-2 2v8a2 2 0 002 2z"/></svg>',Ve=_e;function Me({delayMs:e=30,splitRegex:t=/\s+/,joinWith:s=" "}={}){const n=(0,a.KR)(""),o=(0,a.KR)(!1);let r=null,l=[],i=0;const c=()=>{r&&clearTimeout(r),r=null,o.value=!1,l=[],i=0};return(0,a.xo)(c),{text:n,isStreaming:o,stream:(d="")=>(c(),n.value="",l=String(d).trim().split(t).filter(Boolean),i=0,o.value=!0,new Promise(t=>{const c=async()=>o.value?i>=l.length?(await(0,a.dY)(),o.value=!1,t()):(n.value+=(n.value?s:"")+l[i],i+=1,void(r=setTimeout(c,e))):t();c()})),stop:c}}var Pe={name:"StreamableContent",props:{modelValue:{type:Object,required:!1,default:null,validate(e,t){return t.string||e?!(!e||"object"!=typeof e)&&"string"==typeof e.streamable&&"boolean"==typeof e.streamed:(console.warn("StreamableContent: string prop is required when modelValue is null"),!1)}},string:{required:!1,type:String,default:null,validator(e,t){return!(!t.modelValue&&!e&&(console.warn("StreamableContent: string prop is required when modelValue is null"),1))}},shouldStream:{required:!1,type:Boolean,default:!0},richContent:{type:Boolean,required:!1,default:!1}},emits:["streaming-complete","update:modelValue"],setup(){const{stream:e,text:t,isStreaming:s}=Me({delayMs:30}),{markedInstance:a}=function(){const e=new Te.Dz({breaks:!0,gfm:!0});return e.use({renderer:{code({text:e,lang:t}){const s=t?t.split(/\s/)[0].toLowerCase():"";let a;return a=s&&ye.A.getLanguage(s)?ye.A.highlight(e,{language:s}).value:ye.A.highlightAuto(e).value,`<div class="ff-code-block"><div class="ff-code-block--header">${s?`<span class="ff-code-block--lang">${s}</span>`:""}<button class="ff-code-block--copy">${_e}</button></div><pre><code class="hljs">${a.replace(/\n/g,"&#10;")}</code></pre></div>`}}}),{markedInstance:e}}();return{stream:e,streamedText:t,isStreaming:s,sanitize:T.aj,markedInstance:a}},computed:{...(0,r.aH)(F.u,["supportedActions"]),rawText(){const e=this.modelValue?this.modelValue.streamable:this.string;return this.richContent?this.markedInstance.parse(e||""):e},text(){const e=this.shouldStream?this.streamedText:this.rawText;return this.sanitize(e,{supportedActions:this.supportedActions,targetBlank:!0,appendQueryParameters:{utm_source:"flowfuse-expert",utm_medium:"assistant",utm_campaign:"expert-chat"}})}},watch:{isStreaming(e){e||(this.$emit("streaming-complete"),this.modelValue&&this.$emit("update:modelValue",{...this.modelValue,streamed:!0}))}},mounted(){this.shouldStream&&this.stream(this.rawText)},methods:{handleClick(e){const t=e.target.closest(".ff-code-block--copy");if(!t)return;const s=t.closest(".ff-code-block")?.querySelector("pre code");s&&navigator.clipboard.writeText(s.textContent||"").then(()=>{t.innerHTML='<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" aria-hidden="true"><path stroke-linecap="round" stroke-linejoin="round" d="M5 13l4 4L19 7"/></svg>',setTimeout(()=>{t.innerHTML=Ve},2e3)}).catch(()=>{const e=document.createElement("textarea");e.value=s.textContent||"",e.style.position="fixed",e.style.left="-999999px",document.body.appendChild(e),e.select(),document.execCommand("copy"),document.body.removeChild(e)})}}},Re=(0,A.A)(Pe,[["render",function(e,t,s,n,o,r){return(0,a.openBlock)(),(0,a.CE)("div",(0,a.v6)({class:"streamable-content"},(0,a.Tb)(s.richContent?{click:r.handleClick}:{},!0)),[s.richContent?((0,a.openBlock)(),(0,a.CE)(a.FK,{key:1},[(0,a.Q3)(" eslint-disable-next-line vue/no-v-html "),((0,a.openBlock)(),(0,a.CE)("div",{key:r.text,innerHTML:r.text},null,8,we))],64)):((0,a.openBlock)(),(0,a.CE)("span",{key:r.text},(0,a.v_)(r.text),1))],16)}],["__scopeId","data-v-e45de422"]]),Oe={name:"GuideHeader",components:{StreamableContent:Re},props:{title:{type:String,required:!0},summary:{type:[String,null],required:!1,default:null},shouldStream:{type:Boolean,default:!1}},emits:["streaming-complete"],data(){return{streamableSummary:{streamable:this.summary,streamed:!1},streamableTitle:{streamable:this.title,streamed:!1}}},watch:{streamableSummary(e){e.streamed&&this.$emit("streaming-complete")},streamableTitle(e){!this.summary&&e.streamed&&this.$emit("streaming-complete")}}},Ne=(0,A.A)(Oe,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content");return(0,a.openBlock)(),(0,a.CE)(a.FK,null,[(0,a.Q3)(" Title and Summary "),s.title?((0,a.openBlock)(),(0,a.CE)("div",be,[(0,a.Lk)("h3",Se,[(0,a.createVNode)(l,{modelValue:o.streamableTitle,"onUpdate:modelValue":t[0]||(t[0]=e=>o.streamableTitle=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])]),s.summary?((0,a.openBlock)(),(0,a.CE)("p",Ce,[!s.shouldStream||o.streamableTitle.streamed?((0,a.openBlock)(),(0,a.createBlock)(l,{key:0,modelValue:o.streamableSummary,"onUpdate:modelValue":t[1]||(t[1]=e=>o.streamableSummary=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])):(0,a.Q3)("v-if",!0)])):(0,a.Q3)("v-if",!0)])):(0,a.Q3)("v-if",!0)],2112)}],["__scopeId","data-v-7fe35b3c"]]),Fe={name:"MessageBubble",props:{type:{required:!0,type:String},variant:{required:!1,type:String,default:null}},computed:{isAiMessage(){return"ai"===this.type},isHumanMessage(){return"human"===this.type},isSystemMessage(){return"system"===this.type}}},Ue=(0,A.A)(Fe,[["render",function(e,t,s,n,o,r){return(0,a.openBlock)(),(0,a.CE)("div",{class:(0,a.C4)(["message-bubble flex flex-col gap-1",{"ai-message":r.isAiMessage,"human-message":r.isHumanMessage,"system-message":r.isSystemMessage,[`system-${s.variant}`]:s.variant}])},[(0,a.RG)(e.$slots,"default",{},void 0,!0)],2)}],["__scopeId","data-v-087440d9"]]);const $e={class:"guide-flows"},We={class:"section-title"},He={key:0,class:"resources-grid"};function Qe({intervalMs:e=350,shallow:t=!1}={}){const s=(0,a.KR)([]),n=(0,a.KR)([]),{doWhile:o}=(0,ge.A)(),r=(0,a.KR)(!1);async function l(a=[]){s.value=t?a.map(u):a,await o(()=>s.value.length!==n.value.length,async()=>{if(!Array.isArray(s.value)||0===s.value.length)return;const e=u(s.value[n.value.length]),a=c(),o=t?!!a?.streamed:Object.values(a??{}).every(e=>e.streamed);a?o&&n.value.push(e):n.value.push(e),n.value.length===s.value.length&&(r.value=!0)},{intervalMs:e})}function i(e){e.value=e,n.value=e.map(u),r.value=!1}function c(){return n.value[n.value.length-1]}function d(e,s){t?n.value[e].streamed=!0:n.value[e][s].streamed=!0}function u(e={}){return t?{...e,streamed:!1}:Object.fromEntries(Object.entries(e).map(([e,t])=>[e,{streamable:t,streamed:!1}]))}return{addItemsSequentially:l,addItems:i,initStreamer:async function(e,{shouldStream:t=!1}={}){if(!t)return i(e),Promise.resolve();await l(e)},hasFinishedStreaming:r,items:s,getLastVisibleItem:c,setSubItemStreamedState:d,updateCardStreamingState:function(e,t){Object.keys(e).forEach(e=>{d(t,e)})},visibleItems:n}}const De={class:"flex flex-col gap-3 p-3 bg-white border border-gray-200 rounded-lg"},qe={class:"flex items-start gap-2"},ze={class:"flex-1 flex flex-col gap-1 min-w-0"},je={class:"flex items-start justify-between gap-2"},Ke={class:"text-sm font-medium text-gray-900 overflow-hidden text-ellipsis whitespace-nowrap flex-1 min-w-0"},Ge={class:"flex items-start gap-2 shrink-0 -mt-1"},Je={key:0,class:"text-xs text-gray-500 overflow-hidden text-ellipsis whitespace-nowrap"};var Ye=s(72615),Xe=s(22118),Ze=s(45964),et=s(60926),tt={name:"StandardResourceCard",components:{StreamableContent:Re,TextCopier:Ze.A,FlowViewer:et.A,ChevronUpIcon:Ye.A,ChevronDownIcon:Xe.A},props:{flow:{type:Object,required:!0},shouldStream:{type:Boolean,required:!1,default:!1}},emits:["streaming-complete"],data(){return{flowsExpanded:!0,flowTitle:this.flow.title,flowUrl:this.flow.url,flowMetadata:this.flow.metadata}},computed:{...(0,r.aH)(ee.i,["canImportFlows"]),flowsJson(){return this.flowMetadata?JSON.stringify(this.flowMetadata.streamable.flows,null,2):""}},watch:{flowMetadata(e){e.streamed&&this.$emit("streaming-complete")}},methods:{...(0,r.i0)(F.u,["sendFlowsToImport"]),importFlows(){this.sendFlowsToImport(this.flowsJson)},completeStreaming(){this.flowMetadata&&(this.flowMetadata.streamed=!0),this.$emit("streaming-complete")}}},st={name:"ListFlows",components:{StreamableContent:Re,FlowResourceCard:(0,A.A)(tt,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content"),i=(0,a.g2)("chevron-down-icon"),c=(0,a.g2)("chevron-up-icon"),d=(0,a.g2)("text-copier"),u=(0,a.g2)("ff-button"),m=(0,a.g2)("flow-viewer");return(0,a.openBlock)(),(0,a.CE)("div",De,[(0,a.Lk)("div",qe,[t[4]||(t[4]=(0,a.Fv)('<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="none" viewBox="0 0 24 24" class="shrink-0 w-4 h-4 mt-0.5" data-v-7fbd3436><rect width="24" height="24" fill="var(--ff-color-icon-flow-bg)" rx="4" data-v-7fbd3436></rect><g clip-path="url(#a)" data-v-7fbd3436><path fill="var(--ff-color-icon-flow-fg)" d="M0 12v-1.647c5.09 0 5.81-.9 6.44-1.695.72-.9 1.46-1.6 3.88-1.6v1.648c-1.76 0-2.04.354-2.51.948C6.79 10.937 5.5 12 0 12Z" data-v-7fbd3436></path><path fill="var(--ff-color-icon-flow-fg)" d="M8.6 16.941c-2.9 0-3.47-1.513-3.88-2.614C4.25 13.072 3.85 12 0 12v-1.647c4.67 0 5.67 1.618 6.34 3.419.38 1.015.57 1.522 2.26 1.522v1.647Z" data-v-7fbd3436></path><path fill="var(--ff-color-icon-flow-fg)" d="M16.78 19H9.9c-.95 0-1.72-.737-1.72-1.647v-2.47c0-.91.77-1.648 1.72-1.648h6.88c.95 0 1.72.738 1.72 1.647v2.47c0 .91-.77 1.648-1.72 1.648Zm0-4.118H9.9v2.47h6.88v-2.47Zm1.5-4.117H11.4c-.95 0-1.72-.738-1.72-1.647v-2.47c0-.91.77-1.648 1.72-1.648h6.88c.95 0 1.72.737 1.72 1.647v2.47c0 .91-.77 1.648-1.72 1.648Zm0-4.118H11.4v2.47h6.88v-2.47Z" data-v-7fbd3436></path></g><defs data-v-7fbd3436><clipPath id="a" data-v-7fbd3436><path fill="var(--ff-color-icon-flow-fg)" d="M0 5h20v14H0z" data-v-7fbd3436></path></clipPath></defs></svg>',1)),(0,a.Lk)("div",ze,[(0,a.Lk)("div",je,[(0,a.Lk)("div",Ke,[(0,a.createVNode)(l,{modelValue:o.flowTitle,"onUpdate:modelValue":t[0]||(t[0]=e=>o.flowTitle=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])]),(0,a.Lk)("div",Ge,[(0,a.Lk)("button",{class:"text-gray-600 hover:text-indigo-600 hover:bg-indigo-50 flex items-center transition-colors duration-200 rounded-sm px-2 py-1",onClick:t[1]||(t[1]=e=>o.flowsExpanded=!o.flowsExpanded)},[t[2]||(t[2]=(0,a.Lk)("span",null,"Preview",-1)),o.flowsExpanded?((0,a.openBlock)(),(0,a.createBlock)(i,{key:0,class:"h-4 w-4"})):(0,a.Q3)("v-if",!0),o.flowsExpanded?(0,a.Q3)("v-if",!0):((0,a.openBlock)(),(0,a.createBlock)(c,{key:1,class:"h-4 w-4"}))]),e.canImportFlows?((0,a.openBlock)(),(0,a.createBlock)(u,{key:1,size:"small",kind:"secondary",onClick:r.importFlows},{default:(0,a.k6)(()=>[...t[3]||(t[3]=[(0,a.eW)("Import",-1)])]),_:1},8,["onClick"])):((0,a.openBlock)(),(0,a.createBlock)(d,{key:0,text:r.flowsJson,showText:!1},null,8,["text"]))])]),o.flowMetadata?((0,a.openBlock)(),(0,a.CE)("div",Je,[!s.shouldStream||o.flowTitle.streamed?((0,a.openBlock)(),(0,a.createBlock)(l,{key:0,string:o.flowMetadata.streamable.category,"should-stream":s.shouldStream,onStreamingComplete:r.completeStreaming},null,8,["string","should-stream","onStreamingComplete"])):(0,a.Q3)("v-if",!0)])):(0,a.Q3)("v-if",!0)])]),o.flowMetadata?((0,a.openBlock)(),(0,a.CE)("div",{key:0,class:(0,a.C4)(["flex overflow-auto ml-8 max-h-[500px] flex-col relative",{hidden:o.flowsExpanded}])},[o.flowsExpanded?(0,a.Q3)("v-if",!0):((0,a.openBlock)(),(0,a.createBlock)(m,{key:0,flow:s.flow.metadata.streamable.flows},null,8,["flow"]))],2)):(0,a.Q3)("v-if",!0)])}],["__scopeId","data-v-7fbd3436"]])},props:{flows:{type:Array,required:!0},shouldStream:{type:Boolean,default:!1}},emits:["streaming-complete"],setup(){const{initStreamer:e,updateCardStreamingState:t,visibleItems:s,items:a}=Qe();return{initStreamer:e,updateCardStreamingState:t,visibleItems:s,items:a}},data(){return{streamingTitle:{streamable:"Related Flows",streamed:!1}}},async mounted(){const e=this.flows.map(e=>({title:e.title,url:e.url,metadata:e.metadata}));await this.initStreamer(e,{shouldStream:this.shouldStream}),this.$emit("streaming-complete")}},at=(0,A.A)(st,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content"),i=(0,a.g2)("FlowResourceCard");return(0,a.openBlock)(),(0,a.CE)(a.FK,null,[(0,a.Q3)(" Resources Section "),(0,a.Lk)("div",$e,[(0,a.Lk)("h4",We,[(0,a.createVNode)(l,{modelValue:o.streamingTitle,"onUpdate:modelValue":t[0]||(t[0]=e=>o.streamingTitle=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])]),o.streamingTitle.streamed?((0,a.openBlock)(),(0,a.CE)("div",He,[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(n.visibleItems,(e,t)=>((0,a.openBlock)(),(0,a.createBlock)(i,{key:t,flow:e,"should-stream":s.shouldStream,onStreamingComplete:s=>n.updateCardStreamingState(e,t)},null,8,["flow","should-stream","onStreamingComplete"]))),128))])):(0,a.Q3)("v-if",!0)])],2112)}],["__scopeId","data-v-67b38b2a"]]);const nt={class:"guide-steps"},ot={class:"section-title"},rt={class:"steps-list"},lt={class:"step-number"},it={class:"step-content"},ct={class:"step-title"},dt={key:0,class:"step-detail"};var ut={name:"GuideStepsList",components:{StreamableContent:Re},props:{steps:{required:!0,type:Array},shouldStream:{type:Boolean,default:!1}},emits:["streaming-complete"],setup(){const{initStreamer:e,visibleItems:t}=Qe();return{initStreamer:e,visibleItems:t}},async mounted(){await this.initStreamer(this.steps,{shouldStream:this.shouldStream}),this.$emit("streaming-complete")}},mt=(0,A.A)(ut,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content");return(0,a.openBlock)(),(0,a.CE)("div",nt,[(0,a.Lk)("h4",ot,[(0,a.createVNode)(l,{string:"Steps:","should-stream":s.shouldStream},null,8,["should-stream"])]),(0,a.Lk)("ol",rt,[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(n.visibleItems,(e,t)=>((0,a.openBlock)(),(0,a.CE)("li",{key:t,class:"step-item"},[(0,a.Lk)("div",lt,(0,a.v_)(t+1),1),(0,a.Lk)("div",it,[(0,a.Lk)("h5",ct,[(0,a.createVNode)(l,{modelValue:e.title,"onUpdate:modelValue":t=>e.title=t,"should-stream":s.shouldStream},null,8,["modelValue","onUpdate:modelValue","should-stream"])]),!s.shouldStream||e.title.streamed?((0,a.openBlock)(),(0,a.CE)("p",dt,[(0,a.createVNode)(l,{modelValue:e.detail,"onUpdate:modelValue":t=>e.detail=t,"should-stream":s.shouldStream},null,8,["modelValue","onUpdate:modelValue","should-stream"])])):(0,a.Q3)("v-if",!0)])]))),128))])])}],["__scopeId","data-v-d910bc14"]]);const pt={class:"issues"};var ht={name:"IssuesList",components:{StreamableContent:Re},props:{issues:{type:Array,required:!0},shouldStream:{type:Boolean,default:!1}},emits:["streaming-complete"],setup(){const{initStreamer:e,setSubItemStreamedState:t,visibleItems:s,items:a}=Qe();return{initStreamer:e,setSubItemStreamedState:t,visibleItems:s,items:a,sanitize:T.aj}},data(){return{streamedTitle:{streamable:"Issues",streamed:!1}}},async mounted(){const e=this.issues.map(e=>({content:e}));await this.initStreamer(e,{shouldStream:this.shouldStream}),this.$emit("streaming-complete")}},gt=(0,A.A)(ht,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("exclamation-icon"),i=(0,a.g2)("streamable-content");return(0,a.openBlock)(),(0,a.CE)("div",pt,[(0,a.Lk)("h4",null,[(0,a.createVNode)(l,{class:"ff-icon"}),(0,a.createVNode)(i,{modelValue:o.streamedTitle,"onUpdate:modelValue":t[0]||(t[0]=e=>o.streamedTitle=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])]),(0,a.Lk)("ul",null,[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(n.visibleItems,(e,t)=>((0,a.openBlock)(),(0,a.CE)("li",{key:t},[(0,a.createVNode)(i,{"rich-content":!0,string:e.content.streamable,"should-stream":s.shouldStream,onStreamingComplete:e=>n.setSubItemStreamedState(t,"content")},null,8,["string","should-stream","onStreamingComplete"])]))),128))])])}],["__scopeId","data-v-95f9e4ca"]]);const ft={class:"guide-packages"},kt={class:"section-title"},vt={key:0,class:"packages-list"},bt=["href"],St=["src"],Ct={class:"package-info"},wt={class:"package-text"},yt=["title"],xt={class:"package-url"},Bt={class:"package-actions"};var It={name:"PackageResourceCard",components:{StreamableContent:Re},props:{nodePackage:{type:Object,required:!0},shouldStream:{type:Boolean,default:!1}},emits:["streaming-complete"],setup(e){const t=(0,a.EW)(()=>{const t=e.nodePackage;return"object"==typeof t?t.id.streamable||t.name.streamable:t}),s=(0,a.EW)(()=>{const s=e.nodePackage;return s?s.url.streamable||s.metadata?.streamable?.source||s.metadata?.streamable?.url||`https://flows.nodered.org/node/${t.value}`:"https://flows.nodered.org/"});return{packageName:t,packageUrl:s}},data(){return{streamablePackageName:{streamable:this.packageName,streamed:!1},streamablePackageUrl:{streamable:this.packageUrl,streamed:!1}}},computed:{...(0,r.aH)(ee.i,["canManagePalette"]),...(0,r.aH)(F.u,["palette"]),packageFaviconUrl(){const e=this.nodePackage.metadata?.streamable?.source||this.nodePackage.url.streamable;try{return`https://www.google.com/s2/favicons?domain=${new URL(e).hostname}`}catch(e){return"flows.nodered.org"}},isCorePackage(){return"core-node"===this.nodePackage.type.streamable||this.packageName.startsWith("node-red:")},isPackageInstalled(){const e=this.nodePackage;return!!this.palette?.[e.id.streamable]},urlWithUTMTracking(){const e=this.packageUrl;try{const t=new URL(e);return t.searchParams.set("utm_source","flowfuse-expert"),t.searchParams.set("utm_medium","assistant"),t.searchParams.set("utm_campaign","expert-chat"),t.toString()}catch(t){return e}}},watch:{streamablePackageUrl(e){e.streamed&&this.$emit("streaming-complete")}},methods:{...(0,r.i0)(F.u,["installNodePackage","manageNodePackage"]),handleImageError(e){e.target.style.display="none"},installPackage(){this.installNodePackage(this.packageName)},managePackage(){this.manageNodePackage(this.packageName)}}},At={name:"ListPackages",components:{StreamableContent:Re,PackageResourceCard:(0,A.A)(It,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content"),i=(0,a.g2)("ff-button");return(0,a.openBlock)(),(0,a.CE)("a",{href:r.urlWithUTMTracking,target:"_blank",rel:"noopener noreferrer",class:"package-card"},[(0,a.Lk)("img",{src:r.packageFaviconUrl,alt:"Node-RED",class:"package-favicon",onError:t[0]||(t[0]=(...e)=>r.handleImageError&&r.handleImageError(...e))},null,40,St),(0,a.Lk)("div",Ct,[(0,a.Lk)("div",wt,[(0,a.Lk)("div",{class:"package-name",title:n.packageName},[(0,a.createVNode)(l,{modelValue:o.streamablePackageName,"onUpdate:modelValue":t[1]||(t[1]=e=>o.streamablePackageName=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])],8,yt),(0,a.Lk)("div",xt,[!s.shouldStream||o.streamablePackageName.streamed?((0,a.openBlock)(),(0,a.createBlock)(l,{key:0,modelValue:o.streamablePackageUrl,"onUpdate:modelValue":t[2]||(t[2]=e=>o.streamablePackageUrl=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])):(0,a.Q3)("v-if",!0)])]),(0,a.Lk)("div",Bt,[e.canManagePalette&&!r.isCorePackage?((0,a.openBlock)(),(0,a.CE)(a.FK,{key:0},[r.isPackageInstalled?((0,a.openBlock)(),(0,a.createBlock)(i,{key:0,class:"w-20",size:"small",kind:"secondary",onClick:t[3]||(t[3]=(0,a.D$)(e=>r.managePackage(s.nodePackage),["stop","prevent"]))},{default:(0,a.k6)(()=>[...t[5]||(t[5]=[(0,a.eW)("Manage ",-1)])]),_:1})):((0,a.openBlock)(),(0,a.createBlock)(i,{key:1,class:"w-20",size:"small",kind:"secondary",onClick:t[4]||(t[4]=(0,a.D$)(e=>r.installPackage(s.nodePackage),["stop","prevent"]))},{default:(0,a.k6)(()=>[...t[6]||(t[6]=[(0,a.eW)("Install ",-1)])]),_:1}))],64)):(0,a.Q3)("v-if",!0)])])],8,bt)}],["__scopeId","data-v-2c4e6fb7"]])},props:{packages:{required:!0,type:Array},shouldStream:{type:Boolean,default:!1}},emits:["streaming-complete"],setup(){const{initStreamer:e,updateCardStreamingState:t,visibleItems:s,items:a}=Qe();return{initStreamer:e,updateCardStreamingState:t,visibleItems:s,items:a}},data(){return{packagesTitle:{streamable:"Required Node Packages",streamed:!1}}},async mounted(){const e=this.packages.map(e=>({id:e.id,name:e.name,title:e.title,url:e.url,type:e.type,metadata:e.metadata,hostname:e.hostname}));await this.initStreamer(e,{shouldStream:this.shouldStream}),this.$emit("streaming-complete")}},Et=(0,A.A)(At,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content"),i=(0,a.g2)("PackageResourceCard");return(0,a.openBlock)(),(0,a.CE)("div",ft,[(0,a.Lk)("h4",kt,[(0,a.createVNode)(l,{modelValue:o.packagesTitle,"onUpdate:modelValue":t[0]||(t[0]=e=>o.packagesTitle=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])]),!s.shouldStream||o.packagesTitle.streamed?((0,a.openBlock)(),(0,a.CE)("div",vt,[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(n.visibleItems,(e,t)=>((0,a.openBlock)(),(0,a.createBlock)(i,{key:t,nodePackage:e,"should-stream":s.shouldStream,onStreamingComplete:s=>n.updateCardStreamingState(e,t)},null,8,["nodePackage","should-stream","onStreamingComplete"]))),128))])):(0,a.Q3)("v-if",!0)])}],["__scopeId","data-v-3402c91e"]]);const Lt={key:0,class:"guide-resources"},Tt={class:"section-title"},_t={key:0,class:"resources-grid"},Vt=["href"],Mt=["src","alt"],Pt={class:"resource-info"},Rt=["title"],Ot={key:0,class:"resource-url"};var Nt={name:"StandardResourceCard",components:{StreamableContent:Re},props:{resource:{type:Object,required:!0},shouldStream:{type:Boolean,required:!1,default:!1}},emits:["streaming-complete"],data(){return{resourceUrl:this.resource.metadata?.streamable.source||this.resource.streamable.url,resourceTitle:{...this.resource.title},resourceMetadataSource:this.resource.metadata?.source}},computed:{favIconUrl(){const e=this.resourceUrl;try{return`https://www.google.com/s2/favicons?domain=${new URL(e).hostname}`}catch(e){return""}},urlWithUtmTracking(){const e=this.resourceUrl;try{const t=new URL(e);return t.searchParams.set("utm_source","flowfuse-expert"),t.searchParams.set("utm_medium","assistant"),t.searchParams.set("utm_campaign","expert-chat"),t.toString()}catch(t){return e}}},watch:{resourceTitle(e){e.streamed&&this.$emit("streaming-complete")}},methods:{handleImageError(e){e.target.style.display="none"}}},Ft={name:"ListResources",components:{StreamableContent:Re,StandardResourceCard:(0,A.A)(Nt,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content");return(0,a.openBlock)(),(0,a.CE)(a.FK,null,[(0,a.Q3)(" todo clean resource.url references after transitioning to v4 api "),(0,a.Lk)("a",{href:r.urlWithUtmTracking,target:"_blank",rel:"noopener noreferrer",class:"resource-card"},[(0,a.Lk)("img",{src:r.favIconUrl,alt:s.resource.type,class:"resource-icon",onError:t[0]||(t[0]=(...e)=>r.handleImageError&&r.handleImageError(...e))},null,40,Mt),(0,a.Lk)("div",Pt,[(0,a.Lk)("div",{class:"resource-title",title:o.resourceTitle.streamable},[(0,a.createVNode)(l,{modelValue:o.resourceTitle,"onUpdate:modelValue":t[1]||(t[1]=e=>o.resourceTitle=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])],8,Rt),!s.shouldStream||o.resourceTitle.streamed?((0,a.openBlock)(),(0,a.CE)("div",Ot,[o.resourceMetadataSource?((0,a.openBlock)(),(0,a.createBlock)(l,{key:0,modelValue:o.resourceMetadataSource,"onUpdate:modelValue":t[2]||(t[2]=e=>o.resourceMetadataSource=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])):s.resource.url?((0,a.openBlock)(),(0,a.createBlock)(l,{key:1,string:o.resourceUrl,"should-stream":s.shouldStream},null,8,["string","should-stream"])):(0,a.Q3)("v-if",!0)])):(0,a.Q3)("v-if",!0)])],8,Vt)],2112)}],["__scopeId","data-v-7aeaa1eb"]])},props:{resources:{type:Array,required:!0},shouldStream:{type:Boolean,default:!1}},emits:["streaming-complete"],setup(){const{initStreamer:e,updateCardStreamingState:t,visibleItems:s,items:a}=Qe();return{initStreamer:e,updateCardStreamingState:t,visibleItems:s,items:a}},data(){return{resourceTitle:{streamable:"Related Resources",streamed:!1}}},async mounted(){const e=this.resources.map(e=>({title:e.title,url:e.url,metadata:e.metadata}));await this.initStreamer(e,{shouldStream:this.shouldStream}),this.$emit("streaming-complete")}},Ut=(0,A.A)(Ft,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content"),i=(0,a.g2)("StandardResourceCard");return s.resources&&s.resources.length>0?((0,a.openBlock)(),(0,a.CE)("div",Lt,[(0,a.Lk)("h4",Tt,[(0,a.createVNode)(l,{modelValue:o.resourceTitle,"onUpdate:modelValue":t[0]||(t[0]=e=>o.resourceTitle=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])]),!s.shouldStream||o.resourceTitle.streamed?((0,a.openBlock)(),(0,a.CE)("div",_t,[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(n.visibleItems,(e,t)=>((0,a.openBlock)(),(0,a.createBlock)(i,{key:t,resource:e,"should-stream":s.shouldStream,onStreamingComplete:s=>n.updateCardStreamingState(e,t)},null,8,["resource","should-stream","onStreamingComplete"]))),128))])):(0,a.Q3)("v-if",!0)])):(0,a.Q3)("v-if",!0)}],["__scopeId","data-v-e0cd57b2"]]),$t={name:"RichContent",components:{StreamableContent:Re},props:{content:{required:!0,type:String},messageUuid:{required:!0,type:String},answerUuid:{required:!0,type:String},shouldStream:{required:!0,type:Boolean}},emits:["streaming-complete"],setup(){const{text:e,isStreaming:t,stream:s,stop:a}=Me({delayMs:30});return{sanitize:T.aj,text:e,isStreaming:t,stream:s,stop:a}},async mounted(){this.shouldStream||await this.onStreamComplete()},methods:{...(0,r.i0)(ee.i,["updateAnswerStreamedState"]),async onStreamComplete(){await this.updateAnswerStreamedState({messageUuid:this.messageUuid,answerUuid:this.answerUuid}),this.$emit("streaming-complete")}}},Wt=(0,A.A)($t,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content");return(0,a.openBlock)(),(0,a.createBlock)(l,{string:s.content,"should-stream":s.shouldStream,"rich-content":!0,onStreamingComplete:r.onStreamComplete},null,8,["string","should-stream","onStreamingComplete"])}]]);const Ht={class:"suggestions"},Qt={key:0};var Dt={name:"SuggestionsList",components:{StreamableContent:Re,InformationCircleIcon:s(14811).A},props:{suggestions:{type:Array,required:!0},shouldStream:{type:Boolean,default:!1}},emits:["streaming-complete"],setup(){const{initStreamer:e,setSubItemStreamedState:t,visibleItems:s,items:a}=Qe();return{initStreamer:e,setSubItemStreamedState:t,visibleItems:s,items:a}},data(){return{streamingTitle:{streamable:"Suggestions",streamed:!1}}},async mounted(){const e=this.suggestions.map(e=>({content:e}));await this.initStreamer(e,{shouldStream:this.shouldStream}),this.$emit("streaming-complete")}},qt={name:"AnswerWrapper",components:{SuggestionsList:(0,A.A)(Dt,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("information-circle-icon"),i=(0,a.g2)("streamable-content");return(0,a.openBlock)(),(0,a.CE)("div",Ht,[(0,a.Lk)("h4",null,[(0,a.createVNode)(l,{class:"ff-icon"}),(0,a.createVNode)(i,{modelValue:o.streamingTitle,"onUpdate:modelValue":t[0]||(t[0]=e=>o.streamingTitle=e),"should-stream":s.shouldStream},null,8,["modelValue","should-stream"])]),!s.shouldStream||o.streamingTitle.streamed?((0,a.openBlock)(),(0,a.CE)("ul",Qt,[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(n.visibleItems,(e,t)=>((0,a.openBlock)(),(0,a.CE)("li",{key:t},[(0,a.createVNode)(i,{"rich-content":!0,string:e.content.streamable,"should-stream":s.shouldStream,onStreamingComplete:e=>n.setSubItemStreamedState(t,"content")},null,8,["string","should-stream","onStreamingComplete"])]))),128))])):(0,a.Q3)("v-if",!0)])}],["__scopeId","data-v-be07e6bc"]]),RichContent:Wt,PackagesList:Et,FlowsList:at,AnswerBadge:ve,ResourcesList:Ut,GuideStepsList:mt,MessageBubble:Ue,GuideHeader:Ne,IssuesList:gt},props:{answer:{type:Object,required:!0},messageUuid:{type:String,required:!0}},emits:["streaming-complete"],setup(){const{waitFor:e}=(0,ge.A)();return{waitFor:e}},data(){return{componentStreamingOrder:[],streamedComponents:[]}},computed:{...(0,r.aH)(F.u,["supportedActions"]),...(0,r.aH)(ee.i,["agentMode"]),hasGuideHeader(){return!(!this.answer.title||this.isChatAnswer)},hasGuideSteps(){return Object.hasOwnProperty.call(this.answer,"steps")&&this.answer.steps.length>0},hasResources(){return Object.hasOwnProperty.call(this.answer,"resources")&&this.answer.resources.length>0},hasNodePackages(){return this.answer.nodePackages&&this.answer.nodePackages.length>0},hasFlows(){return this.answer.flows&&this.answer.flows.length>0},hasSuggestions(){return this.answer.suggestions&&this.answer.suggestions.length>0},hasIssues(){return this.answer.issues&&this.answer.issues.length>0},hasPlainContent(){return this.answer.content&&this.answer.content.length>0},isChatAnswer(){return!Object.hasOwnProperty.call(this.answer,"kind")||"chat"===this.answer.kind},isEditorContext(){return this.$route?.name?.includes("editor")||!1},shouldShowRichContent(){const e="rich-content";return!!this.componentStreamingOrder.includes(e)&&!!this.hasPlainContent&&(0===this.componentStreamingOrder.indexOf(e)||this.streamedComponents.length>=this.componentStreamingOrder.indexOf(e))},shouldShowGuideHeader(){const e="guide-header";return!!this.componentStreamingOrder.includes(e)&&!!this.hasGuideHeader&&(0===this.componentStreamingOrder.indexOf(e)||this.streamedComponents.length>=this.componentStreamingOrder.indexOf(e))},shouldShowGuideStepList(){const e="guide-steps-list";return!!this.componentStreamingOrder.includes(e)&&!!this.hasGuideSteps&&(0===this.componentStreamingOrder.indexOf(e)||this.streamedComponents.length>=this.componentStreamingOrder.indexOf(e))},shouldShowResourcesList(){const e="resources-list";return!!this.componentStreamingOrder.includes(e)&&!!this.hasResources&&(0===this.componentStreamingOrder.indexOf(e)||this.streamedComponents.length>=this.componentStreamingOrder.indexOf(e))},shouldShowFlowsList(){const e="flows-list";return!!this.componentStreamingOrder.includes(e)&&!!this.hasFlows&&(0===this.componentStreamingOrder.indexOf(e)||this.streamedComponents.length>=this.componentStreamingOrder.indexOf(e))},shouldShowPackagesList(){const e="packages-list";return!!this.componentStreamingOrder.includes(e)&&!!this.hasNodePackages&&(0===this.componentStreamingOrder.indexOf(e)||this.streamedComponents.length>=this.componentStreamingOrder.indexOf(e))},shouldShowSuggestionsList(){const e="suggestions-list";return!!this.componentStreamingOrder.includes(e)&&!!this.hasSuggestions&&(0===this.componentStreamingOrder.indexOf(e)||this.streamedComponents.length>=this.componentStreamingOrder.indexOf(e))},shouldShowIssuesList(){const e="issues-list";return!!this.componentStreamingOrder.includes(e)&&!!this.hasIssues&&(0===this.componentStreamingOrder.indexOf(e)||this.streamedComponents.length>=this.componentStreamingOrder.indexOf(e))},shouldStream(){return!this.answer._streamed}},watch:{streamedComponents(){this.componentStreamingOrder.length===this.streamedComponents.length&&(this.updateAnswerStreamedState({messageUuid:this.messageUuid,answerUuid:this.answer._uuid}),this.$emit("streaming-complete"))}},beforeUnmount(){this.updateAnswerStreamedState({messageUuid:this.messageUuid,answerUuid:this.answer._uuid,agent:this.agentMode}),this.isEditorContext&&this.$refs.messageBubble.$el.removeEventListener("click",this.handleClick)},mounted(){this.buildStreamingOrder(),this.isEditorContext&&this.$refs.messageBubble.$el.addEventListener("click",this.handleClick)},methods:{...(0,r.i0)(ee.i,["updateAnswerStreamedState"]),buildStreamingOrder(){this.hasPlainContent&&this.componentStreamingOrder.push("rich-content"),this.hasGuideHeader&&this.componentStreamingOrder.push("guide-header"),this.hasGuideSteps&&this.componentStreamingOrder.push("guide-steps-list"),this.hasResources&&this.componentStreamingOrder.push("resources-list"),this.hasFlows&&this.componentStreamingOrder.push("flows-list"),this.hasNodePackages&&this.componentStreamingOrder.push("packages-list"),this.hasIssues&&this.componentStreamingOrder.push("issues-list"),this.hasSuggestions&&this.componentStreamingOrder.push("suggestions-list")},async onComponentComplete(e){this.shouldStream||await this.waitFor(200),this.streamedComponents.push(e)},handleClick(e){const t=e.target;if(!this.isEditorContext)return;if(!t)return;if("A"!==t.nodeName)return;if(!t.classList.contains("assistant-action-link"))return;if(!t.getAttribute("data-assistant-action-href"))return;if(!t.getAttribute("data-action"))return;const s=t.getAttribute("data-action"),a=this.supportedActions?.[s];if(!a)return;e.preventDefault(),e.stopPropagation();const n={};for(const e of t.attributes)if(e.name.startsWith("data-param-")){const t=e.name.replace("data-param-",""),s=a.params?.properties?.[t];if(!s)continue;const o=s.type;let r=e.value;"boolean"===o?r="true"===r:"number"===o&&(r=+r),n[t]=r}(0,F.u)().invokeAction({action:s,params:n})}}},zt=(0,A.A)(qt,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("answer-badge"),i=(0,a.g2)("rich-content"),c=(0,a.g2)("guide-header"),d=(0,a.g2)("guide-steps-list"),u=(0,a.g2)("resources-list"),m=(0,a.g2)("flows-list"),p=(0,a.g2)("packages-list"),h=(0,a.g2)("issues-list"),g=(0,a.g2)("suggestions-list"),f=(0,a.g2)("message-bubble");return(0,a.openBlock)(),(0,a.createBlock)(f,{ref:"messageBubble",type:"ai"},{default:(0,a.k6)(()=>[r.isChatAnswer?(0,a.Q3)("v-if",!0):((0,a.openBlock)(),(0,a.createBlock)(l,{key:0,kind:s.answer.kind},null,8,["kind"])),r.shouldShowRichContent?((0,a.openBlock)(),(0,a.createBlock)(i,{key:1,content:s.answer.content,"message-uuid":s.messageUuid,"answer-uuid":s.answer._uuid,"should-stream":r.shouldStream,class:"mb-3",onStreamingComplete:t[0]||(t[0]=e=>r.onComponentComplete("rich-content"))},null,8,["content","message-uuid","answer-uuid","should-stream"])):(0,a.Q3)("v-if",!0),r.shouldShowGuideHeader?((0,a.openBlock)(),(0,a.createBlock)(c,{key:2,title:s.answer.title,summary:s.answer.summary,"should-stream":r.shouldStream,class:"mt-3",onStreamingComplete:t[1]||(t[1]=e=>r.onComponentComplete("guide-header"))},null,8,["title","summary","should-stream"])):(0,a.Q3)("v-if",!0),r.shouldShowGuideStepList?((0,a.openBlock)(),(0,a.createBlock)(d,{key:3,steps:s.answer.steps,"should-stream":r.shouldStream,class:"mb-3",onStreamingComplete:t[2]||(t[2]=e=>r.onComponentComplete("guide-steps-list"))},null,8,["steps","should-stream"])):(0,a.Q3)("v-if",!0),r.shouldShowResourcesList?((0,a.openBlock)(),(0,a.createBlock)(u,{key:4,resources:s.answer.resources,"should-stream":r.shouldStream,class:"mb-3",onStreamingComplete:t[3]||(t[3]=e=>r.onComponentComplete("resources-list"))},null,8,["resources","should-stream"])):(0,a.Q3)("v-if",!0),r.shouldShowFlowsList?((0,a.openBlock)(),(0,a.createBlock)(m,{key:5,flows:s.answer.flows,"should-stream":r.shouldStream,class:"mb-3",onStreamingComplete:t[4]||(t[4]=e=>r.onComponentComplete("flows-list"))},null,8,["flows","should-stream"])):(0,a.Q3)("v-if",!0),r.shouldShowPackagesList?((0,a.openBlock)(),(0,a.createBlock)(p,{key:6,packages:s.answer.nodePackages,"should-stream":r.shouldStream,class:"mb-3",onStreamingComplete:t[5]||(t[5]=e=>r.onComponentComplete("packages-list"))},null,8,["packages","should-stream"])):(0,a.Q3)("v-if",!0),r.shouldShowIssuesList?((0,a.openBlock)(),(0,a.createBlock)(h,{key:7,issues:s.answer.issues,"should-stream":r.shouldStream,onStreamingComplete:t[6]||(t[6]=e=>r.onComponentComplete("issues-list"))},null,8,["issues","should-stream"])):(0,a.Q3)("v-if",!0),r.shouldShowSuggestionsList?((0,a.openBlock)(),(0,a.createBlock)(g,{key:8,suggestions:s.answer.suggestions,"should-stream":r.shouldStream,onStreamingComplete:t[7]||(t[7]=e=>r.onComponentComplete("suggestions-list"))},null,8,["suggestions","should-stream"])):(0,a.Q3)("v-if",!0)]),_:1},512)}]]);const jt={class:"ff-expert-tool-call"},Kt={class:"ff-expert-tool-call--count"},Gt={class:"ff-expert-tool-call--duration"};var Jt=s(23084);const Yt={class:"ff-expert-tool-call--item"},Xt={class:"ff-expert-tool-call--title"},Zt={class:"ff-expert-tool-call--name"},es=["title"],ts={class:"ff-expert-tool-call--section-duration"},ss={key:0,class:"ff-expert-tool-call--details"},as={key:0,class:"ff-expert-tool-call--section"},ns={key:0,class:"ff-expert-tool-call--code"},os=["innerHTML"],rs={key:1,class:"ff-expert-tool-call--section"},ls={key:0,class:"ff-expert-tool-call--code"},is=["innerHTML"];ye.A.registerLanguage("json",Ie.A);var cs={name:"ToolCallItem",components:{ChevronRightIcon:Jt.A},props:{tool:{type:Object,required:!0},expanded:{type:Boolean,default:!1}},data(){return{inputExpanded:!1,outputExpanded:!1}},methods:{formatKindBadge(e){return{mcp_tool:"T",mcp_resource:"R",mcp_resource_template:"RT",mcp_prompt:"P"}[e]||"?"},formatKindFull(e){return{mcp_tool:"MCP Tool",mcp_resource:"MCP Resource",mcp_resource_template:"MCP Resource Template",mcp_prompt:"MCP Prompt"}[e]||e||"Unknown"},hasContent(e){return null!=e&&(Array.isArray(e)?e.length>0:"object"==typeof e?Object.keys(e).length>0:"string"!=typeof e||""!==e.trim())},highlightJson(e){let t;if("string"==typeof e)try{t=JSON.stringify(JSON.parse(e),null,2)}catch{t=e}else t=JSON.stringify(e,null,2);return ye.A.highlight(t,{language:"json"}).value}}},ds=(0,A.A)(cs,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("ChevronRightIcon");return(0,a.openBlock)(),(0,a.CE)("div",Yt,[(0,a.Lk)("div",Xt,(0,a.v_)(s.tool.title||s.tool.name),1),(0,a.Lk)("div",Zt,[(0,a.Lk)("div",null,[(0,a.Lk)("span",{class:"ff-expert-tool-call--badge",title:r.formatKindFull(s.tool.kind)},(0,a.v_)(r.formatKindBadge(s.tool.kind)),9,es),(0,a.eW)(" "+(0,a.v_)(s.tool.name),1)]),(0,a.Lk)("span",ts,(0,a.v_)(s.tool.durationMs||0)+" ms",1)]),s.expanded?((0,a.openBlock)(),(0,a.CE)("div",ss,[(0,a.Q3)(" Input section (collapsible, expanded by default) "),r.hasContent(s.tool.args)?((0,a.openBlock)(),(0,a.CE)("div",as,[(0,a.Lk)("div",{class:"ff-expert-tool-call--section-header",onClick:t[0]||(t[0]=(0,a.D$)(e=>o.inputExpanded=!o.inputExpanded,["stop"]))},[(0,a.createVNode)(l,{class:(0,a.C4)(["ff-icon-small",{rotated:o.inputExpanded}])},null,8,["class"]),t[2]||(t[2]=(0,a.Lk)("span",{class:"ff-expert-tool-call--section-label"},"Input",-1))]),o.inputExpanded?((0,a.openBlock)(),(0,a.CE)("div",ns,[(0,a.Q3)(" eslint-disable-next-line vue/no-v-html "),(0,a.Lk)("pre",null,[(0,a.Lk)("code",{innerHTML:r.highlightJson(s.tool.args)},null,8,os)])])):(0,a.Q3)("v-if",!0)])):(0,a.Q3)("v-if",!0),(0,a.Q3)(" Output section (collapsible, collapsed by default) "),r.hasContent(s.tool.output)?((0,a.openBlock)(),(0,a.CE)("div",rs,[(0,a.Lk)("div",{class:"ff-expert-tool-call--section-header",onClick:t[1]||(t[1]=(0,a.D$)(e=>o.outputExpanded=!o.outputExpanded,["stop"]))},[(0,a.createVNode)(l,{class:(0,a.C4)(["ff-icon-small",{rotated:o.outputExpanded}])},null,8,["class"]),t[3]||(t[3]=(0,a.Lk)("span",{class:"ff-expert-tool-call--section-label"},"Output",-1))]),o.outputExpanded?((0,a.openBlock)(),(0,a.CE)("div",ls,[(0,a.Q3)(" eslint-disable-next-line vue/no-v-html "),(0,a.Lk)("pre",null,[(0,a.Lk)("code",{innerHTML:r.highlightJson(s.tool.output)},null,8,is)])])):(0,a.Q3)("v-if",!0)])):(0,a.Q3)("v-if",!0)])):(0,a.Q3)("v-if",!0)])}],["__scopeId","data-v-3f837657"]]),us={name:"ToolCalls",components:{ChevronRightIcon:Jt.A,ToolCallItem:ds},props:{message:{type:Object,required:!0,validator:e=>Array.isArray(e.toolCalls)}},data(){return{expanded:!1}},computed:{toolCalls(){return this.message.toolCalls||[]},toolCallCount(){return this.toolCalls.length},formattedDuration(){const e=this.message.duration;if(null==e)return 0;const t="string"==typeof e?parseFloat(e):e;return Math.round(1e3*t)}},methods:{toggleExpanded(){this.expanded=!this.expanded}}},ms={name:"AiMessage",components:{ToolCalls:(0,A.A)(us,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("ChevronRightIcon"),i=(0,a.g2)("ToolCallItem");return(0,a.openBlock)(),(0,a.CE)("div",jt,[(0,a.Lk)("div",{class:"ff-expert-tool-call--header",onClick:t[0]||(t[0]=(...e)=>r.toggleExpanded&&r.toggleExpanded(...e))},[(0,a.createVNode)(l,{class:(0,a.C4)(["ff-icon",{rotated:o.expanded}])},null,8,["class"]),(0,a.Lk)("span",Kt,(0,a.v_)(r.toolCallCount)+" tool call"+(0,a.v_)(r.toolCallCount>1?"s":""),1),(0,a.Lk)("span",Gt,(0,a.v_)(r.formattedDuration)+" ms ",1)]),(0,a.Lk)("div",{class:(0,a.C4)(["ff-expert-tool-call--body",{"is-expanded":o.expanded}])},[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(r.toolCalls,e=>((0,a.openBlock)(),(0,a.createBlock)(i,{key:e.id,tool:e,expanded:o.expanded},null,8,["tool","expanded"]))),128))],2)])}],["__scopeId","data-v-741c64ce"]]),AnswerWrapper:zt},props:{query:{type:String,required:!1,default:null},answer:{type:Object,required:!0},timings:{required:!1,default:null,type:Object},_type:{type:String,required:!0},_timestamp:{required:!0,type:Number},_uuid:{required:!0,type:String},_streamed:{required:!0,type:Boolean}},setup(){const{initStreamer:e,setSubItemStreamedState:t,visibleItems:s,items:a}=Qe({shallow:!0});return{initStreamer:e,setSubItemStreamedState:t,visibleItems:s,items:a}},computed:{toolCalls(){const e=this.answer.filter(e=>["mcp_tool","mcp_resource","mcp_resource_template","mcp_prompt"].includes(e.kind));if(e.length>0){const t=e.map(e=>({id:e.toolId,name:e.toolName,title:e.toolTitle||e.toolName,kind:e.kind,args:e.input,output:e.output,durationMs:e.durationMs}));return{type:"ai",kind:"tool_calls",toolCalls:t,duration:(e.reduce((e,t)=>e+(t.durationMs||0),0)/1e3).toFixed(2),content:`${t.length} tool call(s)`,timestamp:Date.now()}}return null},filteredAnswers(){return this.answer.filter(e=>!["mcp_tool","mcp_resource","mcp_resource_template","mcp_prompt"].includes(e.kind))}},async mounted(){await this.initStreamer(this.filteredAnswers,{shouldStream:!this._streamed})},methods:{slugify:T.Yv}},ps=(0,A.A)(ms,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("tool-calls"),i=(0,a.g2)("answer-wrapper");return(0,a.openBlock)(),(0,a.CE)("div",he,[r.toolCalls?((0,a.openBlock)(),(0,a.createBlock)(l,{key:0,message:r.toolCalls},null,8,["message"])):(0,a.Q3)("v-if",!0),((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(n.visibleItems,(e,t)=>((0,a.openBlock)(),(0,a.createBlock)(i,{key:r.slugify(`${e.kind}-${e.title}-${e.summary}-${e._uuid}`),"message-uuid":s._uuid,answer:e,onStreamingComplete:e=>n.setSubItemStreamedState(t)},null,8,["message-uuid","answer","onStreamingComplete"]))),128))])}]]),hs={name:"HumanMessage",components:{StreamableContent:Re,MessageBubble:Ue},props:{content:{required:!0,type:String},_timestamp:{required:!0,type:Number},_type:{required:!0,type:String}}},gs=(0,A.A)(hs,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("streamable-content"),i=(0,a.g2)("message-bubble");return(0,a.openBlock)(),(0,a.createBlock)(i,{type:"human"},{default:(0,a.k6)(()=>[(0,a.createVNode)(l,{string:s.content,"rich-content":!0,"should-stream":!1},null,8,["string"])]),_:1})}]]),fs={name:"SystemMessage",components:{MessageBubble:Ue},props:{_type:{type:String,required:!0},_variant:{type:String,required:!0},message:{type:String,required:!0},_timestamp:{type:Number,required:!0}}},ks=(0,A.A)(fs,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("message-bubble");return(0,a.openBlock)(),(0,a.createBlock)(l,{type:"system",variant:s._variant},{default:(0,a.k6)(()=>[(0,a.eW)((0,a.v_)(s.message),1)]),_:1},8,["variant"])}]]),vs=s(66461),bs={name:"ExpertMessages",components:{ExpertLoadingIndicator:pe},emits:["resizing"],data(){return{resizeObserver:null,lastHeight:null}},computed:{...(0,r.aH)(ee.i,["messages","isWaitingForResponse"]),messageTypes(){return{ai:(0,a.IG)(ps),human:(0,a.IG)(gs),system:(0,a.IG)(ks)}}},mounted(){this.mountResizeObserver(),window.addEventListener("keydown",this.onKeyDown)},beforeUnmount(){this.unmountResizeObserver(),window.removeEventListener("keydown",this.onKeyDown)},methods:{onKeyDown(e){e.altKey&&e.shiftKey&&"d"===e.key.toLowerCase()&&(e.preventDefault(),(0,vs.X)(this.messages,"expert-messages.json"))},mountResizeObserver(){const e=this.$refs.messagesWrapper;e&&(this.lastHeight=e.offsetHeight,this.resizeObserver=new ResizeObserver(([e])=>{const t=e.contentRect.height;t!==this.lastHeight&&(this.lastHeight=t,this.$emit("resizing"))}),this.resizeObserver.observe(e))},unmountResizeObserver(){this.resizeObserver?.disconnect()}}},Ss=(0,A.A)(bs,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("expert-loading-indicator");return(0,a.openBlock)(),(0,a.CE)("div",re,[(0,a.Lk)("ul",le,[((0,a.openBlock)(!0),(0,a.CE)(a.FK,null,(0,a.pI)(e.messages,e=>((0,a.openBlock)(),(0,a.CE)("li",{key:e._uuid,class:"flex flex-col gap-3"},[r.messageTypes[e._type]?((0,a.openBlock)(),(0,a.createBlock)((0,a.$y)(r.messageTypes[e._type]),(0,a.v6)({key:0,ref_for:!0},{...e}),null,16)):(0,a.Q3)("v-if",!0)]))),128)),e.isWaitingForResponse?((0,a.openBlock)(),(0,a.CE)("li",ie,[(0,a.createVNode)(l)])):(0,a.Q3)("v-if",!0)])],512)}],["__scopeId","data-v-8cb7c522"]]),Cs={name:"ExpertModeSwitcher",components:{ToggleButtonGroup:s(2808).A},props:{isFloating:{required:!1,type:Boolean,default:!1}},computed:{...(0,r.aH)(ee.i,["agentMode"]),agentModeButtons(){return[{title:"Support",value:"support-agent"},{title:"Insights",value:"insights-agent"}]},agentModeWrapper:{get(){return this.agentMode},set(e){this.setAgentMode(e)}}},methods:{...(0,r.i0)(ee.i,["setAgentMode"])}},ws=(0,A.A)(Cs,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("toggle-button-group");return(0,a.openBlock)(),(0,a.CE)("div",{class:(0,a.C4)({"mode-switcher-floating":s.isFloating})},[(0,a.createVNode)(l,{modelValue:r.agentModeWrapper,"onUpdate:modelValue":t[0]||(t[0]=e=>r.agentModeWrapper=e),buttons:r.agentModeButtons,"uses-links":!1,"visually-hide-title":!0},null,8,["modelValue","buttons"])],2)}],["__scopeId","data-v-0d66f778"]]);const ys={class:"info-banner"},xs={key:0,class:"info-text"},Bs={key:1,class:"info-text"};var Is={name:"InfoBanner",computed:{...(0,r.aH)(ee.i,["isSupportAgent","isInsightsAgent"])}},As=(0,A.A)(Is,[["render",function(e,t,s,n,o,r){return(0,a.openBlock)(),(0,a.CE)(a.FK,null,[(0,a.Q3)(" Info Banner "),(0,a.Lk)("div",ys,[e.isSupportAgent?((0,a.openBlock)(),(0,a.CE)("p",xs,[...t[0]||(t[0]=[(0,a.eW)(" AI agent has access to all of FlowFuse's ",-1),(0,a.Lk)("a",{href:"https://flowfuse.com/docs",target:"_blank",rel:"noopener noreferrer",class:"info-link"},"documentation and knowledge",-1),(0,a.eW)(", ",-1),(0,a.Lk)("a",{href:"https://flowfuse.com/blog",target:"_blank",rel:"noopener noreferrer",class:"info-link"},"blogposts",-1),(0,a.eW)(", and more. ",-1)])])):(0,a.Q3)("v-if",!0),e.isInsightsAgent?((0,a.openBlock)(),(0,a.CE)("p",Bs,[...t[1]||(t[1]=[(0,a.Lk)("span",{title:"This feature is still under development",class:"beta-badge"},"BETA",-1),(0,a.eW)(" AI agent can access ",-1),(0,a.Lk)("a",{href:"https://flowfuse.com/node-red/flowfuse/mcp/",target:"_blank",rel:"noopener noreferrer",class:"info-link"},"MCP server tools",-1),(0,a.eW)(" configured in your hosted Node-RED instances. ",-1)])])):(0,a.Q3)("v-if",!0)])],2112)}],["__scopeId","data-v-234efe2c"]]);const Es={class:"update-banner-text update-banner-header flex items-center justify-between"},Ls=["title"],Ts={class:"update-banner-badge ml-4 shrink-0"},_s={class:"update-banner-text update-banner-body",tabindex:"0"},Vs={class:"mb-2"},Ms={class:"flex justify-end"};var Ps=s(99589),Rs=s.n(Ps);const Os="0.11.0";var Ns={name:"UpdateBanner",computed:{...(0,r.aH)(F.u,["palette","editorState","version","nodeRedVersion","supportedActions","isEditorRunning"]),assistantLoaded(){return!!(this.version||this.nodeRedVersion||this.palette)},assistantPackage(){return this.palette&&0!==Object.keys(this.palette).length?this.palette?.["@flowfuse/nr-assistant"]?{installed:!0,...this.palette["@flowfuse/nr-assistant"]}:{installed:!1}:null},availableUpdate(){return Array.isArray(this.editorState?.updatesAvailable?.palette)?this.editorState?.updatesAvailable?.palette?.find(e=>"@flowfuse/nr-assistant"===e.package):null},assistantState(){if(!this.version||Rs().lt(this.version,"0.10.1"));else if(!this.isEditorRunning)return{show:!1};const e=!1!==this.assistantPackage?.enabled,t=this.assistantPackage?.installed??this.assistantLoaded,s=(t?this.assistantPackage?.version:"")||this.version||"0.0.0",a=Rs().gte(this.nodeRedVersion||"0.0.0","4.1.6")&&!!this.availableUpdate;let n=!!this.availableUpdate?.latest;this.assistantLoaded&&!a&&(n=Rs().lt(s,Os));const o={show:!t||!e||n,statusClass:"",expectedVersion:this.availableUpdate?.latest||Os,installedVersion:s,installed:t,enabled:e,chip:"",title:"",body:"",buttonText:"",buttonAction:null};return t?e?n?(o.statusClass="",o.chip=this.availableUpdate?.latest?`V${this.availableUpdate.latest} available`:"Update available",o.title="New FlowFuse Expert Version Available",o.body="There is an update available for FlowFuse Expert in the Node-RED palette. Please update to the latest version to enjoy new features and improvements.",o.buttonText="Update...",o.buttonAction=this.manageAssistantPackage):o.show=!1:(o.statusClass="warning",o.chip="Not enabled",o.title="FlowFuse Expert Not Enabled",o.body="FlowFuse Expert is installed but not enabled in the Node-RED palette. Please enable it to access its features.",o.buttonText="Enable...",o.buttonAction=this.manageAssistantPackage):(o.statusClass="warning",o.chip="Not installed",o.title="FlowFuse Expert Not Installed",o.body="FlowFuse Expert is not installed in the Node-RED palette. Please install it to access its features.",o.buttonText="Install...",o.buttonAction=this.installAssistantPackage),o}},methods:{...(0,r.i0)(F.u,["manageNodePackage","installNodePackage"]),onButtonClick(){"function"==typeof this.assistantState?.buttonAction&&this.assistantState.buttonAction()},manageAssistantPackage(){this.manageNodePackage("@flowfuse/nr-assistant")},installAssistantPackage(){this.installNodePackage("@flowfuse/nr-assistant")}}},Fs=(0,A.A)(Ns,[["render",function(e,t,s,n,o,r){const l=(0,a.g2)("ff-button");return r.assistantState.show?((0,a.openBlock)(),(0,a.CE)("div",{key:0,class:(0,a.C4)(["info-banner update-banner",r.assistantState.statusClass])},[(0,a.Lk)("div",Es,[(0,a.Lk)("span",{class:"truncate flex-1 pr-4",title:r.assistantState.title},(0,a.v_)(r.assistantState.title),9,Ls),(0,a.Lk)("span",Ts,(0,a.v_)(r.assistantState.chip),1)]),(0,a.Lk)("div",_s,[(0,a.Lk)("p",Vs,(0,a.v_)(r.assistantState.body),1),(0,a.Lk)("div",Ms,[(0,a.createVNode)(l,{kind:"secondary",size:"small",onClick:r.onButtonClick},{default:(0,a.k6)(()=>[(0,a.eW)((0,a.v_)(r.assistantState.buttonText),1)]),_:1},8,["onClick"])])])],2)):(0,a.Q3)("v-if",!0)}],["__scopeId","data-v-3ebf57bc"]]),Us=s(26460),$s={name:"ExpertPanel",components:{ExpertModeSwitcher:ws,InfoBanner:As,ExpertMessages:Ss,ExpertChatInput:oe,UpdateBanner:Fs},inject:{togglePinWithWidth:{from:"togglePinWithWidth",default:()=>()=>{}}},props:{instance:{type:Object,required:!1,default:null},device:{type:Object,required:!1,default:null}},data(){return{scrollCheckDebounce:null,autoScroll:!0}},computed:{...(0,r.aH)(ee.i,["abortController","agentMode","messages","isInsightsAgent"]),...(0,r.aH)(ae.W,{isPinned:e=>e.rightDrawer.fixed}),...(0,r.aH)(Us.n,["featuresCheck"]),isEditorContext(){return this.$route?.name?.includes("editor")||!1},isInsightsModeEnabled(){return!!this.featuresCheck?.isExpertInsightsFeatureEnabled},agentModeWrapper:{get(){return this.agentMode},set(e){this.setAgentMode(e)}},isInstanceRunning(){const e="running"===this.instance?.meta?.state,t="running"===this.device?.status;return e||t}},watch:{agentMode:{immediate:!0,async handler(){this.isInsightsAgent&&await this.getCapabilities(),this.addWelcomeMessageIfNeeded()}},"instance.meta.state":{handler(e){this.isEditorContext&&"running"!==e&&this.reset()}},"device.status":{handler(e){this.isEditorContext&&"running"!==e&&this.reset()}}},mounted(){this.isEditorContext&&setTimeout(()=>{this.addWelcomeMessageIfNeeded()},1e3)},beforeUnmount(){this.scrollCheckDebounce&&clearTimeout(this.scrollCheckDebounce),this.resetSessionTimer()},methods:{...(0,r.i0)(ee.i,["setAgentMode","setAbortController","resetSessionTimer","addWelcomeMessageIfNeeded","stopInflightChat"]),...(0,r.i0)(B.W,["getCapabilities"]),...(0,r.i0)(F.u,["reset"]),handleStopGeneration(){this.abortController&&(this.abortController.abort(),this.setAbortController(null)),this.stopInflightChat()},handleScroll(){this.scrollCheckDebounce&&clearTimeout(this.scrollCheckDebounce),this.scrollCheckDebounce=setTimeout(()=>{const e=this.$refs.messagesContainer;if(!e)return;const t=e.scrollHeight-e.scrollTop-e.clientHeight<100;t&&!this.autoScroll?this.autoScroll=!0:!t&&this.autoScroll&&(this.autoScroll=!1)},100)},scrollToBottom(){this.autoScroll&&this.$nextTick(()=>{if(this.$refs.scrollAnchor){const e=this.$refs.messagesContainer;if(!e)return;e.scrollTo({top:e.scrollHeight,behavior:"smooth"})}})}}},Ws=(0,A.A)($s,[["render",function(e,t,s,r,l,i){const c=(0,a.g2)("expert-mode-switcher"),d=(0,a.g2)("info-banner"),u=(0,a.g2)("expert-messages"),m=(0,a.g2)("update-banner"),p=(0,a.g2)("expert-chat-input");return(0,a.openBlock)(),(0,a.CE)("div",n,[i.isInsightsModeEnabled&&i.isEditorContext?((0,a.openBlock)(),(0,a.createBlock)(c,{key:0,isFloating:!0})):(0,a.Q3)("v-if",!0),(0,a.Lk)("div",{ref:"messagesContainer",class:(0,a.C4)(["messages-container",{"has-mode-switcher":i.isInsightsModeEnabled&&i.isEditorContext}]),onScroll:t[0]||(t[0]=(...e)=>i.handleScroll&&i.handleScroll(...e))},[(0,a.createVNode)(d),(0,a.createVNode)(u,{onResizing:i.scrollToBottom},null,8,["onResizing"]),(0,a.Lk)("div",o,null,512)],34),(0,a.Q3)(" Updates Available Banner "),i.isEditorContext&&i.isInstanceRunning?((0,a.openBlock)(),(0,a.createBlock)(m,{key:1})):(0,a.Q3)("v-if",!0),(0,a.createVNode)(p,{onStop:i.handleStopGeneration},null,8,["onStop"])])}],["__scopeId","data-v-fe3acece"]])}}]);