@arcgis/ai-components 5.2.0-next.15 → 5.2.0-next.17
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cdn/{FUIGPHBH.js → 3S7PBYVD.js} +1 -1
- package/dist/cdn/{P7DG5T3Z.js → 4RZPOYZ7.js} +1 -1
- package/dist/cdn/{7PANDHIL.js → 5VXRVWAX.js} +1 -1
- package/dist/cdn/{22IT5TDB.js → 6EVF6NFG.js} +1 -1
- package/dist/cdn/{BX7FSMUU.js → 6LZ6GOHF.js} +1 -1
- package/dist/cdn/{GBYLKQIL.js → C4KITTT5.js} +1 -1
- package/dist/cdn/{DHKUXLU3.js → CJIV4KJZ.js} +1 -1
- package/dist/cdn/{JIWK6QK6.js → DECSD3LN.js} +1 -1
- package/dist/cdn/{Q6LRANX6.js → FZIT3DLD.js} +1 -1
- package/dist/cdn/{4UDYY3HL.js → HOCTVCHH.js} +1 -1
- package/dist/cdn/{7CYGX4F4.js → JEIMRNYM.js} +1 -1
- package/dist/cdn/{I2Y67HBL.js → KIQUEMI4.js} +1 -1
- package/dist/cdn/{K3JCH4XW.js → LBSOW7OW.js} +1 -1
- package/dist/cdn/{XOH56EQ2.js → LODKJRS4.js} +1 -1
- package/dist/cdn/{3JGWGKT6.js → LQSZTK26.js} +1 -1
- package/dist/cdn/{S75VFYR4.js → NRMBMWI5.js} +1 -1
- package/dist/cdn/{L4XF4H6V.js → NTGC53UD.js} +1 -1
- package/dist/cdn/{O3RFFPU3.js → OLJC5BM3.js} +1 -1
- package/dist/cdn/{QYR3NSF2.js → QZVAGRWA.js} +1 -1
- package/dist/cdn/{3VOQD2MR.js → RHF452M7.js} +1 -1
- package/dist/cdn/{XU6NCSE2.js → TR3OKQPQ.js} +1 -1
- package/dist/cdn/{IR7PTESF.js → VKR2CBLM.js} +1 -1
- package/dist/cdn/{IOD3GDA7.js → VKU4WAQV.js} +1 -1
- package/dist/cdn/{TR4GFL7X.js → VV57ZUOI.js} +1 -1
- package/dist/cdn/{X4XY5HIE.js → W5DLXSAP.js} +1 -1
- package/dist/cdn/{JG2BIENI.js → WIJRNMBG.js} +1 -1
- package/dist/cdn/{DQSEBKOX.js → X4UZCTIG.js} +1 -1
- package/dist/cdn/{DXVU45KM.js → XVQJBUMY.js} +1 -1
- package/dist/cdn/agent-utils/index.js +1 -1
- package/dist/cdn/agent-utils/middlewares/humanInTheLoop.js +1 -1
- package/dist/cdn/agent-utils/middlewares/middleware.js +1 -1
- package/dist/cdn/agent-utils/middlewares/trace.js +1 -1
- package/dist/cdn/index.js +1 -1
- package/dist/docs/api.json +1 -1
- package/dist/docs/docs.json +1 -1
- package/dist/docs/web-types.json +1 -1
- package/package.json +4 -4
- /package/dist/cdn/{CHPQM77M.js → IKEF7ZHH.js} +0 -0
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import{a as x}from"./434TAA3J.js";import a from"./
|
|
2
|
+
import{a as x}from"./434TAA3J.js";import a from"./NRMBMWI5.js";import{a as F}from"./E2HENO3T.js";import"./QSA4T3BU.js";import{a as Y}from"./5W7S2RS4.js";import"./NXKKG5TK.js";import{g as A,h,k as L,l as P,n as p,t as v,u as E,v as M,x as I,z as O}from"./MAV3DW27.js";import{b as D}from"./ADYIXCSG.js";import{a as y}from"./4RZPOYZ7.js";import"./6LZ6GOHF.js";import{U as N,a as W,b as q,ta as U,u as j}from"./CJIV4KJZ.js";import{Z as H,ja as T}from"./IKEF7ZHH.js";import"./WNS5ZUF5.js";import"./ZEYIBYSF.js";import"./YIMNOUTF.js";export default $arcgis.t(([Re,{whenOnce:$e,watch:Ae,when:Le},Pe,re,ie,K,ne,ae,De,,,Me,{property:f,subclass:Oe},{a:z,d:V,e:S,g:G,h:B,i:Q}])=>{var oe=async r=>{let e=await ce(),t=await z("default"),i=ie.getDefault(),s=(await re.getCredential(`${i.url}/sharing`)).token,o={type:"generateEmbeddings",webmapEmbeddings:r,auth:{apiUrl:t,token:s}};return e.postMessage(o),await new Promise((n,a)=>{let c=d=>{d.data==="completed"&&(e.removeEventListener("message",c),n())},l=d=>{e.removeEventListener("message",c),a(d instanceof Error?d:new Error("Embeddings worker error"))};e.addEventListener("message",c),e.addEventListener("error",l,{once:!0})}),e},ce=async()=>{{let r=(await import("./23EQTPO3.js")).default;return new r}},le=r=>{r.currentIntent="none"},de=async(r,e)=>{let t=S(e);if(r.agentExecutionContext.userRequest){let s=new T(r.agentExecutionContext.userRequest.trim());r.agentExecutionContext.messages=[...r.agentExecutionContext.messages,s],le(r)}let i=t?.services.agentRegistry.list().map(s=>s.agent.id)??[];return await y({text:`Available agents: ${[...i].join(", ")}`},e),await y({text:"Analyzing user input"},e),r},ge=async(r,e)=>(await y({text:"Exiting..."},e),r),J=r=>typeof r=="object"&&r!==null&&!Array.isArray(r),he=(r,e)=>{if(!J(r)){r!==void 0&&console.warn(`Agent "${e}" returned invalid sharedStatePatch. Ignoring it.`);return}let t={};for(let[i,s]of Object.entries(r)){if(!J(s)||!("value"in s)){console.warn(`Agent "${e}" returned invalid sharedStatePatch entry for key "${i}". Ignoring that entry.`);continue}t[i]={value:s.value}}return t},ue=r=>{let{previousSharedState:e,patch:t,agentId:i}=r;if(!t)return e;let s=Date.now(),o={...e};for(let[n,a]of Object.entries(t))a?.value!==void 0&&(o[n]={value:a.value,meta:{updatedByAgentId:i,updatedAt:s}});return o},X=r=>typeof r!="string"?void 0:r.trim()||void 0,pe=r=>{switch(r){case"failed":return"Agent failed without a summary.";case"unknown":return"Agent returned with unknown status.";case"success":return"Agent completed without a summary.";default:return"Agent completed without a summary."}},me=(r,e)=>{let t=X(e?.outputMessage),i=X(e?.summary),s=e?.status,o=s==="success"||s==="failed"?s:"unknown";o==="unknown"&&console.warn(`Agent "${r}" returned missing/invalid status. Defaulting to "unknown".`);let n=he(e?.sharedStatePatch,r);return{outputMessage:t,summary:i??t??pe(o),status:o,sharedStatePatch:n}},Z=4e3,ye=async(r,e)=>{let t=S(e);if(e?.signal?.aborted)return await y({text:"Run cancelled; skipping agent execution"},e),{...r,currentIntent:"none",requiresFollowUp:!1};let{agentRegistry:i}=t?.services??{},s=i?.get(r.currentIntent);if(!s)return console.warn(`No agent found for intent: ${r.currentIntent}`),r;await y({text:`Executing registered agent: ${s.agent.name}`},e);let o={...e??{},configurable:{...t??{},agentId:s.agent.id,context:s.getContext?await s.getContext():void 0}},n;try{let l=await s.agent.createGraph().compile().invoke({agentExecutionContext:{...r.agentExecutionContext,messages:[...r.agentExecutionContext.messages],priorSteps:structuredClone(r.agentExecutionContext.priorSteps??[]),sharedState:structuredClone(r.agentExecutionContext.sharedState??{})}},o);n=me(s.agent.name,l),await y({text:`Finished executing registered agent: ${s.agent.name}`},e)}catch(l){if(j(l)||e?.signal?.aborted||l instanceof Error&&l.name==="AbortError")throw l;let d=l instanceof Error?l.message:String(l);console.error(`Agent "${s.agent.name}" failed:`,l),await y({text:`Registered agent failed: ${s.agent.name}. ${d}`},e),n={status:"failed",outputMessage:`Agent execution failed: ${d}`,summary:`Agent execution failed: ${d}`}}let a=n.outputMessage,c=[...r.agentExecutionContext.messages];if(a){let l=a.length>Z?`${a.slice(0,Z-14)}
|
|
3
3
|
[truncated]`:a;c.push(new H(l))}return{...r,stepCount:r.stepCount+1,lastExecutedAgent:s.agent.id,requiresFollowUp:n.status==="failed"?!0:r.requiresFollowUp,finalOutputMessage:a??"",agentExecutionContext:{...r.agentExecutionContext,messages:c,priorSteps:[...r.agentExecutionContext.priorSteps??[],{agentId:s.agent.id,assignedTask:r.agentExecutionContext.assignedTask,summary:n?.summary||"No summary provided.",status:n?.status||"unknown"}],sharedState:ue({previousSharedState:r.agentExecutionContext.sharedState,patch:n.sharedStatePatch,agentId:s.agent.id})}}},we=3,be=()=>new U(V).addNode("ingestInput",de).addNode("intentLLM",B).addNode("executeRegisteredAgent",ye).addNode("exit",ge).addEdge(W,"ingestInput").addEdge("ingestInput","intentLLM").addConditionalEdges("intentLLM",r=>r.currentIntent==="none"||r.currentIntent===r.lastExecutedAgent?"exit":"executeRegisteredAgent").addConditionalEdges("executeRegisteredAgent",r=>r.stepCount>=we||!r.requiresFollowUp?"exit":"intentLLM").addEdge("exit",q),C=class{constructor(){this.agentRegistry=new Map}register(e){let{agent:t}=e;if(this.agentRegistry.has(t.id))throw new Error(`Duplicate agent id: ${t.id}`);this.agentRegistry.set(t.id,e)}get(e){return this.agentRegistry.get(e)}list(){return[...this.agentRegistry.values()]}},R=class{constructor(e,t){this.graph=e,this.config={...t}}async waitForUser(){return await new Promise((e,t)=>{this.resolveWait=e,this.rejectWait=t})}handle(e,t){try{let i={agentId:e.agentId,id:e.id,payload:t},s=this.graph.streamEvents(null,{...this.config,configurable:{...this.config.configurable,hitlResponse:i},subgraphs:!0,version:"v2"});this.resolveWait?.(s)}catch(i){this.rejectWait?.(i)}finally{this.resolveWait=void 0,this.rejectWait=void 0}}cancel(){this.rejectWait&&(this.rejectWait(new Error("Request cancelled by user.")),this.resolveWait=void 0,this.rejectWait=void 0)}},fe=async r=>{try{return await(await G()).embedDocuments(r)}catch(e){throw console.error("Failed to generate embeddings:",e),e}},ee=async(r,e)=>{let t=e.get(r);if(t)return t;let i=await fe([r]);return e.set(r,i[0]),i[0]};async function ve(r,e,t,i){let s=`req-${Date.now()}`,o={type:"layerSearch",precomputedEmbedding:i?await ee(r,i):void 0,requestId:s,minScore:t};return await new Promise(n=>{let a=c=>{c.data.requestId===s&&n(c.data.results)};e.addEventListener("message",a,{once:!0}),e.postMessage(o)})}function Ee(r){let{worker:e}=r;return{async searchLayers({text:t,minScore:i,embeddingCache:s}){return await ve(t,e,i,s)}}}var _e=async({combinedQuery:r,layerIds:e,embeddingsWorker:t,minScore:i,topResults:s,embeddingCache:o})=>{let n=`req-${Date.now()}`,a=o?await ee(r,o):void 0,c={type:"fieldSearch",layerIdForFieldsSearch:e,precomputedEmbedding:a,requestId:n,minScore:i,topResults:s};return await new Promise(l=>{let d=u=>{if(u.data.requestId!==n)return;let g=u.data.results.map(({layerId:b,results:k})=>({layerId:b,results:k}));l(g)};t.addEventListener("message",d,{once:!0}),t.postMessage(c)})};function ke(r){let{worker:e}=r;return{async searchFields({text:t,layerIds:i,minScore:s,topResults:o,embeddingCache:n}){return await _e({combinedQuery:t,layerIds:i,embeddingsWorker:e,minScore:s,topResults:o,embeddingCache:n})}}}var Ie=r=>{let e=Q.safeParse(r);if(!e.success)throw new Error("Embeddings response validation failed. Regenerate embeddings.");return e.data},Se=(r,e)=>{let t=new Map,i=new Map;if(e.allLayers.forEach(s=>{s instanceof ne&&i.set(s.id,s)}),r.length!==i.size)throw new Error("Layer count mismatch during registry restoration. Regenerate embeddings.");for(let s of r){let o=i.get(s.id);if(!o)throw new Error(`Layer with ID ${s.id} not found in the original map during registry restoration. Regenerate embeddings.`);if(s.fields.length!==o.fields.length)throw new Error(`Field count mismatch for layer ID ${s.id} during registry restoration. Regenerate embeddings.`);let n={name:s.name,title:s.title,description:s.description},a=new Map;for(let c of s.fields){let l=o.fieldsIndex.get(c.name);if(!l)throw new Error(`Field with name ${c.name} not found in the original layer ${s.id} during registry restoration. Regenerate embeddings.`);a.set(c.name,{name:c.name,alias:o.getFieldAlias(c.name)??c.alias,description:c.description,type:l.type||"unknown",valueType:l.valueType||"unknown",domain:o.getFieldDomain(c.name)??void 0})}t.set(s.id,{layerItem:n,fieldRegistry:a})}return t},xe=async r=>{try{return(await ae(r,{responseType:"json"})).data}catch(e){throw new Error(`Failed to fetch data from ${r}: ${String(e)}`)}},Ce=async r=>{let e=r.map;if(!e?.portalItem)throw new Error("WebMap portal item is missing.");let{resources:t}=await e.portalItem.fetchResources(),i=t.find(o=>o.resource.path==="embeddings-v01.json");if(!i?.resource.url)throw new Error("Embeddings resource 'embeddings-v01.json' not found in the webmap portal item.");let s=await xe(i.resource.url);return Ie(s)},_=class r{constructor(){this.orchestratorReady=!1,this.chatHistory=[],this.priorSteps=[],this.sharedState={},this.agentRegistry=new C,this.activeRunId="",this.cancelledRunIds=new Set,this.streamEpoch=0}static async init(e){let t=new r;try{if(e.view?.map){await K.whenOnce(()=>e.view.ready);let i=await Ce(e.view),s=Se(i.layers,e.view.map);t.layersAndFieldsRegistry=s,t.embeddingsWorker=await oe(i)}return e.agents?.forEach(i=>{t.agentRegistry.register(i)}),t.orchestratorReady=!0,t}catch(i){throw console.error("Orchestrator initialization failed:",i),i}}async*ask(e){if(!this.orchestratorReady)throw new Error("Orchestrator is not ready yet.");if(!this.agentRegistry.list().length)throw new Error("Orchestrator has no registered agents.");if(++this.streamEpoch,!e.trim())return;let t=D();this.activeRunId=t,this.activeAbortController=new AbortController,this.graph||(this.graph=be().compile({checkpointer:new N}));let i=this.embeddingsWorker?Ee({worker:this.embeddingsWorker}):void 0,s=this.embeddingsWorker?ke({worker:this.embeddingsWorker}):void 0,o=new Map,n={thread_id:t,hitlResponse:null,services:{layerSearch:i,fieldSearch:s,layersAndFieldsRegistry:this.layersAndFieldsRegistry,agentRegistry:this.agentRegistry,embeddingCache:o}},a={version:"v2",streamMode:"custom",signal:this.activeAbortController.signal,configurable:n,subgraphs:!0},c=this.graph?.streamEvents({agentExecutionContext:{userRequest:e,messages:this.chatHistory,priorSteps:this.priorSteps,sharedState:this.sharedState}},a),l=++this.streamEpoch;if(yield*this.pipeStream(c,l,t),this.isRunCancelled(t)){yield{runId:t,timestamp:Date.now(),type:"cancelled",reason:"user"};return}for(;;){if(this.isRunCancelled(t)){yield{runId:t,timestamp:Date.now(),type:"cancelled",reason:"user"};return}let u=(await this.graph.getState(a,{subgraphs:!0})).tasks.find(g=>g.interrupts.length>0)?.interrupts[0]?.value;if(!u)break;this.currentInterrupt=u,this.interruptHandler=new R(this.graph,a),yield{runId:t,timestamp:Date.now(),type:"interrupt",interrupt:u};try{let g=await this.interruptHandler.waitForUser(),b=++this.streamEpoch;yield*this.pipeStream(g,b,t)}catch(g){if(this.isRunCancelled(t)){yield{runId:t,timestamp:Date.now(),type:"cancelled",reason:"user"};return}if(g){yield{runId:t,timestamp:Date.now(),type:"error",error:{message:g?.message}};return}}}if(this.isRunCancelled(t)){yield{runId:t,timestamp:Date.now(),type:"cancelled",reason:"user"};return}let d=(await this.graph.getState(a,{subgraphs:!0})).values;if(this.isRunCancelled(t)){yield{runId:t,timestamp:Date.now(),type:"cancelled",reason:"user"};return}this.chatHistory=d.agentExecutionContext.messages.length?d.agentExecutionContext.messages:this.chatHistory,this.priorSteps=d.agentExecutionContext.priorSteps?.slice(-5)??[],this.sharedState=d.agentExecutionContext.sharedState??{},yield{runId:t,timestamp:Date.now(),type:"completed",result:{content:d.finalOutputMessage}}}newConversation(){this.chatHistory=[],this.priorSteps=[],this.sharedState={}}resumeInterrupt(e){if(!this.currentInterrupt||!this.interruptHandler)throw new Error("No pending interrupt to resume.");this.interruptHandler.handle(this.currentInterrupt,e)}cancelInterrupt(){this.interruptHandler&&this.interruptHandler.cancel()}cancel(){this.activeRunId&&(this.cancelledRunIds.add(this.activeRunId),this.activeAbortController?.abort(),++this.streamEpoch,this.interruptHandler?.cancel())}async*pipeStream(e,t,i){for await(let s of e){if(this.isRunCancelled(i)||t!==this.streamEpoch)break;s.event==="on_custom_event"&&s.name==="trace_message"?yield{runId:i,timestamp:Date.now(),type:"trace",data:s.data}:s.name==="graph_ux_suggestion"&&(yield{runId:i,timestamp:Date.now(),type:"ux-suggestion",suggestion:s.data})}}isRunCancelled(e){return this.cancelledRunIds.has(e)}dispose(){this.embeddingsWorker&&(this.embeddingsWorker.terminate(),this.embeddingsWorker=void 0),this.orchestratorReady=!1}};var Fe=A`:host{display:block;width:var(--arcgis-internal-panel-width, 100%);height:var(--arcgis-internal-expand-max-height, 100%);--calcite-panel-content-bottom-space: 0}.footer-container{display:flex;flex-direction:column;flex:1 1 0;gap:var(--calcite-spacing-md)}.content-container{display:flex;flex-direction:column;flex:1 1 0;min-height:0;position:relative;overflow:auto}.suggested-prompts-container{display:flex;justify-content:center;width:100%;background:var(--calcite-panel-background-color, var(--calcite-color-background))}.suggested-prompts{display:block;padding:var(--calcite-spacing-md);max-width:100%;box-sizing:border-box}.error-notice{padding:var(--calcite-spacing-sm)}.interrupt-waiting-message{font-style:italic;color:var(--calcite-color-text-2)}`,We=Object.defineProperty,qe=Object.getOwnPropertyDescriptor,w=(r,e,t,i)=>{for(var s=i>1?void 0:i?qe(e,t):e,o=r.length-1,n;o>=0;o--)(n=r[o])&&(s=(i?n(e,t,s):n(s))||s);return i&&s&&We(e,t,s),s},je=async r=>await new Promise(e=>setTimeout(e,r)),te=r=>!r||typeof r!="object"?!1:r.name==="AbortError";async function*He(r,{chunkSize:e=5,delay:t=20}={}){let i=0;for(;i<r.length;)yield r.slice(i,i+e),i+=e,await je(t)}async function*se(r,e,t,i){for await(let s of He(r)){if(i?.aborted){yield{type:"cancelled",log:t,runId:e};return}yield{type:"block-data",blockType:"text",data:{content:s},runId:e}}}var m=class extends Me{constructor(r){super(r),this.view=null,this.loading=!1,this.processing=!1,this.processingStep=""}async load(){this._set("loading",!0);try{await this._initialize()}finally{this._set("loading",!1)}}destroy(){this.orchestrator?.dispose(),super.destroy()}async _initialize(){this.removeHandles(),await Promise.all([this.portal.load(),this.view?.when()]),this.view&&await $e(()=>!this.view.updating),this._set("orchestrator",await _.init({agents:[...this.agents],view:this.view??void 0})),this.addHandles([Ae(()=>[this.view,this.agents],()=>{this._initialize()})])}clearChatHistory(){this.orchestrator?.newConversation()}async*ask(r,e){if(!this.orchestrator)throw new Error("Orchestrator not initialized yet.");this._set("processing",!0),this._set("processingStep","");let t=[],i,s="pending";try{let o=this.orchestrator.ask(r);for await(let n of o)switch(s=n.runId,n.type){case"trace":{this._set("processingStep",n.data.text),t.push(n.data.text);break}case"completed":{this._set("processing",!1),this._set("processingStep","");let a=n.result,c=!!a.content.length,l=!!i?.length;if(!c&&!l){yield{type:"completed",error:"No response received.",log:t,runId:s};return}let d=a.content;if(yield{type:"block-start",blockType:"text",runId:s},yield*se(d,s,t,e),yield{type:"block-end",blockType:"text",runId:s},l)for(let u of i){if(e?.aborted){yield{type:"cancelled",log:t,runId:s};return}let{type:g,data:b}=u;if(yield{type:"block-start",blockType:g,runId:s},g==="text"){let k=typeof b?.content=="string"?b.content:"";yield*se(k,s,t,e)}else yield{type:"block-data",blockType:g,data:b,runId:s};yield{type:"block-end",blockType:g,runId:s}}yield{type:"completed",response:d,blocks:i,log:t,runId:s};return}case"ux-suggestion":{let a=n.suggestion;i=i?[...i,a]:[a];break}case"interrupt":{let{kind:a,message:c,metadata:l}=n.interrupt,d=Array.isArray(l)?l.filter(g=>typeof g=="string"):[],u=(()=>{switch(a){case"booleanChoice":return{type:"boolean-choice",message:c,options:d};case"singleSelection":return{type:"single-select",message:c,options:d};case"multipleSelection":return{type:"multi-select",message:c,options:d};case"textInput":return{type:"text-input",message:c};default:return{type:a,message:c,options:d}}})();this._set("processingStep","Waiting for user input..."),yield{type:"interrupt",payload:u,runId:s};break}case"cancelled":{yield{type:"cancelled",log:t,runId:s};return}case"error":{if(e?.aborted||te(n.error)){yield{type:"cancelled",log:t,runId:s};return}yield{type:"completed",error:n.error.message,log:t,runId:s};return}default:{console.warn("Unknown event type:",n);break}}}catch(o){if(e?.aborted||te(o)){yield{type:"cancelled",log:t,runId:s};return}console.warn("Error during message processing:",o),yield{type:"completed",error:"An error occurred during message processing.",log:t,runId:"error"};return}finally{this._set("processing",!1)}}cancel(){this.orchestrator?.cancel()}};w([f({readOnly:!0})],m.prototype,"orchestrator",2);w([f()],m.prototype,"agents",2);w([f()],m.prototype,"portal",2);w([f()],m.prototype,"view",2);w([f({readOnly:!0})],m.prototype,"loading",2);w([f({readOnly:!0})],m.prototype,"processing",2);w([f({readOnly:!0})],m.prototype,"processingStep",2);m=w([Oe("OrchestratorController")],m);var Te="Embeddings resource 'embeddings-v01.json' not found in the webmap portal item.",Ne="Embeddings not found for this web map.",Ue="https://developers.arcgis.com/javascript/latest/agentic-apps/ai-webmap-setup/#embeddings",$=class extends M{constructor(){super(...arguments),this._messages=F({blocking:!0}),this.#e=v(),this.#a=v(),this.#s=v(),this.#t=null,this.#o=new Map,this.#r=Pe.getDefault(),this.#i=e=>{e.stopPropagation(),this.cancelInterrupt()},this.#n=e=>{e.stopPropagation();let t=e.detail;this.submitInterrupt(t)},this.#c=e=>{e.stopPropagation(),this.keepSuggestedPrompts||(this.suggestedPrompts=[]);let t=e.detail;this._inputValue="",this.arcgisSubmit.emit(t),this.submitMessage(t)},this.#l=e=>{if(this._canceling=!0,e.stopPropagation(),this.arcgisCancel.emit(),this._interrupt){this.orchestrator?.cancelInterrupt(),this._interrupt=null;return}this._orchestratorController?.cancel(),this.#t?.abort(),this.#t=null},this.#d=e=>{e.stopPropagation();let t=e.detail;this.arcgisFeedback.emit(t)},this.#g=e=>{e.stopPropagation();let t=e.detail;this._inputValue=t.prompt,this.arcgisPromptSelect.emit(t)},this.#h=e=>{this.arcgisSlottableRequest.emit(e.detail)},this._orchestratorController=null,this._interrupt=null,this._interruptDetails=[],this._error=null,this._inputValue="",this._isAnswering=!1,this._canceling=!1,this.messages=new Re([]),this.referenceElement=null,this.suggestedPrompts=[],this.feedbackEnabled=!1,this.keepSuggestedPrompts=!1,this.logEnabled=!1,this.copyEnabled=!1,this.voiceInputEnabled=!1,this.readAloudEnabled=!1,this.assistantAvatarEnabled=!1,this.arcgisCancel=p(),this.arcgisError=p(),this.arcgisFeedback=p(),this.arcgisInterrupt=p(),this.arcgisInterruptCancel=p(),this.arcgisInterruptSubmit=p(),this.arcgisPromptSelect=p(),this.arcgisReady=p(),this.arcgisSubmit=p(),this.arcgisSlottableRequest=p({bubbles:!1,composed:!1}),this.arcgisResponse=p()}static{this.properties={_orchestratorController:16,_interrupt:16,_interruptDetails:16,_error:16,_inputValue:16,_isAnswering:16,_signedInUserId:16,_canceling:16,_isSignedIn:16,_user:16,awaitingResponse:32,awaitingResponseStep:32,interrupt:32,messages:0,orchestrator:32,entryMessage:1,heading:1,description:1,referenceElement:1,suggestedPrompts:0,feedbackEnabled:5,keepSuggestedPrompts:5,logEnabled:5,copyEnabled:5,voiceInputEnabled:5,readAloudEnabled:5,assistantAvatarEnabled:5}}static{this.styles=Fe}#e;#a;#s;#t;#o;#r;#i;#n;#c;#l;#d;#g;#h;async#u(){try{let e=Y(this.el,this.referenceElement);await e?.componentOnReady();let t=[...this.#o.values()];return t.length?(this._orchestratorController?.destroy(),this._orchestratorController=new m({agents:t,portal:this.#r,view:e?.view}),await this._orchestratorController.load(),!0):(this._error="No agents found.",!1)}catch(e){return this._error=e?.message??"Error initializing orchestrator.",P(this)(e),!1}}get _isSignedIn(){return!!this.#r?.user||!!this._signedInUserId}get _user(){return this.#r?.user?.fullName||this.#r?.user?.username}get awaitingResponse(){return this._orchestratorController?.processing??!1}get awaitingResponseStep(){return this._orchestratorController?.processingStep??""}get interrupt(){return this._interrupt}get orchestrator(){return this._orchestratorController?.orchestrator}async clearChatHistory(){this._reset(),this._orchestratorController?.clearChatHistory()}cancelInterrupt(){this.arcgisInterruptCancel.emit(),this.orchestrator?.cancelInterrupt(),this._interrupt=null}register(e){this.#o.set(e.agent.id,e)}async submitMessage(e){let t=e.trim();if(!t||(this.messages.push({id:Date.now().toString(),role:"user",content:t}),!this._orchestratorController))return;this.#t=new AbortController;let i=this._orchestratorController.ask(t,this.#t?.signal);for await(let s of i){let o=s.runId,n=this.messages.at(-1);switch(s.type){case"block-start":{this._isAnswering=!0;let a={type:s.blockType,isPending:!0};if(n?.role==="assistant"&&n.id===o){let c=[...n.blocks??[],a];this.messages.splice(-1,1,{...n,blocks:c})}else this.messages.push({role:"assistant",blocks:[a],id:o,isStreaming:!0,interrupts:this._interruptDetails}),this._interruptDetails=[];break}case"block-data":{if(n?.role!=="assistant"||n?.id!==o)break;let a=[...n.blocks??[]],c=a[a.length-1],{blockType:l,data:d}=s;if(c?.type!==l||!c.isPending)break;if(l==="text"){let u=typeof c.data?.content=="string"?c.data.content:"",g=typeof d?.content=="string"?d.content:"";a[a.length-1]={...c,data:{...c.data,content:u+g}}}else a[a.length-1]={...c,data:{...c.data,...d??{}}};this.messages.splice(-1,1,{...n,blocks:a});break}case"block-end":{if(n?.role!=="assistant"||n?.id!==o)break;let a=[...n.blocks??[]],c=a[a.length-1];if(c?.type!==s.blockType||!c.isPending)break;let l=c;a[a.length-1]={...l,data:{...l.data},isPending:!1},this.messages.splice(-1,1,{...n,blocks:a});break}case"completed":s.error?(this.messages.push({role:"assistant",log:s.log,error:s.error,id:o,interrupts:this._interruptDetails}),this._interruptDetails=[]):n?.role==="assistant"&&n.id===o&&this.messages.splice(-1,1,{...n,content:s.response,blocks:n.blocks?.map(a=>({...a,isPending:!1}))??[],isStreaming:!1,log:s.log}),this._isAnswering=!1,this.#t=null,this._canceling=!1;break;case"interrupt":this._interrupt={...s.payload,id:o},this.arcgisInterrupt.emit(this._interrupt);break;case"cancelled":n?.role==="assistant"&&n.id===o?this.messages.splice(-1,1,{...n,blocks:n.blocks?.filter(a=>a.type==="text"||!a.isPending)??[],isStreaming:!1,log:s.log,error:"(Stopped by user)"}):(this.messages.push({role:"assistant",log:s.log,error:"(Stopped by user)",id:o,interrupts:this._interruptDetails}),this._interruptDetails=[]),this._isAnswering=!1,this.#t=null,this._canceling=!1;break}}}submitInterrupt(e){this.arcgisInterruptSubmit.emit(e),this._interrupt&&(this._interruptDetails=[...this._interruptDetails,{interrupt:this._interrupt,response:e}]),this.orchestrator?.resumeInterrupt(e),this._interrupt=null}load(){this.manager.onLifecycle(this._reset.bind(this))}loaded(){this.manager.onLifecycle(()=>{this.#e.value?.addEventListener("arcgisPromptSelect",this.#g),this.#e.value?.addEventListener("arcgisSubmit",this.#c),this.#e.value?.addEventListener("arcgisCancel",this.#l),this.#e.value?.addEventListener("arcgisFeedback",this.#d);let e=Le(()=>!!this._interrupt&&!!this.#s.value,()=>{let i=this.#s.value;i.removeEventListener("arcgisSubmit",this.#n),i.removeEventListener("arcgisCancel",this.#i),i.addEventListener("arcgisSubmit",this.#n,{once:!0}),i.addEventListener("arcgisCancel",this.#i,{once:!0})}),t=this.messages.on("after-add",i=>{let s=i.item;s.role==="assistant"&&(s.error||s.content)&&this.arcgisResponse.emit(s)});return queueMicrotask(()=>{this.#u().then(i=>{i?this.arcgisReady.emit():this._error&&this.arcgisError.emit(new Error(this._error))})}),()=>{e.remove(),t.remove(),this.#e.value?.removeEventListener("arcgisPromptSelect",this.#g),this.#s.value?.removeEventListener("arcgisSubmit",this.#n),this.#s.value?.removeEventListener("arcgisCancel",this.#i),this.#e.value?.removeEventListener("arcgisSubmit",this.#c),this.#e.value?.removeEventListener("arcgisCancel",this.#l),this.#e.value?.removeEventListener("arcgisFeedback",this.#d),this._orchestratorController?.destroy(),this._orchestratorController=null}})}_reset(){this._orchestratorController?.cancel(),this.#t?.abort(),this._interrupt=null,this.messages.removeAll(),this._error=null,this._inputValue="",this._signedInUserId=void 0}_renderEntryMessage(){return this._isSignedIn?this._error?this._renderErrorNotice():this.entryMessage?this.messages.length>0?null:h`<calcite-notice open kind=brand closable icon width=full><div slot=message>${this.entryMessage}</div></calcite-notice>`:h`<slot name=entry-message></slot>`:this._renderSignInNotice()}_renderSignInNotice(){let e=this.#r;return h`<calcite-notice slot=entry-message open kind=brand icon width=full><div slot=message>You need to sign in to use the assistant chat.</div>${e?h`<calcite-link slot=link @click=${async()=>{try{let t=await De.getCredential(`${e.url}/sharing`);this._signedInUserId=t.userId,this._error=null,this.requestUpdate(),await this.#u()?this.arcgisReady.emit():this._error&&this.arcgisError.emit(new Error(this._error))}catch(t){this._error=t?.message??"Error signing in.",this.arcgisError.emit(new Error(this._error)),L("error",this,"Error signing in:",{detail:{error:t}})}}} target=_blank title="Sign in to ArcGIS Online">Sign in</calcite-link>`:h`<div slot=link>No portal information available</div>`}</calcite-notice>`}_renderErrorNotice(){return this._error?h`<calcite-notice slot=entry-message open kind=brand icon width=full>${this._error===Te?h`<div slot=message>${Ne}</div><calcite-link slot=link .href=${Ue} target=_blank title="Learn about web map embeddings">Read more</calcite-link>`:h`<div slot=message>${this._error}</div>`}</calcite-notice>`:null}render(){return h`<calcite-panel .loading=${!this._orchestratorController&&!this._error||this._orchestratorController?.loading} .heading=${this.heading??this._messages.assistantLabel} .description=${this.description} ${E(this.#e)}><slot name=header-actions-start slot=header-actions-start></slot><slot name=header-actions-end slot=header-actions-end></slot><div class="content-container"><arcgis-assistant-chat .loading=${this.awaitingResponse} .messages=${this.messages} .interrupt=${this._interrupt}><slot name=message-starter slot=message-starter></slot><slot name=messages slot=messages>${this.messages.map(e=>e.role==="assistant"?h`<arcgis-assistant-message .message=${e} .feedbackEnabled=${this.feedbackEnabled} .logEnabled=${this.logEnabled} .copyEnabled=${this.copyEnabled} .readAloudEnabled=${this.readAloudEnabled} @arcgisSlottableRequest=${this.#h} .assistantAvatarEnabled=${this.assistantAvatarEnabled}>${e.blocks?.map((t,i)=>h`<slot name=${x(e.id,i)??I} slot=${x(e.id,i)??I}><arcgis-assistant-message-block .block=${t}></arcgis-assistant-message-block></slot>`)}</arcgis-assistant-message>`:h`<arcgis-assistant-user-message .message=${e} .user=${this._user}></arcgis-assistant-user-message>`)}</slot>${this._interrupt?h`<div slot=message-loading><div class="interrupt-waiting-message">waiting for user input...</div></div>`:h`<slot name=message-loading slot=message-loading><arcgis-assistant-message-loading .loading=${this.awaitingResponse} .loadingMessage=${this.awaitingResponseStep} .assistantAvatarEnabled=${this.assistantAvatarEnabled} .interrupts=${this._interruptDetails}></arcgis-assistant-message-loading></slot>`}</arcgis-assistant-chat></div>${this._interrupt?h`<slot name=interrupt><arcgis-assistant-interrupt slot=content-bottom .type=${this._interrupt.type} .message=${this._interrupt.message} .options=${this._interrupt.options} ${E(this.#s)}></arcgis-assistant-interrupt></slot>`:this.suggestedPrompts?.length?h`<div class="suggested-prompts-container" slot=content-bottom><arcgis-assistant-suggested-prompts class="suggested-prompts" .prompts=${this.suggestedPrompts}></arcgis-assistant-suggested-prompts></div>`:null}<div class="footer-container" slot=footer>${this._renderEntryMessage()}<slot name=chat-entry><arcgis-assistant-chat-entry .awaitingResponse=${this.awaitingResponse||this._isAnswering} .inputValue=${this._inputValue} .messages=${this.messages} .voiceInputEnabled=${this.voiceInputEnabled} .disabled=${this._canceling||!this._isSignedIn||!!this._interrupt} ${E(this.#a)}><slot name=entry-actions-start slot=entry-actions-start></slot><slot name=entry-actions-end slot=entry-actions-end><calcite-button .iconStart=${this.awaitingResponse||this._isAnswering?"circle-stop":"send"} @click=${()=>{this.#a.value?.submitMessage()}} round>${this.awaitingResponse||this._isAnswering?this._messages.stopButtonLabel:this._messages.askButtonLabel}</calcite-button></slot></arcgis-assistant-chat-entry></slot><slot name=footer-content></slot></div></calcite-panel>`}};O("arcgis-assistant",$);return $},"core/Collection","core/reactiveUtils","portal/Portal","identity/IdentityManager","portal/Portal","core/reactiveUtils","layers/FeatureLayer","request","identity/IdentityManager","config","layers/FeatureLayer","core/Accessor","core/accessorSupport/decorators",a)
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import a from"./
|
|
2
|
+
import a from"./RHF452M7.js";import"./3S7PBYVD.js";import"./CJIV4KJZ.js";import"./IKEF7ZHH.js";import"./ZEYIBYSF.js";import"./YIMNOUTF.js";export default $arcgis.t(([{property:d,subclass:f},{a:u,c:i,d:c}])=>{var m=Object.defineProperty,g=Object.getOwnPropertyDescriptor,p=(e,o,r,t)=>{for(var s=t>1?void 0:t?g(o,r):o,a=e.length-1,n;a>=0;a--)(n=e[a])&&(s=(t?n(o,r,s):n(s))||s);return t&&s&&m(o,r,s),s},l=class extends c{constructor(e){super(e)}getAgents(){return this.agents}getEntryNode(e){return e[0]?i(e[0],0):void 0}isTerminalAgent(e,o){return o===e.length-1}validateAgents(e){super.validateAgents(e);let o=new Map;for(let[r,t]of e.entries()){let s=e[r-1];if(t.outputSchema)for(let a of u(t.outputSchema)){let n=o.get(a)??[];n.push(`${t.name} [${r}]`),o.set(a,n)}if(!(r===0||!t.inputSchema||s?.outputSchema))throw new Error(`Workflow agent "${t.name}" declares an input schema, so upstream agent "${s.name}" must declare an output schema.`)}for(let[r,t]of o.entries())t.length>1&&console.warn(`Workflow output field "${r}" is declared by multiple steps (${t.join(", ")}). Later steps will overwrite earlier values in shared state.`)}buildEdges(e){return e.length===1?[{from:i(e[0],0),decide:()=>{}}]:e.slice(0,-1).map((o,r)=>({from:i(o,r),decide:t=>t.status==="failed"?void 0:i(e[r+1],r+1)}))}};p([d()],l.prototype,"agents",2);l=p([f("SequentialWorkflow")],l);return l},"core/accessorSupport/decorators",a)
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import{a as p}from"./
|
|
2
|
+
import{a as p}from"./6LZ6GOHF.js";function f(r,e,o){return{name:r,handler:async(a,t)=>{let n=async l=>{let u=await e.beforeAgent?.(l),w=u?{...l,state:{...l.state,...u}}:l,i=await t(w),d=await e.afterAgent?.({...w,result:i});return d?{...i,...d}:i};return e.wrapAgent?await e.wrapAgent(a,n):await n(a)},hooks:e,outputKey:o?.outputKey}}function M(r,e,o){return{name:r,handler:async(a,t)=>e.wrapToolCall?await e.wrapToolCall(a,t):await t(a),outputKey:o?.outputKey}}function y(r){return r.map(e=>s(e.name,e.hooks??{})).filter(e=>!!e)}function s(r,e){let{afterModel:o,beforeModel:a,wrapModelCall:t,wrapToolCall:n}=e;if(!(!o&&!a&&!t&&!n))return p({afterModel:o,beforeModel:a,name:r,wrapModelCall:t,wrapToolCall:n})}export{f as a,M as b,y as c};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import"../YIMNOUTF.js";var a,o,i,c,u,s,w,f,l,m,p;async function r(n,t){if(t in n)return n[t];if("default"in n){let e=await n.default;return typeof e=="object"&&e!==null&&t in e?e[t]:e}throw new Error(`Unable to resolve ${String(t)} from module.`)}function k(n,t){let e={};for(let[y,d]of Object.entries(t))e[y]=b(n,d);return e}function W(n,t){return n.object(k(n,t))}function b(n,t){let e=g(n,t);return t.required===!0?e:e.optional()}function g(n,t){let e=A(n,t);return t.description!==void 0&&(e=e.describe(t.description)),e}function h(n,t){switch(t){case"string":return n.string();case"number":return n.number();case"boolean":return n.boolean()}}function A(n,t){switch(t.type){case"string":{if(t.enum!==void 0){if(t.enum.length===0)throw new Error("String schema field enum must include at least one value.");return n.enum(t.enum)}return n.string()}case"number":return n.number();case"boolean":return n.boolean();case"array":{if(t.itemType===void 0)throw new Error("Array schema field requires an itemType definition.");return n.array(h(n,t.itemType))}}}async function S(n){p??=import("../Q7TL5Q5N.js");let t=await p;return W(t.z,n)}async function L(n){a??=import("../
|
|
2
|
+
import"../YIMNOUTF.js";var a,o,i,c,u,s,w,f,l,m,p;async function r(n,t){if(t in n)return n[t];if("default"in n){let e=await n.default;return typeof e=="object"&&e!==null&&t in e?e[t]:e}throw new Error(`Unable to resolve ${String(t)} from module.`)}function k(n,t){let e={};for(let[y,d]of Object.entries(t))e[y]=b(n,d);return e}function W(n,t){return n.object(k(n,t))}function b(n,t){let e=g(n,t);return t.required===!0?e:e.optional()}function g(n,t){let e=A(n,t);return t.description!==void 0&&(e=e.describe(t.description)),e}function h(n,t){switch(t){case"string":return n.string();case"number":return n.number();case"boolean":return n.boolean()}}function A(n,t){switch(t.type){case"string":{if(t.enum!==void 0){if(t.enum.length===0)throw new Error("String schema field enum must include at least one value.");return n.enum(t.enum)}return n.string()}case"number":return n.number();case"boolean":return n.boolean();case"array":{if(t.itemType===void 0)throw new Error("Array schema field requires an itemType definition.");return n.array(h(n,t.itemType))}}}async function S(n){p??=import("../Q7TL5Q5N.js");let t=await p;return W(t.z,n)}async function L(n){a??=import("../VKR2CBLM.js");let t=await a,e=await r(t,"FunctionAgent");return new e(n)}async function v(n){o??=import("../JEIMRNYM.js");let t=await o,e=await r(t,"FunctionTool");return new e(n)}async function T(n){i??=import("../C4KITTT5.js");let t=await i,e=await r(t,"LLMAgent");return new e(n)}async function q(n){c??=import("../FZIT3DLD.js");let t=await c,e=await r(t,"WorkflowAgent");return new e(n)}async function F(n){u??=import("../LBSOW7OW.js");let t=await u,e=await r(t,"ConditionalWorkflow");return new e(n)}async function j(n){s??=import("../W5DLXSAP.js");let t=await s,e=await r(t,"LoopWorkflow");return new e(n)}async function E(n){w??=import("../OLJC5BM3.js");let t=await w,e=await r(t,"ParallelWorkflow");return new e(n)}async function M(n){f??=import("../DECSD3LN.js");let t=await f,e=await r(t,"RouterWorkflow");return new e(n)}async function P(n){l??=import("../X4UZCTIG.js");let t=await l,e=await r(t,"SequentialWorkflow");return new e(n)}async function R(n){m??=import("../LQSZTK26.js");let t=await m,e=await r(t,"SwitchWorkflow");return new e(n)}export{F as createConditionalWorkflow,L as createFunctionAgent,v as createFunctionTool,T as createLLMAgent,j as createLoopWorkflow,E as createParallelWorkflow,M as createRouterWorkflow,S as createSchema,P as createSequentialWorkflow,R as createSwitchWorkflow,q as createWorkflowAgent};
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import{a as g,b as p}from"../../
|
|
2
|
+
import{a as g,b as p}from"../../XVQJBUMY.js";import"../../6LZ6GOHF.js";import{q as l}from"../../CJIV4KJZ.js";import"../../IKEF7ZHH.js";import"../../ZEYIBYSF.js";import"../../YIMNOUTF.js";var m="human-in-the-loop",w="Agent execution requires approval",f="Agent execution rejected by the user.",y="human-in-the-loop-tool",h="Tool execution requires approval";function x(t={}){let{outputKey:e}=t;return g(m,{wrapAgent:async(n,r)=>{let a=b(n),o=$(a,n),i=c(n.config?.configurable);if(i?.agentId!==a)throw new l(await I({agentId:a,interruptId:o,options:t,request:n}));if(i.id!==o){if(T(a,i.id))return await r(n);throw new l(await I({agentId:a,interruptId:o,options:t,request:n}))}if(i.payload===!1)return{outputMessage:f,status:"failed",summary:f};let u=e?{...n.state,[e]:i.payload}:n.state,d={...n,state:u};return await r(d)}},{outputKey:e})}function H(t={}){let{outputKey:e}=t;return p(y,{wrapToolCall:async(n,r)=>{let a=n.tool.name,o=q(n.config?.configurable),i=C(o,n.toolCallId??a),u=c(n.config?.configurable);if(u?.agentId!==o||u.id!==i)throw new l(await M({agentId:o,interruptId:i,options:t,request:n}));if(u.payload===!1)return`Tool call "${a}" was rejected by the user.`;let d=e?{...n.input,[e]:u.payload}:n.input,s={...n,input:d};return await r(s)}})}async function I(t){let{agentId:e,interruptId:n,options:r,request:a}=t,o=await r.interrupt?.({...a,agentId:e});return{agentId:e,id:n,kind:o?.kind??"booleanChoice",message:o?.message??w,metadata:o?.metadata}}function b(t){return typeof t.config?.configurable?.agentId=="string"?t.config.configurable.agentId:t.agent.id}function $(t,e){let n=e.config?.configurable?.thread_id,r=typeof n=="string"&&n?`${n}:`:"";return`${t}:${r}${e.nodeName}`}function T(t,e){return e.startsWith(`${t}:tool:`)}function q(t){return typeof t?.agentId=="string"?t.agentId:"llm-agent"}function C(t,e){return`${t}:tool:${e}`}async function M(t){let{agentId:e,interruptId:n,options:r,request:a}=t,{input:o,tool:i,toolCallId:u}=a,d=i.name,s=await r.interrupt?.({...a,args:o,toolName:d,toolCallId:u});return{agentId:e,id:n,kind:s?.kind??"booleanChoice",message:s?.message??`${h}
|
|
3
3
|
Tool: ${d}`,metadata:s?.metadata??{args:o,toolCallId:u,toolName:d}}}function N(t){return c(t?.configurable)?.payload}function c(t){let e=t?.hitlResponse;return e&&typeof e=="object"&&"id"in e&&"agentId"in e?e:null}export{x as createHumanInTheLoopMiddleware,H as createHumanInTheLoopToolMiddleware,N as getHumanInTheLoopPayload};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import{a,b,c}from"../../
|
|
2
|
+
import{a,b,c}from"../../XVQJBUMY.js";import"../../6LZ6GOHF.js";import"../../CJIV4KJZ.js";import"../../IKEF7ZHH.js";import"../../ZEYIBYSF.js";import"../../YIMNOUTF.js";export{c as convertToLangChainMiddlewares,a as createAgentMiddleware,b as createToolMiddleware};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import{a as o}from"../../
|
|
2
|
+
import{a as o}from"../../4RZPOYZ7.js";import{a as l,b as c}from"../../XVQJBUMY.js";import"../../6LZ6GOHF.js";import"../../CJIV4KJZ.js";import{P as s,Z as i}from"../../IKEF7ZHH.js";import"../../ZEYIBYSF.js";import"../../YIMNOUTF.js";var m="agent-trace",u="tool-trace";function y(){return l(m,{wrapModelCall:async(t,e)=>{let a=await e(t),r=t.runtime,g=d(a);return await Promise.all(g.map(async n=>await o({text:`LLM requested tool call "${n.name}" with arguments: ${JSON.stringify(n.args,null,2)}`},r))),a}})}function M(){return c(u,{wrapToolCall:async(t,e)=>{let a=await e(t),r=t.config;return await o({text:`Finished executing tool: ${s.isInstance(a)?a.content.toString():typeof a=="string"?a:t.tool.name}`},r),a}})}function d(t){return!i.isInstance(t)||!Array.isArray(t.tool_calls)?[]:t.tool_calls.filter(e=>typeof e?.name=="string")}export{y as createAgentTraceMiddleware,M as createToolTraceMiddleware};
|
package/dist/cdn/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import{p as s,y as e}from"./MAV3DW27.js";import"./ADYIXCSG.js";import"./YIMNOUTF.js";var a=s(e,{"arcgis-assistant":[()=>import("./
|
|
2
|
+
import{p as s,y as e}from"./MAV3DW27.js";import"./ADYIXCSG.js";import"./YIMNOUTF.js";var a=s(e,{"arcgis-assistant":[()=>import("./WIJRNMBG.js"),"_messages:,assistantAvatarEnabled,awaitingResponse:,awaitingResponseStep:,copyEnabled,description,entryMessage,feedbackEnabled,heading,interrupt:,keepSuggestedPrompts,logEnabled,messages:,orchestrator:,readAloudEnabled,referenceElement,suggestedPrompts:,voiceInputEnabled;clearChatHistory,submitMessage;cancelInterrupt,register,submitInterrupt"],"arcgis-assistant-agent":[()=>import("./CI3QSFPS.js"),"agent:,context:;getContext"],"arcgis-assistant-data-exploration-agent":[()=>import("./5VXRVWAX.js"),"referenceElement;;getContext"],"arcgis-assistant-help-agent":[()=>import("./TR3OKQPQ.js"),"referenceElement;;getContext"],"arcgis-assistant-knowledge-agent":[()=>import("./6EVF6NFG.js"),"context:,referenceElement,serviceUrl;getContext"],"arcgis-assistant-layer-styling-agent":[()=>import("./KIQUEMI4.js"),"referenceElement;;getContext"],"arcgis-assistant-navigation-agent":[()=>import("./NTGC53UD.js"),"referenceElement;;getContext"],"arcgis-assistant-chat":[()=>import("./PB2ODJC7.js"),"interrupt:,loading,messages:"],"arcgis-assistant-chat-entry":[()=>import("./M3SWPT3M.js"),"_messages:,awaitingResponse,disabled,entryPlaceholder,inputValue,keyboardShortcutsDisabled,messages:,status,voiceInputEnabled;submitMessage"],"arcgis-assistant-interrupt":[()=>import("./XBW4MWQR.js"),"_messages:,message,options:,type"],"arcgis-assistant-interrupt-preview":[()=>import("./JN744CAW.js"),"interrupts:"],"arcgis-assistant-message":[()=>import("./CAECQD75.js"),"assistantAvatarEnabled,copyEnabled,feedbackEnabled,footerDisabled,logEnabled,message:,readAloudEnabled"],"arcgis-assistant-message-block":[()=>import("./GPYYAQVI.js"),"block:"],"arcgis-assistant-message-feedback":[()=>import("./FWU6DFIB.js"),"_messages:,feedbackEnabled,message:"],"arcgis-assistant-message-footer":[()=>import("./DEAYZ3MK.js"),"_messages:,copyEnabled,feedbackEnabled,logEnabled,message:,readAloudEnabled"],"arcgis-assistant-message-loading":[()=>import("./ZPLFFLPF.js"),"assistantAvatarEnabled,interrupts:,loading,loadingMessage"],"arcgis-assistant-message-log":[()=>import("./Z7UWJ4AI.js"),"log:,logEnabled,showLog"],"arcgis-assistant-message-read-aloud":[()=>import("./RMLXVQZ5.js"),"_messages:,message:,readAloudEnabled"],"arcgis-assistant-message-text":[()=>import("./SBHLUL3Q.js"),"content"],"arcgis-assistant-speech-input":[()=>import("./ZOSUDIJH.js"),"awaitingResponse,inputValue,language,mode;;clearDraftSession"],"arcgis-assistant-suggested-prompts":[()=>import("./WH6QQK6N.js"),"_messages:,label,prompts:"],"arcgis-assistant-user-message":[()=>import("./K475UT3E.js"),"content,message:,user"]});a({resourcesUrl:import.meta.url});var t=new CSSStyleSheet;t.replaceSync("@layer{:not([hydrated]):is(arcgis-assistant,arcgis-assistant-agent,arcgis-assistant-data-exploration-agent,arcgis-assistant-help-agent,arcgis-assistant-knowledge-agent,arcgis-assistant-layer-styling-agent,arcgis-assistant-navigation-agent,arcgis-assistant-chat,arcgis-assistant-chat-entry,arcgis-assistant-interrupt,arcgis-assistant-message,arcgis-assistant-message-block,arcgis-assistant-message-feedback,arcgis-assistant-message-footer,arcgis-assistant-message-loading,arcgis-assistant-message-log,arcgis-assistant-message-read-aloud,arcgis-assistant-message-text,arcgis-assistant-speech-input,arcgis-assistant-suggested-prompts,arcgis-assistant-user-message){visibility:hidden}}");document.adoptedStyleSheets=[...document.adoptedStyleSheets,t];window.$arcgis||Object.defineProperty(window,"$arcgis",{configurable:!1,enumerable:!0,writable:!1,value:{}}),((a,r,p,j,i=(a.importMap??={}).imports??={})=>{"agent-utils/index,agent-utils/middlewares/middleware,agent-utils/middlewares/humanInTheLoop,agent-utils/middlewares/trace".split(",").map(e=>i[p+e+j]=i[p+e]=import.meta.resolve("./"+e+j));a.t=(c,...x)=>Promise.all(x.map(x=>x.then?x:(!a?.forceESM&&a?.import||(x=>import(x+".js").then(m=>m.default??m)))("@arcgis/core/"+x))).then(c);r.p=a.t(([m])=>{r.t=m.trackAccess;r.o=m.createObservable;r.c=m.createTrackingTarget;r.r=m.runTracked},"applications/Components/reactiveUtils")})($arcgis,e,"@arcgis/ai-components/",".js")
|