@arcgis/ai-components 5.2.0-next.7 → 5.2.0-next.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cdn/{BFZJNJL6.js → 53ZCUPKK.js} +1 -1
- package/dist/cdn/{GCQLVNNC.js → 5XRDJL7R.js} +1 -1
- package/dist/cdn/{AEJHYRGT.js → EECZLT6C.js} +1 -1
- package/dist/cdn/{JV4SI65E.js → ETRWZ3MS.js} +1 -1
- package/dist/cdn/{VOQX4AVB.js → GGSZM7KV.js} +1 -1
- package/dist/cdn/{3NI46YCE.js → I6HNBTWY.js} +1 -1
- package/dist/cdn/{R6HV42YW.js → IG6YKZH3.js} +1 -1
- package/dist/cdn/{47FWPQ2A.js → P26NON3Z.js} +1 -1
- package/dist/cdn/{V7OJRG26.js → S3VPZFWQ.js} +1 -1
- package/dist/cdn/index.js +1 -1
- package/dist/chunks/generateLayerDescriptions.js +0 -1
- package/dist/docs/api.json +1 -1
- package/dist/docs/docs.json +1 -1
- package/dist/docs/web-types.json +1 -1
- package/dist/utils/index.d.ts +90 -43
- package/dist/utils/index.js +78 -64
- package/package.json +4 -4
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import b from"./
|
|
2
|
+
import b from"./EECZLT6C.js";import a from"./ETRWZ3MS.js";import{Fb as f,a as h,b as l}from"./462JBSEV.js";import{a as y,c as E}from"./HB5A5R2E.js";import"./AMP6IALT.js";import"./OAVEHGB6.js";import{v as u,y as d}from"./OH64RMOR.js";import"./YIMNOUTF.js";export default $arcgis.t(([,,,,,,,,,,,,,,,{f:p,n:x},{I:c,J:H,a:S,m:_,n:w,o:m,p:v}])=>{var C=[H],b=e=>{if(!e||e.size===0)return"No layers available in this map.";let t=Array.from(e.values()).map(({layerItem:o,fieldRegistry:a},s)=>{let r=Array.from(a.values()).map(n=>n.name).slice(0,10).join(", "),i=a.size>10?` (and ${a.size-10} more)`:"";return`${s+1}. "${o.title}". Description: ${o.description}
|
|
3
3
|
Fields: ${r}${i}`}).join(`
|
|
4
4
|
|
|
5
5
|
`);return`This map contains ${e.size} layer(s):
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import c from"./
|
|
2
|
+
import c from"./I6HNBTWY.js";import b from"./EECZLT6C.js";import a from"./ETRWZ3MS.js";import{Fb as I,a as w,b as h,q as E}from"./462JBSEV.js";import{a as v,c as F}from"./HB5A5R2E.js";import"./AMP6IALT.js";import"./OAVEHGB6.js";import{v as x,y as S}from"./OH64RMOR.js";import"./YIMNOUTF.js";export default $arcgis.t(([,,,,,,,,,,,,,,,{f:n,n:L},{A:z,B:u,a:$,m:C,o:y,p:N,q:A,r:R,s:T,t:b,u:_,v:V,w:q,x:j,y:k,z:M},D])=>{var B=.7,P=10,J=async(t,r)=>{try{await n({text:"Similarity search to find fields"},r);let e=y(r,"fieldSearch"),i=y(r,"layersAndFieldsRegistry"),o=y(r,"embeddingCache"),a=await e.searchFields({text:t.agentExecutionContext.assignedTask,layerIds:t.vectorSearchLayerIds,minScore:B,topResults:P,embeddingCache:o}),m=a.map(({layerId:c,results:d})=>{let g=d.map(s=>` - ${s.name} (${s.score.toFixed(2)})`).join(`
|
|
3
3
|
`);return`${i.get(c)?.layerItem.name??c}:
|
|
4
4
|
${g}`}).join(`
|
|
5
5
|
`),l;return a.length>0?l=`Vector search completed. Matching layers and fields with scores:
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import a from"./
|
|
2
|
+
import a from"./ETRWZ3MS.js";import{Bb as j,L as q,M as ee,R as z,Za as I,_a as h,g as ge,j as V,k as Q,kb as g,qb as be,u as we}from"./462JBSEV.js";export default $arcgis.t(([$e,M,Ce,,Ne,oe,tt,{addressToLocations:rt},ot,at,Re,{createRenderer:nt},{getSchemesByTag:it,getSchemes:st},{getBackgroundColorTheme:ke},{createAgeRenderer:lt,createContinuousRenderer:ct},{getSchemesByTag:pe},{createContinuousRenderer:ut},{createRenderer:dt},{getSchemesByTag:pt},{createRenderer:mt},{getSchemesByTag:ht},{createRenderer:ft},{getSchemesByTag:yt},{createRenderer:gt},{getSchemesByTag:wt},{createAgeRenderer:bt,createContinuousRenderer:vt},{createRenderer:Tt},{getSchemesByTag:St},xt,_e,qe,{formatDateOnly:Et,convertDateFormatToIntlOptions:U,formatTimeOnly:It,formatDate:Fe},$t,Nt,kt,Ft,Mt,ze,,{fetchKnowledgeGraph:Me,executeQueryStreaming:At,executeSearchStreaming:Ct},Rt,{a:i,c:L,d:ve,f:T,g:S,m:Te}])=>{var Ie=e=>Array.isArray(e)&&e.every(q),Ze=e=>typeof e=="object"&&e!=null&&"messages"in e&&Ie(e.messages),Ye=e=>typeof e=="object"&&e!=null&&"lg_tool_call"in e,B=class extends be{tools;handleToolErrors=!0;trace=!1;constructor(e,t){let{name:r,tags:o,handleToolErrors:a}=t??{};super({name:r,tags:o,func:(n,s)=>this.run(n,s)}),this.tools=e,this.handleToolErrors=a??this.handleToolErrors}async runTool(e,t){let r=this.tools.find(o=>o.name===e.name);try{if(r===void 0)throw new Error(`Tool "${e.name}" not found.`);let o=await r.invoke({...e,type:"tool_call"},t);return q(o)&&o.getType()==="tool"||Q(o)?o:new ee({status:"success",name:r.name,content:typeof o=="string"?o:JSON.stringify(o),tool_call_id:e.id})}catch(o){if(!this.handleToolErrors||we(o))throw o;return new ee({status:"error",content:`Error: ${o.message}
|
|
3
3
|
Please fix your mistakes.`,name:e.name,tool_call_id:e.id??""})}}async run(e,t){let r;if(Ye(e))r=[await this.runTool(e.lg_tool_call,t)];else{let n;if(Ie(e))n=e;else if(Ze(e))n=e.messages;else throw new Error("ToolNode only accepts BaseMessage[] or { messages: BaseMessage[] } as input.");let s=new Set(n.filter(u=>u.getType()==="tool").map(u=>u.tool_call_id)),l;for(let u=n.length-1;u>=0;u-=1){let c=n[u];if(z(c)){l=c;break}}if(l==null||!z(l))throw new Error("ToolNode only accepts AIMessages as input.");r=await Promise.all(l.tool_calls?.filter(u=>u.id==null||!s.has(u.id)).map(u=>this.runTool(u,t))??[])}if(!r.some(Q))return Array.isArray(e)?r:{messages:r};let o=[],a=null;for(let n of r)Q(n)?n.graph===V.PARENT&&Array.isArray(n.goto)&&n.goto.every(s=>ge(s))?a?a.goto.push(...n.goto):a=new V({graph:V.PARENT,goto:n.goto}):o.push(n):o.push(Array.isArray(e)?[n]:{messages:[n]});return a&&o.push(a),o}};var Fn=g.Root({llmInputMessages:g({reducer:(e,t)=>j([],t),default:()=>[]})});var O=(e,t)=>t??e,ji=g.Root({...ve(),intent:g({reducer:O}),vectorSearchLayerResults:g({reducer:O,default:()=>[]}),vectorSearchFieldResults:g({reducer:O}),navigationInternalState:g({reducer:O,default:()=>({toolCallMessage:void 0})})});async function _t(e,t){let r=M.getDefault().helperServices,o=r.geocode.find(d=>d.name==="ArcGIS World Geocoding Service")??r.geocode[0];if(!o)throw new Error("No geocoding service found in helperServices.");let a=o.url,n=`${oe.assetsPath?.endsWith("/")?oe.assetsPath:`${oe.assetsPath}/`}esri/images/search/search-symbol-32.png`,s=(await rt(a,{address:{SingleLine:e},outFields:["Match_addr"]}))?.[0];if(!s?.extent||!s.location)throw new Error(`Could not find location for: ${e}`);let l=new ot({url:n,width:24,height:24}),u=new tt({geometry:s.location,symbol:l});t.graphics.removeAll(),t.graphics.add(u),await t.goTo(s.extent);let c={address:s.address??"",location:s.location?s.location.toJSON():null,extent:s.extent?s.extent.toJSON():null};return{text:`Successfully zoomed to ${e}.`,sharedStatePatch:{lastResolvedLocation:{value:c}}}}var qt=["mapView"];function $(e){let t=e?.configurable?.context;if(!t||typeof t!="object")throw new Error("NavigationAgent context missing");let r=qt.filter(o=>!(o in t));if(r.length)throw new Error(`NavigationAgent context missing: ${r.join(", ")}`);return t}async function zt({address:e},t){let{mapView:r}=$(t);return await _t(e,r)}var jt=i.object({address:i.string().describe("The full address or place name to locate.")}),Li=h(zt,{name:"goToAddress",description:"Geocodes an address using Esri's World Geocoding Service and zooms the map to that location.",schema:jt});async function Lt(e,t){let r=t.map.bookmarks;if(!r||r.length===0)throw new Error("No bookmarks found in the map.");let o=r.find(n=>n.name===e);if(!o)throw new Error(`Bookmark with name "${e}" not found.`);let a=o.viewpoint;if(!a)throw new Error(`Bookmark with name "${e}" does not have a valid viewpoint.`);return await t.goTo(a),{text:`Navigated to bookmark: ${e}`}}async function Ot({bookmarkName:e},t){let{mapView:r}=$(t);return await Promise.resolve(Lt(e,r))}var Dt=I.object({bookmarkName:I.string().describe("The name of the bookmark to navigate to.")}),Oi=h(Ot,{name:"goToBookmark",description:"Go to the extent of the bookmark with the given name.",schema:Dt});async function Pt(e,t,r){let o=r.map?.allLayers.find(s=>s.id===e);if(!o)return{text:`Error: Layer with id ${e} not found`};let a=t?.trim()?t:"1=1",n=o.createQuery();n.where=a;try{let{extent:s,count:l}=await o.queryExtent(n);if(l===0)return{text:`No features found in ${o.title} matching: ${a}`,where:a};if(s)await r.goTo(s);else return{text:`Error: Unable to determine extent for ${o.title}`,where:a};let u={layerId:e,layerTitle:o.title??e,where:a,count:l};return{text:`Successfully zoomed to ${l} feature(s) in ${o.title} matching: ${a}`,where:a,sharedStatePatch:{lastNavigatedFeatures:{value:u}}}}catch(s){return console.error("Error in goToFeatures:",s),{text:`Error: ${s instanceof Error?s.message:"Unknown error"}`,where:a}}}async function Gt({layerId:e,where:t},r){let{mapView:o}=$(r);return await Pt(e,t,o)}var Vt=I.object({layerId:I.string().describe("The layerId of the layer to zoom to."),where:I.string().describe("The sql-92 where clause used to query features to zoom to")}),Di=h(Gt,{name:"goToFeatures",description:"Go to the features that match the given filter related to the given layerId.",schema:Vt});async function Qt(e){let t=new at({xmin:-180,ymin:-90,xmax:180,ymax:90,spatialReference:{wkid:4326}}).expand(.7);return await e.goTo(t),{text:"Successfully zoomed to world extent"}}async function Bt(e,t){let{mapView:r}=$(t);return await Qt(r)}var Ut=I.object({}),Pi=h(Bt,{name:"goToFullExtent",description:"Zooms the map to the full world extent using Esri's Geocoding Service.",schema:Ut});async function Kt(e){let t=e.map.initialViewProperties?.viewpoint?.targetGeometry;if(t)await e.goTo(t);else throw new Error("Initial extent is undefined");return{text:"Successfully zoomed to home extent"}}async function Wt(e,t){let{mapView:r}=$(t);return await Kt(r)}var Ht=i.object({}),Gi=h(Wt,{name:"goToHomeExtent",description:"Go to the initial web map view extent",schema:Ht});async function Jt(e,t){await t.when();let r=t.map?.allLayers.find(a=>a.id===e);if(!r)return console.warn(`[goToLayer] No matching FeatureLayer found for: ${e}`),{text:`Could not find layer for: ${e}`};let o;return(r.type==="link-chart"||r.type==="knowledge-graph-sublayer")&&t.map?.activeLinkChartLayer?o=t.map.diagramNodesExtent:o=r.fullExtent,o?(await t.goTo(o),r.visible=!0,{text:`Successfully zoomed to: ${r.title??""}`}):{text:"Layer has no defined extent. Cannot zoom to layer."}}async function Zt({layerId:e},t){let{mapView:r}=$(t);return await Jt(e,r)}var Yt=I.object({layerId:I.string().describe("The id of the layer to navigate to")}),Vi=h(Zt,{name:"goToLayer",description:"Zooms the map view to the full extent of the top matching layer.",schema:Yt});async function Xt(e,t){return await t.goTo({scale:e}),{text:`Successfully zoomed to: ${e}`}}async function er({scale:e},t){let{mapView:r}=$(t);return await Xt(e,r)}var tr=i.object({scale:i.number().describe("The map scale of the view to go to.")}),Qi=h(er,{name:"goToScale",description:"Go to the specified view scale.",schema:tr});async function rr(e,t,r){let o={target:new Re({longitude:e.longitude,latitude:e.latitude,spatialReference:{wkid:4326}})};return r?.zoom!==void 0&&(o.zoom=r.zoom),r?.scale!==void 0&&(o.scale=r.scale),await t.goTo(o),{text:`Successfully navigated to: ${[`(${e.latitude}\xB0, ${e.longitude}\xB0)`,r?.zoom!==void 0?`zoom ${r.zoom}`:"",r?.scale!==void 0?`scale 1:${r.scale}`:""].filter(Boolean).join(", ")}`}}async function or({center:e,zoom:t,scale:r},o){let{mapView:a}=$(o);return await rr(e,a,{zoom:t,scale:r})}var ar=i.object({center:i.object({longitude:i.number().describe("The longitude (x-coordinate) of the point to navigate to."),latitude:i.number().describe("The latitude (y-coordinate) of the point to navigate to.")}),zoom:i.number().optional().describe("The zoom level. Higher values = more zoomed in."),scale:i.number().optional().describe("The map scale. Alternative to zoom. Smaller numbers = more zoomed in.")}),Bi=h(or,{name:"goToViewpoint",description:"Go to the specified viewpoint. This can contain a combination of scale, center, zoom, etc.",schema:ar});async function nr(e,t){return await t.goTo({zoom:e}),{text:`Successfully zoomed to: ${e}`}}async function ir({zoom:e},t){let{mapView:r}=$(t);return await nr(e,r)}var sr=i.object({zoom:i.number().min(1).max(20).describe("The zoom level of the view to go to.")}),Ui=h(ir,{name:"goToZoom",description:'Go to the specified zoom level. If input is generic (e.g. "zoom in", then only zoom to the next appropriate level - increase level for zooming in and decrease for zooming out.).',schema:sr}),Ae=Object.assign({"../agents/arcgisKnowledge/prompts/arcgis_knowledge_current_lc_context.md":()=>import("./KMQ3SP4I.js").then(e=>e.default),"../agents/arcgisKnowledge/prompts/arcgis_knowledge_current_map_context.md":()=>import("./5QAHYX7Y.js").then(e=>e.default),"../agents/arcgisKnowledge/prompts/arcgis_knowledge_lucene_generation_prompt.md":()=>import("./5ZZGKP7N.js").then(e=>e.default),"../agents/arcgisKnowledge/prompts/arcgis_knowledge_summarize_result_prompt.md":()=>import("./AXDZBBNL.js").then(e=>e.default),"../agents/arcgisKnowledge/prompts/arcgis_knowledge_tool_prompt.md":()=>import("./ZS2TZ6BF.js").then(e=>e.default),"../agents/dataExploration/prompts/data_explore_filter_prompt.md":()=>import("./LQ6R5YRN.js").then(e=>e.default),"../agents/dataExploration/prompts/data_explore_query_prompt.md":()=>import("./X2ZDYHCG.js").then(e=>e.default),"../agents/dataExploration/prompts/summarize_query_response_prompt.md":()=>import("./ZLXN7NMF.js").then(e=>e.default),"../agents/help/prompts/help_prompt.md":()=>import("./F2AHA4GB.js").then(e=>e.default),"../agents/layerStyling/prompts/layer_styling_prompt.md":()=>import("./FX7UOGHP.js").then(e=>e.default),"../agents/navigation/prompts/navigation_intent_prompt.md":()=>import("./NE7E52YR.js").then(e=>e.default),"../agents/navigation/prompts/navigation_tool_prompt.md":()=>import("./6YMR4QSD.js").then(e=>e.default)});async function ne(e){let t=Object.entries(Ae).find(([r])=>r.endsWith(`/${e}.md`));if(!t)throw new Error(`Prompt not found: ${e}
|
|
4
4
|
Available prompts:
|
|
5
5
|
${Object.keys(Ae).join(`
|
|
@@ -97,7 +97,7 @@ ${await sf(J,_,f,N,x,o)}`,id:Fs(),additional_kwargs:{lc_source:"summarization"}}
|
|
|
97
97
|
|
|
98
98
|
`);return o[o.length-1]?.trim()===r?t:`${t}
|
|
99
99
|
|
|
100
|
-
${r}`},Zc=()=>({userRequest:"",assignedTask:"",messages:[],priorSteps:[],sharedState:{}}),If=()=>({agentExecutionContext:he({reducer:qc,default:Zc}),outputMessage:he({reducer:Jc,default:()=>""}),summary:he({reducer:Nn,default:()=>""}),status:he({reducer:Nn})}),Aj=()=>({...If(),sharedStatePatch:he({reducer:Nn})}),wj=he.Root({agentExecutionContext:he({default:Zc,reducer:qc}),currentIntent:he({default:()=>"none",reducer:Nn}),lastExecutedAgent:he({default:()=>"",reducer:Nn}),requiresFollowUp:he({default:()=>!0,reducer:Nn}),stepCount:he({default:()=>0,reducer:(t,e)=>e??t+1}),finalOutputMessage:he({default:()=>"",reducer:Jc})}),Rn=async(t,e)=>{await Ys("trace_message",t,e)},bj=async(t,e)=>{await Ys("graph_ux_suggestion",t,e)},xf=t=>{if(!t||typeof t!="object"||!("services"in t))return!1;let e=t.services;return!!e&&typeof e=="object"&&"agentRegistry"in e},Tf=t=>{let e=t?.configurable;return xf(e)?e:void 0},vf=(t,e,r)=>{let n=t[e];return n?typeof n=="function"?n():Promise.resolve(n):new Promise((o,s)=>{(typeof queueMicrotask=="function"?queueMicrotask:setTimeout)(s.bind(null,new Error("Unknown variable dynamic import: "+e+(e.split("/").length!==r?". Note that variables only represent file names one level deep.":""))))})},Of=async t=>(await vf(Object.assign({"./field_descriptions_prompt.md":()=>import("./ZTBA5PM7.js"),"./intent_prompt.md":()=>import("./FL4W4VYN.js"),"./layer_descriptions_prompt.md":()=>import("./7RCQFLPP.js")}),`./${t}.md`,2)).default,Cf=async t=>{let{agent:e,messages:r,config:n}=t;return{structuredResponse:(await e.invoke({messages:r},n)).structuredResponse}},Vc=(t,e)=>async(r,n)=>{let o=new Headers(n?.headers);o.delete("Authorization"),o.delete("api-key"),t&&t.length>0&&(o.set("X-Esri-Authorization",`Bearer ${t}`),o.set("X-Esri-Request-Source","MapsSDK"));let s=e&&n?.signal?AbortSignal.any([e,n.signal]):n?.signal??e;return await fetch(r,{...n,headers:o,signal:s})},yo=async(t={})=>{let{modelTier:e="default",temperature:r=0,abortSignal:n}=t,o=aa.getDefault(),s=await Kc.getCredential(`${o.url}/sharing`),i=Wc[e],a=await wf(e);return new ws({modelName:i,apiKey:"dummy-key",...e!=="default"&&{temperature:r},configuration:{baseURL:a,fetch:Vc(s.token,n)}})},Ij=async(t="default",e)=>{let r=aa.getDefault(),n=await Kc.getCredential(`${r.url}/sharing`),o=la[t],s=await bf(t);return new bs({modelName:o,apiKey:"dummy-key",configuration:{baseURL:s,fetch:Vc(n.token,e)},batchSize:2048,maxConcurrency:10})},Pf=b.object({id:b.string().min(1),name:b.string().min(1),description:b.string().min(1)});b.array(Pf);var Bc=t=>JSON.stringify(t,null,2),kf=t=>{let e=t.map(n=>n.id),r=b.enum(e);return b.object({intent:r.nullable(),assignedTask:b.string().nullable(),requiresFollowUp:b.boolean()})},xj=async(t,e)=>{let r=Tf(e);if(r.abortSignal?.aborted)return await Rn({text:"Run cancelled; skipping intent routing"},e),{...t,currentIntent:"none",finalOutputMessage:"Operation cancelled.",requiresFollowUp:!1};try{await Rn({text:"Asking LLM to route to an agent"},e);let n=r.services.agentRegistry?.list()??[],o=n.map(({agent:x})=>({id:x.id,name:x.name,description:x.description}));if(!o.length)return await Rn({text:"No agents registered; skipping intent detection"},e),{...t,currentIntent:"none",finalOutputMessage:"No agents registered; skipping intent detection."};let s=await Of("intent_prompt"),i=Bc(o),a=kf(o),u={registeredAgents:i,priorSteps:Bc(t.agentExecutionContext.priorSteps),userRequest:t.agentExecutionContext.userRequest},l=await Zs.fromTemplate(s).format(u),c=ra({model:await yo({modelTier:"fast",abortSignal:r.abortSignal}),tools:[],systemPrompt:l,
|
|
100
|
+
${r}`},Zc=()=>({userRequest:"",assignedTask:"",messages:[],priorSteps:[],sharedState:{}}),If=()=>({agentExecutionContext:he({reducer:qc,default:Zc}),outputMessage:he({reducer:Jc,default:()=>""}),summary:he({reducer:Nn,default:()=>""}),status:he({reducer:Nn})}),Aj=()=>({...If(),sharedStatePatch:he({reducer:Nn})}),wj=he.Root({agentExecutionContext:he({default:Zc,reducer:qc}),currentIntent:he({default:()=>"none",reducer:Nn}),lastExecutedAgent:he({default:()=>"",reducer:Nn}),requiresFollowUp:he({default:()=>!0,reducer:Nn}),stepCount:he({default:()=>0,reducer:(t,e)=>e??t+1}),finalOutputMessage:he({default:()=>"",reducer:Jc})}),Rn=async(t,e)=>{await Ys("trace_message",t,e)},bj=async(t,e)=>{await Ys("graph_ux_suggestion",t,e)},xf=t=>{if(!t||typeof t!="object"||!("services"in t))return!1;let e=t.services;return!!e&&typeof e=="object"&&"agentRegistry"in e},Tf=t=>{let e=t?.configurable;return xf(e)?e:void 0},vf=(t,e,r)=>{let n=t[e];return n?typeof n=="function"?n():Promise.resolve(n):new Promise((o,s)=>{(typeof queueMicrotask=="function"?queueMicrotask:setTimeout)(s.bind(null,new Error("Unknown variable dynamic import: "+e+(e.split("/").length!==r?". Note that variables only represent file names one level deep.":""))))})},Of=async t=>(await vf(Object.assign({"./field_descriptions_prompt.md":()=>import("./ZTBA5PM7.js"),"./intent_prompt.md":()=>import("./FL4W4VYN.js"),"./layer_descriptions_prompt.md":()=>import("./7RCQFLPP.js")}),`./${t}.md`,2)).default,Cf=async t=>{let{agent:e,messages:r,config:n}=t;return{structuredResponse:(await e.invoke({messages:r},n)).structuredResponse}},Vc=(t,e)=>async(r,n)=>{let o=new Headers(n?.headers);o.delete("Authorization"),o.delete("api-key"),t&&t.length>0&&(o.set("X-Esri-Authorization",`Bearer ${t}`),o.set("X-Esri-Request-Source","MapsSDK"));let s=e&&n?.signal?AbortSignal.any([e,n.signal]):n?.signal??e;return await fetch(r,{...n,headers:o,signal:s})},yo=async(t={})=>{let{modelTier:e="default",temperature:r=0,abortSignal:n}=t,o=aa.getDefault(),s=await Kc.getCredential(`${o.url}/sharing`),i=Wc[e],a=await wf(e);return new ws({modelName:i,apiKey:"dummy-key",...e!=="default"&&{temperature:r},configuration:{baseURL:a,fetch:Vc(s.token,n)}})},Ij=async(t="default",e)=>{let r=aa.getDefault(),n=await Kc.getCredential(`${r.url}/sharing`),o=la[t],s=await bf(t);return new bs({modelName:o,apiKey:"dummy-key",configuration:{baseURL:s,fetch:Vc(n.token,e)},batchSize:2048,maxConcurrency:10})},Pf=b.object({id:b.string().min(1),name:b.string().min(1),description:b.string().min(1)});b.array(Pf);var Bc=t=>JSON.stringify(t,null,2),kf=t=>{let e=t.map(n=>n.id),r=b.enum(e);return b.object({intent:r.nullable(),assignedTask:b.string().nullable(),requiresFollowUp:b.boolean()})},xj=async(t,e)=>{let r=Tf(e);if(r.abortSignal?.aborted)return await Rn({text:"Run cancelled; skipping intent routing"},e),{...t,currentIntent:"none",finalOutputMessage:"Operation cancelled.",requiresFollowUp:!1};try{await Rn({text:"Asking LLM to route to an agent"},e);let n=r.services.agentRegistry?.list()??[],o=n.map(({agent:x})=>({id:x.id,name:x.name,description:x.description}));if(!o.length)return await Rn({text:"No agents registered; skipping intent detection"},e),{...t,currentIntent:"none",finalOutputMessage:"No agents registered; skipping intent detection."};let s=await Of("intent_prompt"),i=Bc(o),a=kf(o),u={registeredAgents:i,priorSteps:Bc(t.agentExecutionContext.priorSteps),userRequest:t.agentExecutionContext.userRequest},l=await Zs.fromTemplate(s).format(u),c=ra({model:await yo({modelTier:"fast",abortSignal:r.abortSignal}),tools:[],systemPrompt:l,responseFormat:a,middleware:[oa({model:await yo({modelTier:"fast",abortSignal:r.abortSignal}),trigger:{tokens:4e3},keep:{messages:6}}),sa({runLimit:2})]}),{structuredResponse:m}=await Cf({agent:c,messages:t.agentExecutionContext.messages,config:e}),_=a.parse(m??{intent:null,assignedTask:null,requiresFollowUp:!1}),f=_.intent??"none",y={...t,currentIntent:f,requiresFollowUp:_.requiresFollowUp,agentExecutionContext:{...t.agentExecutionContext,assignedTask:_.assignedTask??""}};if(f==="none"){let x=`I could not find an agent that can handle that request. I have access to the following agents: ${n.map(({agent:N})=>N.name).join(", ")}.
|
|
101
101
|
|
|
102
102
|
Please ask a question that can be answered by one of these agents.`;return await Rn({text:"LLM did not identify a clear intent."},e),{...t,currentIntent:f,requiresFollowUp:!1,finalOutputMessage:x,agentExecutionContext:{...t.agentExecutionContext,assignedTask:"",messages:[...t.agentExecutionContext.messages,new S(x)],priorSteps:[...t.agentExecutionContext.priorSteps??[],{agentId:"no-intent-router",assignedTask:t.agentExecutionContext.userRequest,summary:"No matching agent found; asked user to rephrase.",status:"failed"}]}}}return await Rn({text:`Agent picked: ${f}
|
|
103
103
|
Task Assigned: ${_.assignedTask??""}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import c from"./
|
|
2
|
+
import c from"./EECZLT6C.js";import a from"./ETRWZ3MS.js";import{Fb as k,Q as x,a as y,b as l}from"./462JBSEV.js";import{c as b,d as A}from"./HB5A5R2E.js";import"./AMP6IALT.js";import"./OAVEHGB6.js";import{v as w,y as f}from"./OH64RMOR.js";import"./YIMNOUTF.js";export default $arcgis.t(([,,,,,,,,,,,,,{fetchKnowledgeGraph:J},{f:c,l:v,n:_},{K:u,L:K,M:S,N:M,O:G,P:T,Q:C,R:N,S:R,T:z,U:F,a:q,m:g,n:d,p:E}])=>{var L=[T,C,z,N,G,F,R];async function I(e,a){let i=await g("arcgis_knowledge_tool_prompt"),s=K(a),n={assignedTask:e.agentExecutionContext.assignedTask,userRequest:e.agentExecutionContext.userRequest,priorSteps:e.agentExecutionContext.priorSteps,contextType:s},r=await _({promptText:i,messages:e.arcgisKnowledgeMessages,inputVariables:n,tools:L}),t=(r.tool_calls?.length??0)>0,o=typeof r.text=="string"?r.text.trim():"",h=o.length>0,p=r.content.toString();return!t&&(s==="map"||s==="knowledgeGraph")?{...e,arcgisKnowledgeMessages:[...e.arcgisKnowledgeMessages,r],outputMessage:s==="map"?"No tools were found for the current view and prompt. Maps do not support changing nonspatial visibility, layout changes, or generation from queries.":"No tools were found for the current prompt and knowledge graph service. A knowledge graph service only supports search and query.",status:"success"}:{...e,arcgisKnowledgeMessages:[...e.arcgisKnowledgeMessages,r],outputMessage:t?p:o,status:t?e.status:h?"success":"failed",summary:p?d(p):"ArcGIS Knowledge Agent tool executed."}}async function U(e,a){let i=new q(L);try{let s=await i.invoke({messages:e.arcgisKnowledgeMessages},a),n=[];for(let t of s.messages){let o;if(typeof t.content!="string")throw new Error(`Unexpected tool message content type: ${typeof t.content}. Expected string.`);try{o=JSON.parse(t.content)}catch{throw new Error(`Failed to parse tool message content as JSON. Tool: ${t.name??"unknown"}`)}if(!o||typeof o!="object"||!("toolName"in o))throw new Error(`Parsed tool message content does not have expected structure. Parsed content: ${JSON.stringify(o)}`);n.push(o)}await c({text:`Finished executing ArcGIS Knowledge Agent tools: ${s.messages.filter(t=>t.name).map(t=>t.name).join(", ")}`},a);let r=n.filter(t=>typeof t!="string").map(t=>`- Called Tool: ${t.toolName}, Status: ${t.status}`);return{...e,outputMessage:r.join(`
|
|
3
3
|
`),summary:r.length?d(r.join(`
|
|
4
4
|
`)):"ArcGIS Knowledge Agent did not execute any tools or return any results.",arcgisKnowledgeMessages:[...e.arcgisKnowledgeMessages,...s.messages],arcgisKnowledgeToolResult:n}}catch(s){let n=s instanceof Error?s.message:String(s);return await c({text:`ArcGIS Knowledge Agent tool execution failed: ${n}`},a),{...e,outputMessage:`ArcGIS Knowledge Agent tool execution failed: ${n}`,status:"failed",summary:`ArcGIS Knowledge Agent tool execution failed: ${n}`,arcgisKnowledgeMessages:[...e.arcgisKnowledgeMessages]}}}var D=(e,a)=>E([],"ArcgisKnowledge Agent")(e,a);async function j(e,a){let i=(e.arcgisKnowledgeToolResult??[]).map(h=>({...h,details:void 0})),{knowledgeGraph:s}=await S(a),n=M.getDataModelTypesSummary(s.dataModel),r={assignedTask:e.agentExecutionContext.assignedTask,userRequest:e.agentExecutionContext.userRequest,toolResult:i,dataModelSummary:n},t=await v({promptText:await g("arcgis_knowledge_summarize_result_prompt"),modelTier:"default",inputVariables:r}),o=typeof t=="string"?t:t.content;return{...e,outputMessage:o,status:"success",summary:d(o),arcgisKnowledgeMessages:[...e.arcgisKnowledgeMessages,new x(o)]}}var O=()=>new k(u).addNode("requireArcgisKnowledgeServices",D).addNode("agent",I).addNode("tools",U).addNode("summarizationLLM",j).addEdge(y,"requireArcgisKnowledgeServices").addEdge("requireArcgisKnowledgeServices","agent").addConditionalEdges("agent",e=>(e.arcgisKnowledgeMessages[e.arcgisKnowledgeMessages.length-1]?.tool_calls?.length??0)>0?"tools":l).addConditionalEdges("tools",e=>e.status==="failed"?l:"summarizationLLM").addEdge("summarizationLLM",l),V=String.raw`The purpose of this agent is to work with Knowledge Graph data, a graph database technology that represents and stores data as interconnected entities (nodes) and relationships (edges).
|
|
5
5
|
This agent has two categories of skills: those that work with an active link chart visualization of a subset of the data in the knowledge graph, and those that work with the knowledge graph data more generally against the entire dataset in the service and database.
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import a from"./
|
|
2
|
+
import a from"./ETRWZ3MS.js";export default $arcgis.t(([,,,,,{f:t}])=>{var y=async(o,r)=>{let i=o.tool_calls??[];if(i.length===0){await t({text:`LLM did not request any tool calls: ${String(o?.content)}`},r);return}await Promise.all(i.map(async a=>await t({text:`LLM invoked ${a.name} tool with arguments: ${JSON.stringify(a.args,null,2)}`},r)))};return y},"identity/IdentityManager","portal/Portal","core/reactiveUtils","layers/FeatureLayer","request",a)
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import{a as I,b as _}from"./7GH7VSB2.js";import{a as P}from"./H7422XUG.js";import"./MH5RPXHM.js";import a from"./
|
|
2
|
+
import{a as I,b as _}from"./7GH7VSB2.js";import{a as P}from"./H7422XUG.js";import"./MH5RPXHM.js";import a from"./ETRWZ3MS.js";import{Fb as H,Q as F,W as O,a as D,b as W,eb as j,u as q}from"./462JBSEV.js";import{a as B}from"./AMP6IALT.js";import"./OAVEHGB6.js";import{g as $,h as g,l as A,n as u,t as b,u as E,v as L,w as v,y as M}from"./OH64RMOR.js";import"./YIMNOUTF.js";export default $arcgis.t(([_e,{whenOnce:ke,watch:Ce,when:Re},$e,ee,te,K,se,re,,,Ae,{property:w,subclass:Le},{b:N,e:z,f:m,h:S,i:U,j:V,k:T}])=>{var ie=async s=>{let e=await ne(),t=await N("default"),i=te.getDefault(),r=(await ee.getCredential(`${i.url}/sharing`)).token,n={type:"generateEmbeddings",webmapEmbeddings:s,auth:{apiUrl:t,token:r}};return e.postMessage(n),await new Promise((a,l)=>{let o=d=>{d.data==="completed"&&(e.removeEventListener("message",o),a())},c=d=>{e.removeEventListener("message",o),l(d instanceof Error?d:new Error("Embeddings worker error"))};e.addEventListener("message",o),e.addEventListener("error",c,{once:!0})}),e},ne=async()=>{{let s=(await import("./23EQTPO3.js")).default;return new s}},ae=s=>{s.currentIntent="none"},oe=async(s,e)=>{let t=S(e);if(s.agentExecutionContext.userRequest){let r=new O(s.agentExecutionContext.userRequest.trim());s.agentExecutionContext.messages=[...s.agentExecutionContext.messages,r],ae(s)}let i=t?.services.agentRegistry.list().map(r=>r.agent.id)??[];return await m({text:`Available agents: ${[...i].join(", ")}`},e),await m({text:"Analyzing user input"},e),s},ce=async(s,e)=>(await m({text:"Exiting..."},e),s),G=s=>typeof s=="object"&&s!==null&&!Array.isArray(s),le=(s,e)=>{if(!G(s)){s!==void 0&&console.warn(`Agent "${e}" returned invalid sharedStatePatch. Ignoring it.`);return}let t={};for(let[i,r]of Object.entries(s)){if(!G(r)||!("value"in r)){console.warn(`Agent "${e}" returned invalid sharedStatePatch entry for key "${i}". Ignoring that entry.`);continue}t[i]={value:r.value}}return t},de=s=>{let{previousSharedState:e,patch:t,agentId:i}=s;if(!t)return e;let r=Date.now(),n={...e};for(let[a,l]of Object.entries(t))l?.value!==void 0&&(n[a]={value:l.value,meta:{updatedByAgentId:i,updatedAt:r}});return n},Q=s=>typeof s!="string"?void 0:s.trim()||void 0,ge=s=>{switch(s){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."}},he=(s,e)=>{let t=Q(e?.outputMessage),i=Q(e?.summary),r=e?.status,n=r==="success"||r==="failed"?r:"unknown";n==="unknown"&&console.warn(`Agent "${s}" returned missing/invalid status. Defaulting to "unknown".`);let a=le(e?.sharedStatePatch,s);return{outputMessage:t,summary:i??t??ge(n),status:n,sharedStatePatch:a}},J=4e3,ue=async(s,e)=>{let t=S(e);if(t?.abortSignal?.aborted)return await m({text:"Run cancelled; skipping agent execution"},e),{...s,currentIntent:"none",requiresFollowUp:!1};let{agentRegistry:i}=t?.services??{},r=i?.get(s.currentIntent);if(!r)return console.warn(`No agent found for intent: ${s.currentIntent}`),s;await m({text:`Executing registered agent: ${r.agent.name}`},e);let n={...e??{},configurable:{...t??{},agentId:r.agent.id,context:r.getContext?await r.getContext():void 0}},a;try{let c=await r.agent.createGraph().compile().invoke({agentExecutionContext:{...s.agentExecutionContext,messages:[...s.agentExecutionContext.messages],priorSteps:structuredClone(s.agentExecutionContext.priorSteps??[]),sharedState:structuredClone(s.agentExecutionContext.sharedState??{})}},n);a=he(r.agent.name,c),await m({text:`Finished executing registered agent: ${r.agent.name}`},e)}catch(c){if(q(c))throw c;let d=c instanceof Error?c.message:String(c);console.error(`Agent "${r.agent.name}" failed:`,c),await m({text:`Registered agent failed: ${r.agent.name}. ${d}`},e),a={status:"failed",outputMessage:`Agent execution failed: ${d}`,summary:`Agent execution failed: ${d}`}}let l=a.outputMessage,o=[...s.agentExecutionContext.messages];if(l){let c=l.length>J?`${l.slice(0,J-14)}
|
|
3
3
|
[truncated]`:l;o.push(new F(c))}return{...s,stepCount:s.stepCount+1,lastExecutedAgent:r.agent.id,requiresFollowUp:a.status==="failed"?!0:s.requiresFollowUp,finalOutputMessage:l??"",agentExecutionContext:{...s.agentExecutionContext,messages:o,priorSteps:[...s.agentExecutionContext.priorSteps??[],{agentId:r.agent.id,assignedTask:s.agentExecutionContext.assignedTask,summary:a?.summary||"No summary provided.",status:a?.status||"unknown"}],sharedState:de({previousSharedState:s.agentExecutionContext.sharedState,patch:a.sharedStatePatch,agentId:r.agent.id})}}},pe=3,me=()=>new H(z).addNode("ingestInput",oe).addNode("intentLLM",V).addNode("executeRegisteredAgent",ue).addNode("exit",ce).addEdge(D,"ingestInput").addEdge("ingestInput","intentLLM").addConditionalEdges("intentLLM",s=>s.currentIntent==="none"||s.currentIntent===s.lastExecutedAgent?"exit":"executeRegisteredAgent").addConditionalEdges("executeRegisteredAgent",s=>s.stepCount>=pe||!s.requiresFollowUp?"exit":"intentLLM").addEdge("exit",W),k=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()]}},C=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},r=this.graph.streamEvents(null,{...this.config,configurable:{...this.config.configurable,hitlResponse:i},subgraphs:!0,version:"v2"});this.resolveWait?.(r)}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)}},ye=async s=>{try{return await(await U()).embedDocuments(s)}catch(e){throw console.error("Failed to generate embeddings:",e),e}},X=async(s,e)=>{let t=e.get(s);if(t)return t;let i=await ye([s]);return e.set(s,i[0]),i[0]};async function we(s,e,t,i){let r=`req-${Date.now()}`,n={type:"layerSearch",precomputedEmbedding:i?await X(s,i):void 0,requestId:r,minScore:t};return await new Promise(a=>{let l=o=>{o.data.requestId===r&&a(o.data.results)};e.addEventListener("message",l,{once:!0}),e.postMessage(n)})}function fe(s){let{worker:e}=s;return{async searchLayers({text:t,minScore:i,embeddingCache:r}){return await we(t,e,i,r)}}}var ve=async({combinedQuery:s,layerIds:e,embeddingsWorker:t,minScore:i,topResults:r,embeddingCache:n})=>{let a=`req-${Date.now()}`,l=n?await X(s,n):void 0,o={type:"fieldSearch",layerIdForFieldsSearch:e,precomputedEmbedding:l,requestId:a,minScore:i,topResults:r};return await new Promise(c=>{let d=h=>{if(h.data.requestId!==a)return;let f=h.data.results.map(({layerId:Y,results:Z})=>({layerId:Y,results:Z}));c(f)};t.addEventListener("message",d,{once:!0}),t.postMessage(o)})};function be(s){let{worker:e}=s;return{async searchFields({text:t,layerIds:i,minScore:r,topResults:n,embeddingCache:a}){return await ve({combinedQuery:t,layerIds:i,embeddingsWorker:e,minScore:r,topResults:n,embeddingCache:a})}}}var Ee=s=>{let e=T.safeParse(s);if(!e.success)throw new Error("Embeddings response validation failed. Regenerate embeddings.");return e.data},xe=(s,e)=>{let t=new Map,i=new Map;if(e.allLayers.forEach(r=>{r instanceof se&&i.set(r.id,r)}),s.length!==i.size)throw new Error("Layer count mismatch during registry restoration. Regenerate embeddings.");for(let r of s){let n=i.get(r.id);if(!n)throw new Error(`Layer with ID ${r.id} not found in the original map during registry restoration. Regenerate embeddings.`);if(r.fields.length!==n.fields.length)throw new Error(`Field count mismatch for layer ID ${r.id} during registry restoration. Regenerate embeddings.`);let a={name:r.name,title:r.title,description:r.description},l=new Map;for(let o of r.fields){let c=n.fieldsIndex.get(o.name);if(!c)throw new Error(`Field with name ${o.name} not found in the original layer ${r.id} during registry restoration. Regenerate embeddings.`);l.set(o.name,{name:o.name,alias:n.getFieldAlias(o.name)??o.alias,description:o.description,type:c.type||"unknown",valueType:c.valueType||"unknown",domain:n.getFieldDomain(o.name)??void 0})}t.set(r.id,{layerItem:a,fieldRegistry:l})}return t},Se=async s=>{try{return(await re(s,{responseType:"json"})).data}catch(e){throw new Error(`Failed to fetch data from ${s}: ${String(e)}`)}},Ie=async s=>{let e=s.map;if(!e?.portalItem)throw new Error("WebMap portal item is missing.");let{resources:t}=await e.portalItem.fetchResources(),i=t.find(n=>n.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 r=await Se(i.resource.url);return Ee(r)},x=class s{constructor(){this.orchestratorReady=!1,this.chatHistory=[],this.priorSteps=[],this.sharedState={},this.agentRegistry=new k,this.activeRunId="",this.cancelledRunIds=new Set,this.streamEpoch=0}static async init(e){let t=new s;try{if(e.view?.map){await K.whenOnce(()=>e.view.ready);let i=await Ie(e.view),r=xe(i.layers,e.view.map);t.layersAndFieldsRegistry=r,t.embeddingsWorker=await ie(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=String(Date.now());this.activeRunId=t,this.activeAbortController=new AbortController,this.graph||(this.graph=me().compile({checkpointer:new j}));let i=this.embeddingsWorker?fe({worker:this.embeddingsWorker}):void 0,r=this.embeddingsWorker?be({worker:this.embeddingsWorker}):void 0,n=new Map,a={version:"v2",streamMode:"custom",configurable:{thread_id:t,abortSignal:this.activeAbortController.signal,hitlResponse:null,services:{layerSearch:i,fieldSearch:r,layersAndFieldsRegistry:this.layersAndFieldsRegistry,agentRegistry:this.agentRegistry,embeddingCache:n}},subgraphs:!0},l=this.graph?.streamEvents({agentExecutionContext:{userRequest:e,messages:this.chatHistory,priorSteps:this.priorSteps,sharedState:this.sharedState}},a),o=++this.streamEpoch;if(yield*this.pipeStream(l,o,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 d=(await this.graph.getState(a,{subgraphs:!0})).tasks.find(h=>h.interrupts.length>0)?.interrupts[0]?.value;if(!d)break;this.currentInterrupt=d,this.interruptHandler=new C(this.graph,a),yield{runId:t,timestamp:Date.now(),type:"interrupt",interrupt:d};try{let h=await this.interruptHandler.waitForUser(),f=++this.streamEpoch;yield*this.pipeStream(h,f,t)}catch(h){if(this.isRunCancelled(t)){yield{runId:t,timestamp:Date.now(),type:"cancelled",reason:"user"};return}if(h){yield{runId:t,timestamp:Date.now(),type:"error",error:{message:h?.message}};return}}}if(this.isRunCancelled(t)){yield{runId:t,timestamp:Date.now(),type:"cancelled",reason:"user"};return}let c=(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=c.agentExecutionContext.messages.length?c.agentExecutionContext.messages:this.chatHistory,this.priorSteps=c.agentExecutionContext.priorSteps?.slice(-5)??[],this.sharedState=c.agentExecutionContext.sharedState??{},yield{runId:t,timestamp:Date.now(),type:"completed",result:{content:c.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 r of e){if(this.isRunCancelled(i)||t!==this.streamEpoch)break;r.event==="on_custom_event"&&r.name==="trace_message"?yield{runId:i,timestamp:Date.now(),type:"trace",data:r.data}:r.name==="graph_ux_suggestion"&&(yield{runId:i,timestamp:Date.now(),type:"ux-suggestion",suggestion:r.data})}}isRunCancelled(e){return this.cancelledRunIds.has(e)}dispose(){this.embeddingsWorker&&(this.embeddingsWorker.terminate(),this.embeddingsWorker=void 0),this.orchestratorReady=!1}};var Me=$`:host{display:block;width:var(--arcgis-internal-panel-width, 100%);height:var(--arcgis-internal-expand-max-height, 100%)}.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%}.suggested-prompts{display:block;padding:var(--calcite-spacing-md);max-width:100%;box-sizing:border-box}.error-notice{padding:var(--calcite-spacing-sm)}`,Pe=Object.defineProperty,De=Object.getOwnPropertyDescriptor,y=(s,e,t,i)=>{for(var r=i>1?void 0:i?De(e,t):e,n=s.length-1,a;n>=0;n--)(a=s[n])&&(r=(i?a(e,t,r):a(r))||r);return i&&r&&Pe(e,t,r),r},p=class extends Ae{constructor(s){super(s),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 ke(()=>!this.view.updating),this._set("orchestrator",await x.init({agents:[...this.agents],view:this.view??void 0})),this.addHandles([Ce(()=>[this.view,this.agents],()=>{this._initialize()})])}clearChatHistory(){this.orchestrator?.newConversation()}async*ask(s,e){if(!this.orchestrator)throw new Error("Orchestrator not initialized yet.");this._set("processing",!0),this._set("processingStep","");let t=[],i;try{let r=this.orchestrator.ask(s);for await(let n of r){let a=n.runId;if(e?.aborted){yield{type:"cancelled",runId:a};break}switch(n.type){case"trace":{this._set("processingStep",n.data.text),t.push(n.data.text);break}case"completed":{let l=n.result,o=!!l.content.length,c=!!i?.length;if(!o&&!c){yield{type:"completed",error:"Could not process the request.",log:t,runId:a};return}let d=l.content;this._set("processingStep",""),yield{type:"completed",response:d,blocks:i,log:t,runId:a};return}case"ux-suggestion":{let l=n.suggestion;i=i?[...i,l]:[l];break}case"interrupt":{let{kind:l,message:o,metadata:c}=n.interrupt,d=Array.isArray(c)?c.filter(f=>typeof f=="string"):[],h=(()=>{switch(l){case"booleanChoice":return{type:"boolean-choice",message:o,options:d};case"singleSelection":return{type:"single-select",message:o,options:d};case"multipleSelection":return{type:"multi-select",message:o,options:d};case"textInput":return{type:"text-input",message:o};default:return{type:l,message:o,options:d}}})();this._set("processingStep","Waiting for user input..."),yield{type:"interrupt",payload:h,runId:a};break}case"cancelled":{yield{type:"cancelled",runId:a};return}case"error":{yield{type:"completed",error:n.error.message,log:t,runId:a};return}default:{console.warn("Unknown event type:",n);break}}}}catch(r){console.warn("Error during message processing:",r),yield{type:"completed",error:"An error occurred during message processing.",log:t,runId:"error"};return}finally{this._set("processing",!1)}}};y([w({readOnly:!0})],p.prototype,"orchestrator",2);y([w()],p.prototype,"agents",2);y([w()],p.prototype,"portal",2);y([w()],p.prototype,"view",2);y([w({readOnly:!0})],p.prototype,"loading",2);y([w({readOnly:!0})],p.prototype,"processing",2);y([w({readOnly:!0})],p.prototype,"processingStep",2);p=y([Le("OrchestratorController")],p);var We="Embeddings resource 'embeddings-v01.json' not found in the webmap portal item.",qe="Embeddings not found for this web map.",Fe="https://developers.arcgis.com/javascript/latest/agentic-apps/ai-webmap-setup/#embeddings",R=class extends L{constructor(){super(...arguments),this._messages=P({blocking:!0}),this.#e=b(),this.#a=b(),this.#t=b(),this.#s=null,this.#o=new Map,this.#r=$e.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(e.stopPropagation(),this.arcgisCancel.emit(),this._interrupt){this.orchestrator?.cancelInterrupt(),this._interrupt=null;return}this.#s?.abort()},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._error=null,this._inputValue="",this.messages=new _e([]),this.referenceElement=null,this.suggestedPrompts=[],this.feedbackEnabled=!1,this.keepSuggestedPrompts=!1,this.logEnabled=!1,this.copyEnabled=!1,this.voiceInputEnabled=!1,this.readAloudEnabled=!1,this.arcgisCancel=u(),this.arcgisError=u(),this.arcgisFeedback=u(),this.arcgisInterrupt=u(),this.arcgisInterruptCancel=u(),this.arcgisInterruptSubmit=u(),this.arcgisPromptSelect=u(),this.arcgisReady=u(),this.arcgisSubmit=u(),this.arcgisSlottableRequest=u({bubbles:!1,composed:!1})}static{this.properties={_orchestratorController:16,_interrupt:16,_error:16,_inputValue: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}}static{this.styles=Me}#e;#a;#t;#s;#o;#r;#i;#n;#c;#l;#d;#g;#h;async#u(){try{let e=B(this.el,this.referenceElement);await e?.componentOnReady();let t=[...this.#o.values()];return t.length?(this._orchestratorController=new p({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.",A(this)(e),!1}}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;let i=this._orchestratorController.ask(t,this.#s?.signal);for await(let r of i){let n=r.runId;switch(r.type){case"completed":this.messages.push({role:"assistant",content:r.response,blocks:r.blocks,log:r.log,error:r.error,id:n});break;case"interrupt":this._interrupt={...r.payload,id:n},this.arcgisInterrupt.emit(this._interrupt);break;case"cancelled":this.messages.push({role:"assistant",error:"Request cancelled.",id:n});break}}}submitInterrupt(e){this.arcgisInterruptSubmit.emit(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=Re(()=>!!this._interrupt&&!!this.#t.value,()=>{let t=this.#t.value;t.removeEventListener("arcgisSubmit",this.#n),t.removeEventListener("arcgisCancel",this.#i),t.addEventListener("arcgisSubmit",this.#n,{once:!0}),t.addEventListener("arcgisCancel",this.#i,{once:!0})});return queueMicrotask(()=>{this.#u().then(t=>{t?this.arcgisReady.emit():this._error&&this.arcgisError.emit(new Error(this._error))})}),()=>{e.remove(),this.#e.value?.removeEventListener("arcgisPromptSelect",this.#g),this.#t.value?.removeEventListener("arcgisSubmit",this.#n),this.#t.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.#s?.abort(),this._interrupt=null,this.messages.removeAll(),this._error=null,this._inputValue=""}_renderEntryMessage(){return this._interrupt?g`<slot name=interrupt><arcgis-assistant-interrupt .type=${this._interrupt.type} .message=${this._interrupt.message} .options=${this._interrupt.options} ${E(this.#t)}></arcgis-assistant-interrupt></slot>`:this._error?this._renderErrorNotice():this.entryMessage?this.messages.length>0?null:g`<calcite-notice open kind=info closable icon width=full><div slot=message>${this.entryMessage}</div></calcite-notice>`:g`<slot name=entry-message></slot>`}_renderErrorNotice(){return this._error?g`<calcite-notice closable slot=entry-message open kind=danger icon width=full>${this._error===We?g`<div slot=message>${qe}</div><calcite-link slot=link .href=${Fe} target=_blank title="Learn about web map embeddings">Read more</calcite-link>`:g`<div slot=message>${this._error}</div>`}</calcite-notice>`:null}_renderSuggestedPrompts(){return this.suggestedPrompts?.length?g`<div class="suggested-prompts-container"><arcgis-assistant-suggested-prompts class="suggested-prompts" .prompts=${this.suggestedPrompts}></arcgis-assistant-suggested-prompts></div>`:null}render(){return g`<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}><slot name=message-starter slot=message-starter></slot><slot name=messages slot=messages>${this.messages.map(e=>e.role==="assistant"?g`<arcgis-assistant-message .message=${e} .feedbackEnabled=${this.feedbackEnabled} .logEnabled=${this.logEnabled} .copyEnabled=${this.copyEnabled} .readAloudEnabled=${this.readAloudEnabled} @arcgisSlottableRequest=${this.#h}><slot name=${I(e.id)??v} slot=${I(e.id)??v}>${e?.error?g`<calcite-notice class="error-notice" open icon kind=warning width=full><div slot=message>${e.error}</div></calcite-notice>`:g`<arcgis-assistant-message-text .content=${e?.content}></arcgis-assistant-message-text>`}</slot>${e.blocks?.map((t,i)=>g`<slot name=${_(e.id,i)??v} slot=${_(e.id,i)??v}><arcgis-assistant-message-block .block=${t}></arcgis-assistant-message-block></slot>`)}</arcgis-assistant-message>`:g`<arcgis-assistant-user-message .message=${e} .user=${this._user}></arcgis-assistant-user-message>`)}</slot><slot name=message-loading slot=message-loading><arcgis-assistant-message-loading .loading=${this.awaitingResponse} .loadingMessage=${this.awaitingResponseStep}></arcgis-assistant-message-loading></slot></arcgis-assistant-chat></div>${this._renderSuggestedPrompts()}<div class="footer-container" slot=footer>${this._renderEntryMessage()}<slot name=chat-entry><arcgis-assistant-chat-entry .awaitingResponse=${this.awaitingResponse} .inputValue=${this._inputValue} .messages=${this.messages} .voiceInputEnabled=${this.voiceInputEnabled} ${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?"circle-stop":"send"} @click=${()=>{this.#a.value?.submitMessage()}} round>${this.awaitingResponse?this._messages.stopButtonLabel:this._messages.askButtonLabel}</calcite-button></slot></arcgis-assistant-chat-entry></slot><slot name=footer-content></slot></div></calcite-panel>`}};M("arcgis-assistant",R);return R},"core/Collection","core/reactiveUtils","portal/Portal","identity/IdentityManager","portal/Portal","core/reactiveUtils","layers/FeatureLayer","request","identity/IdentityManager","layers/FeatureLayer","core/Accessor","core/accessorSupport/decorators",a)
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import d from"./
|
|
2
|
+
import d from"./I6HNBTWY.js";import c from"./EECZLT6C.js";import a from"./ETRWZ3MS.js";import{Fb as k,Q as V,a as N,b as E}from"./462JBSEV.js";import{a as D,c as O}from"./HB5A5R2E.js";import"./AMP6IALT.js";import"./OAVEHGB6.js";import{v as b,y as A}from"./OH64RMOR.js";import"./YIMNOUTF.js";export default $arcgis.t(([,,,,,,,,,,K,X,,,{f:n,l:z,n:T},{C:R,D:G,E:L,F:P,G:F,H:U,a:j,m:S,n:M,o:p,p:Q},C])=>{var Y=async(e,t)=>(await n({text:"Exiting Data Exploration agent"},t),e),Z=async(e,t)=>{await n({text:"Requesting LLM for layer filter results"},t);let a=await S("data_explore_filter_prompt");if(!t?.configurable)throw new Error("config.configurable is required for layer filter tools");let{userTimezone:c,userTimezoneOffset:l}=L(),s={layerFieldInfo:e.layerFieldInfo,userTimezone:c,userTimezoneOffset:l,queryResponse:e.queryResponse,assignedTask:e.agentExecutionContext.assignedTask,userRequest:e.agentExecutionContext.userRequest,priorSteps:e.agentExecutionContext.priorSteps},r=await T({promptText:a,modelTier:"advanced",messages:e.dataExplorationMessages,inputVariables:s,tools:F}),i=[...e.dataExplorationMessages,r];if(!((r.tool_calls?.length??0)>0))return await n({text:"LLM determined no filter changes needed"},t),{...e,dataExplorationMessages:i};let u=[...i,r],o=r.content.toString();return await C(r,t),{...e,dataExplorationMessages:u,outputMessage:o}},ee=async(e,t)=>{await n({text:"Requesting LLM for layer query results"},t);let a=await S("data_explore_query_prompt");if(!t?.configurable)throw new Error("config.configurable is required for layer query tools");let{userTimezone:c,userTimezoneOffset:l}=L(),s=e.agentExecutionContext.sharedState.lastNavigatedFeatures,r=s&&typeof s=="object"&&"value"in s?s.value:s,i="none";if(r!=null)try{i=JSON.stringify(r)}catch{i="none"}let u={layerFieldInfo:e.layerFieldInfo,userTimezone:c,userTimezoneOffset:l,assignedTask:e.agentExecutionContext.assignedTask,userRequest:e.agentExecutionContext.userRequest,priorSteps:e.agentExecutionContext.priorSteps,lastNavigatedFeatures:i},o=await T({promptText:a,modelTier:"advanced",messages:e.dataExplorationMessages,inputVariables:u,tools:P}),m=o.content.toString();return await C(o,t),{...e,dataExplorationMessages:[...e.dataExplorationMessages,o],outputMessage:m,status:"success",summary:m?M(m):"Query executed."}},te=async(e,t)=>{try{await n({text:"Requesting LLM for summary on query results"},t);let a=await S("summarize_query_response_prompt"),c={queryResponse:e.queryResponse,assignedTask:e.agentExecutionContext.assignedTask,userRequest:e.agentExecutionContext.userRequest,priorSteps:e.agentExecutionContext.priorSteps},l=await z({promptText:a,modelTier:"fast",messages:e.dataExplorationMessages,inputVariables:c}),s=typeof l=="string"?l:l.content,r=new V(s);await n({text:`Received response from LLM: ${s}`},t);let i=s;return{...e,outputMessage:i,status:"success",summary:i?M(i):"Summary generated.",dataExplorationMessages:[...e.dataExplorationMessages,r]}}catch(a){throw await n({text:"Error during filter LLM request"},t),new Error(`Error during filter LLM request: ${a instanceof Error?a.message:String(a)}`)}};async function ae(e,t){let a=await new j(F).invoke({messages:e.dataExplorationMessages},t);return await n({text:`Finished executing layer filter tool: ${a.messages.map(c=>c.content).join(", ")}`},t),{...e}}var se=10,re=["string","small-integer","integer"],ie=async(e,t,{includeSummaryStatistics:a=!0,includeUniqueValues:c=!0}={})=>{let l=null,s=null;try{if(t.type!=="geometry"&&t.type!=="oid"&&t.type!=="global-id"){a&&(l=await K({layer:e,field:t.name}));let r=t.domain?.type==="coded-value"?t.domain:null;c&&(re.includes(t.type)||r)&&(s=(await X({layer:e,field:t.name})).uniqueValueInfos.sort((i,u)=>u.count-i.count).slice(0,se),r&&(s=s.map(i=>({...i,value:r.getName(i.value)??i.value}))))}}catch(r){console.error(`Error fetching statistics for field ${t.name}:`,r)}return{summaryStatistics:l,uniqueValues:s}};function oe(e,t){return["string","small-integer","integer"].includes(e)||t==="coded-value"}async function ne(e,t,a,c=!0){let l=[],s=[],r=[];for(let i of e){let u=function(g){let d=t.get(g)?.layerItem;return d?[d.name&&`Name: ${d.name}`,d.title&&`Title: ${d.title}`,d.description&&`Description: ${d.description}`].filter(Boolean).join(" | "):g},{layerId:o,results:m}=i,f=a.map?.allLayers.find(g=>g.id===o),w=t.get(o)?.fieldRegistry;if(!w)continue;let h=l.find(g=>g.layerId===o);h||(h={layerId:o,layerSummary:u(o),fieldInfos:[]},l.push(h));for(let g of m){let d=w.get(g.name);if(!d)continue;let y=d.statistics,v=c&&!y?.summaryStatistics,q=oe(d.type,d.domain?.type)&&!y?.uniqueValues,_=v||q;if(r.push({layerId:o,fieldName:d.name,didFetchStatistics:_}),_){let J=ie(f,d,{includeSummaryStatistics:v,includeUniqueValues:q}).then($=>{let x={summaryStatistics:y?.summaryStatistics??null,uniqueValues:y?.uniqueValues??null};v&&(x.summaryStatistics=$.summaryStatistics),q&&(x.uniqueValues=$.uniqueValues),w.set(d.name,{...d,statistics:x}),d.statistics=x});s.push(J)}h.fieldInfos.push(d)}}return await Promise.all(s),{layerFieldInfo:l,didFetchStatistics:s.length>0,fieldStatisticsFetchStatus:r}}var W=/\b(average|avg|mean|median|max(?:imum)?|min(?:imum)?|sum|total|count|std(?:dev|\s*deviation)|variance|null\s*count|missing\s*values?|range)\b/iu;function le(e,t){return W.test(e)||W.test(t)}var de=async(e,t)=>{try{await n({text:"Preparing field information for vector search results"},t);let a=p(t,"layersAndFieldsRegistry"),{mapView:c}=G(t),{assignedTask:l,userRequest:s}=e.agentExecutionContext,r=le(l,s),{layerFieldInfo:i,didFetchStatistics:u,fieldStatisticsFetchStatus:o}=await ne(e.vectorSearchFieldResults,a,c,r);u?await n({text:"Statistics fetched"},t):await n({text:"Statistics skipped"},t);for(let m of o)await n({text:` - ${m.fieldName} - stats ${m.didFetchStatistics?"fetched":"skipped"}`},t);return await n({text:"Field information prepared"},t),{...e,layerFieldInfo:i}}catch(a){throw await n({text:"Error during fetching statistics"},t),new Error(`Error during fetching statistics: ${a instanceof Error?a.message:String(a)}`)}},B=.7,ce=10,ue=async(e,t)=>{try{await n({text:"Similarity search to find fields"},t);let a=p(t,"fieldSearch"),c=p(t,"layersAndFieldsRegistry"),l=p(t,"embeddingCache"),s=await a.searchFields({text:e.agentExecutionContext.assignedTask,layerIds:e.vectorSearchLayerIds,minScore:B,topResults:ce,embeddingCache:l}),r=s.map(({layerId:u,results:o})=>{let m=o.map(f=>` - ${f.name} (${f.score.toFixed(2)})`).join(`
|
|
3
3
|
`);return`${c.get(u)?.layerItem.name??u}:
|
|
4
4
|
${m}`}).join(`
|
|
5
5
|
`),i;return s.length>0?i=`Vector search completed. Matching layers and fields with scores:
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import b from"./
|
|
2
|
+
import b from"./EECZLT6C.js";import a from"./ETRWZ3MS.js";import{Fb as C,a as N,b as T}from"./462JBSEV.js";import{a as L,c as R}from"./HB5A5R2E.js";import"./AMP6IALT.js";import"./OAVEHGB6.js";import{v as E,y as $}from"./OH64RMOR.js";import"./YIMNOUTF.js";export default $arcgis.t(([,,,,,,,,,,,,,,,{a:f,f:d,m:b,n:F},{a:_,b:v,c:x,d:I,e:A,f:M,g:Z,h:q,i:j,j:V,k:O,l:z,m:S,n:G,o:h,p:B}])=>{var w=[I,A,M,Z,q,j,V,O,z];async function H(e,t){let a=await S("navigation_tool_prompt"),{mapView:r}=x(t),l=r.map.bookmarks?.map(p=>p.name).filter(Boolean)??[],i=e.vectorSearchLayerResults?.length>0?e.vectorSearchLayerResults.map((p,W)=>`${W+1}. layerId=${p.id} | title=${p.title??""} | name=${p.name??""} | score=${p.score.toFixed(2)}`).join(`
|
|
3
3
|
`):"",c=e.vectorSearchFieldResults?.length>0?JSON.stringify(e.vectorSearchFieldResults,null,2):"",n=e.intent==="goToBookmark"&&l.length?`Available bookmarks:
|
|
4
4
|
${l.map(p=>`- ${p}`).join(`
|
|
5
5
|
`)}`:"",o=(e.intent==="goToLayer"||e.intent==="goToFeatures")&&e.vectorSearchLayerResults?.length?`Candidate layers:
|
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,x as e}from"./OH64RMOR.js";import"./YIMNOUTF.js";var a=s(e,{"arcgis-assistant":[()=>import("./
|
|
2
|
+
import{p as s,x as e}from"./OH64RMOR.js";import"./YIMNOUTF.js";var a=s(e,{"arcgis-assistant":[()=>import("./IG6YKZH3.js"),"_messages:,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("./FX5JFRDL.js"),"agent:,context:;getContext"],"arcgis-assistant-data-exploration-agent":[()=>import("./P26NON3Z.js"),"referenceElement;;getContext"],"arcgis-assistant-help-agent":[()=>import("./53ZCUPKK.js"),"referenceElement;;getContext"],"arcgis-assistant-knowledge-agent":[()=>import("./GGSZM7KV.js"),"context:,referenceElement,serviceUrl;getContext"],"arcgis-assistant-layer-styling-agent":[()=>import("./5XRDJL7R.js"),"referenceElement;;getContext"],"arcgis-assistant-navigation-agent":[()=>import("./S3VPZFWQ.js"),"referenceElement;;getContext"],"arcgis-assistant-chat":[()=>import("./NVI3I46B.js"),"loading,messages:"],"arcgis-assistant-chat-entry":[()=>import("./7PLV4QH6.js"),"_messages:,awaitingResponse,entryPlaceholder,inputValue,keyboardShortcutsDisabled,messages:,status,voiceInputEnabled;submitMessage"],"arcgis-assistant-interrupt":[()=>import("./Y333DGV6.js"),"_messages:,message,options:,type"],"arcgis-assistant-message":[()=>import("./USMDJUFS.js"),"copyEnabled,feedbackEnabled,footerDisabled,logEnabled,message:,readAloudEnabled"],"arcgis-assistant-message-block":[()=>import("./SXDLXCIM.js"),"block:"],"arcgis-assistant-message-feedback":[()=>import("./V2P4AIGG.js"),"_messages:,feedbackEnabled,message:"],"arcgis-assistant-message-footer":[()=>import("./3PKJWIC3.js"),"_messages:,copyEnabled,feedbackEnabled,logEnabled,message:,readAloudEnabled"],"arcgis-assistant-message-loading":[()=>import("./2AXF774U.js"),"loading,loadingMessage"],"arcgis-assistant-message-log":[()=>import("./P6OPJQMC.js"),"log:,logEnabled,showLog"],"arcgis-assistant-message-read-aloud":[()=>import("./DHOVCT6R.js"),"_messages:,message:,readAloudEnabled"],"arcgis-assistant-message-text":[()=>import("./AO7BQHKC.js"),"content"],"arcgis-assistant-speech-input":[()=>import("./QR54T33D.js"),"awaitingResponse,inputValue,language,mode;;clearDraftSession"],"arcgis-assistant-suggested-prompts":[()=>import("./7BCR6TUO.js"),"_messages:,label,prompts:"],"arcgis-assistant-user-message":[()=>import("./DDLZOMUY.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)=>{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)
|
|
@@ -208,7 +208,6 @@ const R = (e) => JSON.stringify(e, null, 2), de = (e) => {
|
|
|
208
208
|
model: await b({ modelTier: "fast", abortSignal: s.abortSignal }),
|
|
209
209
|
tools: [],
|
|
210
210
|
systemPrompt: T,
|
|
211
|
-
checkpointer: !0,
|
|
212
211
|
responseFormat: l,
|
|
213
212
|
middleware: [
|
|
214
213
|
// Preserve recent conversation context while summarizing older messages
|