@arcgis/ai-components 5.0.7 → 5.0.9
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/{XYBXVAHS.js → 23RHBIQG.js} +1 -1
- package/dist/cdn/{HC3YXKVE.js → 36II53D3.js} +1 -1
- package/dist/cdn/{XG7NHSS7.js → 46V7X5JS.js} +1 -1
- package/dist/cdn/{AS5CYI5K.js → 52GK3WHG.js} +1 -1
- package/dist/cdn/{2L2G6TTO.js → 5QOWLY4K.js} +1 -1
- package/dist/cdn/{G5SVW5OY.js → AUBCU3OY.js} +1 -1
- package/dist/cdn/{W2KYGDOS.js → BFHTVXW6.js} +1 -1
- package/dist/cdn/{DNRDUCZV.js → BPQHDASZ.js} +1 -1
- package/dist/cdn/{3SIHFDVG.js → HLPUBPCI.js} +1 -1
- package/dist/cdn/{4KXUYUUA.js → JGIGJE4O.js} +1 -1
- package/dist/cdn/{JWS4SVEU.js → JUAPAUGI.js} +1 -1
- package/dist/cdn/{G2C4Q2YF.js → MUPZUO2E.js} +25 -25
- package/dist/cdn/{FNDI55JS.js → OCPIIJ2S.js} +1 -1
- package/dist/cdn/{E6U4H6CO.js → ONNF5H7M.js} +1 -1
- package/dist/cdn/{V6PPEDFJ.js → P6OWXBI4.js} +1 -1
- package/dist/cdn/{2RG2VLSE.js → XSCK3GGX.js} +1 -1
- package/dist/cdn/{LBAXQLW3.js → YNFGT5LD.js} +1 -1
- package/dist/cdn/{R6KK4LQM.js → ZMGGKF6I.js} +1 -1
- package/dist/cdn/index.js +1 -1
- package/dist/chunks/runtime.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 +6 -6
|
@@ -1,27 +1,27 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.0/LICENSE.txt */
|
|
2
|
-
import a from"./LM63GUX3.js";export default $arcgis.t(([wt,we,We,bt,{addressToLocations:vt},P,me,Ue,K,ie,be,ve,Ke,He,Je,St,{createRenderer:Tt},{getSchemesByTag:xt,getSchemes:Et},{getBackgroundColorTheme:Ce},{createAgeRenderer:It,createContinuousRenderer:Ft},{getSchemesByTag:Se},{createContinuousRenderer:$t},{createRenderer:Lt},{getSchemesByTag:_t},{createRenderer:kt},{getSchemesByTag:Nt},{createRenderer:At},{getSchemesByTag:qt},{createRenderer:Rt},{getSchemesByTag:Mt},{createAgeRenderer:Ct,createContinuousRenderer:zt},{createRenderer:jt},{getSchemesByTag:Vt},Ze,ze,je,{executeQueryStreaming:Ot},Dt,{a:_e,b:ke,c:B,d:de,e:ue,f:O,g:Q,h:C,i:w,j:y,k:N,l:
|
|
2
|
+
import a from"./LM63GUX3.js";export default $arcgis.t(([wt,we,We,bt,{addressToLocations:vt},P,me,Ue,K,ie,be,ve,Ke,He,Je,St,{createRenderer:Tt},{getSchemesByTag:xt,getSchemes:Et},{getBackgroundColorTheme:Ce},{createAgeRenderer:It,createContinuousRenderer:Ft},{getSchemesByTag:Se},{createContinuousRenderer:$t},{createRenderer:Lt},{getSchemesByTag:_t},{createRenderer:kt},{getSchemesByTag:Nt},{createRenderer:At},{getSchemesByTag:qt},{createRenderer:Rt},{getSchemesByTag:Mt},{createAgeRenderer:Ct,createContinuousRenderer:zt},{createRenderer:jt},{getSchemesByTag:Vt},Ze,ze,je,{executeQueryStreaming:Ot},Dt,{a:_e,b:ke,c:B,d:de,e:ue,f:O,g:Q,h:C,i:w,j:y,k:N,l:I,m:Ne,n:Z,o:Y,p:Ae,q:A,r:q,s:s,t:h,u:$,v:X,w:qe,x:D}])=>{var Me=e=>Array.isArray(e)&&e.every(B),ft=e=>typeof e=="object"&&e!=null&&"messages"in e&&Me(e.messages),pt=e=>typeof e=="object"&&e!=null&&"lg_tool_call"in e,z=class extends Ae{tools;handleToolErrors=!0;trace=!1;constructor(e,r){let{name:t,tags:a,handleToolErrors:o}=r??{};super({name:t,tags:a,func:(i,n)=>this.run(i,n)}),this.tools=e,this.handleToolErrors=o??this.handleToolErrors}async runTool(e,r){let t=this.tools.find(a=>a.name===e.name);try{if(t===void 0)throw new Error(`Tool "${e.name}" not found.`);let a=await t.invoke({...e,type:"tool_call"},r);return B(a)&&a.getType()==="tool"||Y(a)?a:new de({status:"success",name:t.name,content:typeof a=="string"?a:JSON.stringify(a),tool_call_id:e.id})}catch(a){if(!this.handleToolErrors||ke(a))throw a;return new de({status:"error",content:`Error: ${a.message}
|
|
3
3
|
Please fix your mistakes.`,name:e.name,tool_call_id:e.id??""})}}async run(e,r){let t;if(pt(e))t=[await this.runTool(e.lg_tool_call,r)];else{let i;if(Me(e))i=e;else if(ft(e))i=e.messages;else throw new Error("ToolNode only accepts BaseMessage[] or { messages: BaseMessage[] } as input.");let n=new Set(i.filter(d=>d.getType()==="tool").map(d=>d.tool_call_id)),l;for(let d=i.length-1;d>=0;d-=1){let c=i[d];if(Q(c)){l=c;break}}if(l==null||!Q(l))throw new Error("ToolNode only accepts AIMessages as input.");t=await Promise.all(l.tool_calls?.filter(d=>d.id==null||!n.has(d.id)).map(d=>this.runTool(d,r))??[])}if(!t.some(Y))return Array.isArray(e)?t:{messages:t};let a=[],o=null;for(let i of t)Y(i)?i.graph===Z.PARENT&&Array.isArray(i.goto)&&i.goto.every(n=>Ne(n))?o?o.goto.push(...i.goto):o=new Z({graph:Z.PARENT,goto:i.goto}):a.push(i):a.push(Array.isArray(e)?[i]:{messages:[i]});return o&&a.push(o),a}};var Is=y.Root({llmInputMessages:y({reducer:(e,r)=>A([],r),default:()=>[]})});var Ye=y.Root({messages:y({reducer:A,default:()=>[]}),outputMessage:y({reducer:(e="",r)=>{let t=typeof r=="string"?r.trim():"";if(!t)return e;let a=e.trim();if(!a)return t;if(a===t)return e;let o=a.split(`
|
|
4
4
|
|
|
5
5
|
`);return o[o.length-1]?.trim()===t?e:`${e}
|
|
6
6
|
|
|
7
|
-
${t}`},default:()=>""}),intent:y({reducer:(e,r)=>r}),vectorSearchLayerResults:y({reducer:(e,r)=>r,default:()=>[]}),vectorSearchFieldResults:y({reducer:(e,r)=>r})});async function Pt(e,r){let t=P.getDefault().helperServices.geocode.find(
|
|
7
|
+
${t}`},default:()=>""}),intent:y({reducer:(e,r)=>r}),vectorSearchLayerResults:y({reducer:(e,r)=>r,default:()=>[]}),vectorSearchFieldResults:y({reducer:(e,r)=>r})});async function Pt(e,r){let t=P.getDefault().helperServices,a=t.geocode.find(E=>E.name==="ArcGIS World Geocoding Service")??t.geocode[0];if(!a)throw new Error("No geocoding service found in helperServices.");let o=a.url,i=`${me.assetsPath?.endsWith("/")?me.assetsPath:`${me.assetsPath}/`}esri/images/search/search-symbol-32.png`,n=(await vt(o,{address:{SingleLine:e},outFields:["Match_addr"]}))?.[0];if(!n?.extent)throw new Error(`Could not find location for: ${e}`);let{xmin:l,ymin:d,xmax:c,ymax:u,spatialReference:m}=n.extent,f=new We({xmin:l,ymin:d,xmax:c,ymax:u,spatialReference:m}),p=(l+c)/2,T=(d+u)/2,g=new we({x:p,y:T,spatialReference:m}),v=new bt({url:i,width:24,height:24}),S=new wt({geometry:g,symbol:v});return r.graphics.removeAll(),r.graphics.add(S),await r.goTo(f),`Successfully zoomed to: ${e}. Location coordinates: x=${p}, y=${T}, wkid=${m.wkid}`}var Gt=["mapView"];function L(e){let r=e?.configurable?.context;if(!r||typeof r!="object")throw new Error("NavigationAgent context missing");let t=Gt.filter(a=>!(a in r));if(t.length)throw new Error(`NavigationAgent context missing: ${t.join(", ")}`);return r}async function Bt({address:e},r){let{mapView:t}=L(r);return await Pt(e,t)}var Qt=s.object({address:s.string().describe("The full address or place name to locate.")}),Wt=w(Bt,{name:"goToAddress",description:"Geocodes an address using Esri's World Geocoding Service and zooms the map to that location.",schema:Qt});async function Ut(e,r){let t=r.map.bookmarks;if(!t||t.length===0)throw new Error("No bookmarks found in the map.");let a=t.find(i=>i.name===e);if(!a)throw new Error(`Bookmark with name "${e}" not found.`);let o=a.viewpoint;if(!o)throw new Error(`Bookmark with name "${e}" does not have a valid viewpoint.`);return await r.goTo(o),`Navigated to bookmark: ${e}`}async function Kt({bookmarkName:e},r){let{mapView:t}=L(r);return await Promise.resolve(Ut(e,t))}var Ht=C.object({bookmarkName:C.string().describe("The name of the bookmark to navigate to.")}),Jt=w(Kt,{name:"goToBookmark",description:"Go to the extent of the bookmark with the given name.",schema:Ht});async function Zt(e,r,t){let a=t.map?.allLayers.find(i=>i.id===e);if(!a)return`Error: Layer with id ${e} not found`;let o=a.createQuery();o.where=r??"1=1";try{let{extent:i,count:n}=await a.queryExtent(o);if(n===0)return`No features found in ${a.title} matching: ${r}`;if(i)await t.goTo(i);else return`Error: Unable to determine extent for ${a.title}`;return`Successfully zoomed to ${n} feature(s) in ${a.title}`}catch(i){return console.error("Error in goToFeatures:",i),`Error: ${i instanceof Error?i.message:"Unknown error"}`}}async function Yt({layerId:e,where:r},t){let{mapView:a}=L(t);return await Zt(e,r,a)}var Xt=C.object({layerId:C.string().describe("The layerId of the layer to zoom to."),where:C.string().describe("The sql-92 where clause used to query features to zoom to")}),er=w(Yt,{name:"goToFeatures",description:"Go to the features that match the given filter related to the given layerId.",schema:Xt});async function tr(e){let r=new We({xmin:-180,ymin:-90,xmax:180,ymax:90,spatialReference:{wkid:4326}}).expand(.7);return await e.goTo(r),"Successfully zoomed to world extent"}async function rr(e,r){let{mapView:t}=L(r);return await tr(t)}var ar=C.object({}),or=w(rr,{name:"goToFullExtent",description:"Zooms the map to the full world extent using Esri's Geocoding Service.",schema:ar});async function ir(e){let r=e.map.initialViewProperties?.viewpoint?.targetGeometry;if(r)await e.goTo(r);else throw new Error("Initial extent is undefined");return"Successfully zoomed to home extent"}async function nr(e,r){let{mapView:t}=L(r);return await ir(t)}var sr=s.object({}),lr=w(nr,{name:"goToHomeExtent",description:"Go to the initial web map view extent",schema:sr});async function cr(e,r){await r.when();let t=r.map?.allLayers.find(o=>o.id===e);if(!t)return console.warn(`[goToLayer] No matching FeatureLayer found for: ${e}`),`Could not find layer for: ${e}`;let a;return(t.type==="link-chart"||t.type==="knowledge-graph-sublayer")&&r.map?.activeLinkChartLayer?a=r.map.diagramNodesExtent:a=t.fullExtent,a?(await r.goTo(a),t.visible=!0,`Successfully zoomed to: ${t.title??""}`):"Layer has no defined extent. Cannot zoom to layer."}async function dr({layerId:e},r){let{mapView:t}=L(r);return await cr(e,t)}var ur=C.object({layerId:C.string().describe("The id of the layer to navigate to")}),hr=w(dr,{name:"goToLayer",description:"Zooms the map view to the full extent of the top matching layer.",schema:ur});async function mr(e,r){return await r.goTo({scale:e}),`Successfully zoomed to: ${e}`}async function fr({scale:e},r){let{mapView:t}=L(r);return await mr(e,t)}var pr=s.object({scale:s.number().describe("The map scale of the view to go to.")}),gr=w(fr,{name:"goToScale",description:"Go to the specified view scale.",schema:pr});async function yr(e,r,t){let a={target:new we({longitude:e.longitude,latitude:e.latitude,spatialReference:{wkid:4326}})};return t?.zoom!==void 0&&(a.zoom=t.zoom),t?.scale!==void 0&&(a.scale=t.scale),await r.goTo(a),`Successfully navigated to: ${[`(${e.latitude}\xB0, ${e.longitude}\xB0)`,t?.zoom!==void 0?`zoom ${t.zoom}`:"",t?.scale!==void 0?`scale 1:${t.scale}`:""].filter(Boolean).join(", ")}`}async function wr({center:e,zoom:r,scale:t},a){let{mapView:o}=L(a);return await yr(e,o,{zoom:r,scale:t})}var br=s.object({center:s.object({longitude:s.number().describe("The longitude (x-coordinate) of the point to navigate to."),latitude:s.number().describe("The latitude (y-coordinate) of the point to navigate to.")}),zoom:s.number().optional().describe("The zoom level. Higher values = more zoomed in."),scale:s.number().optional().describe("The map scale. Alternative to zoom. Smaller numbers = more zoomed in.")}),vr=w(wr,{name:"goToViewpoint",description:"Go to the specified viewpoint. This can contain a combination of scale, center, zoom, etc.",schema:br});async function Sr(e,r){return await r.goTo({zoom:e}),`Successfully zoomed to: ${e}`}async function Tr({zoom:e},r){let{mapView:t}=L(r);return await Sr(e,t)}var xr=s.object({zoom:s.number().min(1).max(20).describe("The zoom level of the view to go to.")}),Er=w(Tr,{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:xr}),Te=[Wt,Jt,er,or,lr,hr,gr,vr,Er],Ve=Object.assign({"../agents/arcgisKnowledge/prompts/arcgis_knowledge_current_lc_context.md":()=>import("./QZJ4SRT5.js").then(e=>e.default),"../agents/arcgisKnowledge/prompts/arcgis_knowledge_intent_prompt.md":()=>import("./BN4IYD74.js").then(e=>e.default),"../agents/arcgisKnowledge/prompts/arcgis_knowledge_tool_prompt.md":()=>import("./M32BWJ4D.js").then(e=>e.default),"../agents/dataExploration/prompts/data_explore_filter_prompt.md":()=>import("./2NGJKVKI.js").then(e=>e.default),"../agents/dataExploration/prompts/data_explore_query_prompt.md":()=>import("./VL4VHVEB.js").then(e=>e.default),"../agents/dataExploration/prompts/summarize_query_response_prompt.md":()=>import("./I2OEGQRT.js").then(e=>e.default),"../agents/help/prompts/help_prompt.md":()=>import("./XOLWLHTD.js").then(e=>e.default),"../agents/layerFilter/prompts/layer_filter_prompt.md":()=>import("./Y4325EIX.js").then(e=>e.default),"../agents/layerQuery/prompts/data_query_prompt.md":()=>import("./3YA7AYJB.js").then(e=>e.default),"../agents/layerQuery/prompts/summarize_query_response_prompt.md":()=>import("./JVPRUGML.js").then(e=>e.default),"../agents/layerStyling/prompts/layer_styling_prompt.md":()=>import("./TBTPT64L.js").then(e=>e.default),"../agents/navigation/prompts/navigation_intent_prompt.md":()=>import("./QYS2QVQH.js").then(e=>e.default),"../agents/navigation/prompts/navigation_tool_prompt.md":()=>import("./IMPD5HA4.js").then(e=>e.default)});async function _(e){let r=Object.entries(Ve).find(([t])=>t.endsWith(`/${e}.md`));if(!r)throw new Error(`Prompt not found: ${e}
|
|
8
8
|
Available prompts:
|
|
9
9
|
${Object.keys(Ve).join(`
|
|
10
10
|
`)}`);return await r[1]()}var Ir=(e,r=3)=>e.filter(t=>t instanceof ue).slice(-r),x=(e,r=3)=>{let t=e.map((o,i)=>o instanceof ue?i:-1).filter(o=>o!==-1);if(t.length===0)return[];let a=t.length>r?t[t.length-r]:t[0];return e.slice(a)},R=(e,r=" ")=>Ir(e).map(t=>t.content).join(r).trim();async function Fr(e,r){let t=await _("navigation_tool_prompt"),{mapView:a}=L(r),o=a.map,i=e.vectorSearchLayerResults?.length>0?e.vectorSearchLayerResults.map((T,g)=>`${g+1}. layerId=${T.id} | title=${T.title??""} | name=${T.name??""} | score=${T.score.toFixed(2)}`).join(`
|
|
11
11
|
`):"",n=e.vectorSearchFieldResults?.length>0?JSON.stringify(e.vectorSearchFieldResults,null,2):"",l=e.intent==="goToBookmark"&&o.bookmarks?.length?`Available bookmarks:
|
|
12
12
|
${JSON.stringify(o.bookmarks,null,2)}`:"",d=(e.intent==="goToLayer"||e.intent==="goToFeatures")&&e.vectorSearchLayerResults?.length?`Candidate layers:
|
|
13
13
|
${i}`:"",c=e.intent==="goToFeatures"&&e.vectorSearchFieldResults?.length?`Candidate fields:
|
|
14
|
-
${n}`:"",u={intent:e.intent,bookmarksSection:l,layersSection:d,fieldsSection:c,currentZoom:a.zoom},
|
|
14
|
+
${n}`:"",u={intent:e.intent,bookmarksSection:l,layersSection:d,fieldsSection:c,currentZoom:a.zoom},m=await D({promptText:t,modelTier:"advanced",messages:x(e.messages),inputVariables:u,tools:Te}),f=[...e.messages,m],p=(m.tool_calls?.length??0)>0?[...f]:[...f,m];return{...e,messages:p}}async function $r(e,r){let t=await new z(Te).invoke({messages:x(e.messages)},r),a=t.messages.map(n=>n.text).join(`
|
|
15
15
|
`);await h({text:`Finished executing navigation tool: ${a}`},r);let o=[...e.messages,...t.messages],i=t.messages.map(n=>n.text).join(`
|
|
16
|
-
`);return{...e,messages:o,outputMessage:i}}async function Lr(e,r){let t=await _("navigation_intent_prompt"),{mapView:a}=L(r),o=Te.map(
|
|
17
|
-
${JSON.stringify(i.bookmarks,null,2)}`:"",l={tools:o.map(({name:
|
|
16
|
+
`);return{...e,messages:o,outputMessage:i}}async function Lr(e,r){let t=await _("navigation_intent_prompt"),{mapView:a}=L(r),o=Te.map(m=>({name:m.name,description:m.description,schema:m.schema})),i=a.map,n=i.bookmarks?.length?`Available bookmarks:
|
|
17
|
+
${JSON.stringify(i.bookmarks,null,2)}`:"",l={tools:o.map(({name:m,description:f,schema:p})=>`${m}: ${f}, ${JSON.stringify(p)}`).join(`
|
|
18
18
|
`),bookmarks:n},d=s.object({intent:s.string()}),c=await qe({promptText:t,messages:x(e.messages),inputVariables:l,schema:d}),u=typeof c.intent=="string"?c.intent.trim().replace(/^"|"$/gu,""):"";return{...e,intent:u||""}}var b=(e,r)=>{let t=e?.configurable?.services?.[r];if(t==null)throw new Error(`${r} missing in config.configurable.services`);return t},_r=.7,kr=async(e,r)=>{try{let t=R(e.messages);await h({text:`Similarity search to find layers: ${t}`},r);let a=b(r,"layerSearch"),o=b(r,"layersAndFieldsRegistry"),i=b(r,"embeddingCache"),n=(await a.searchLayers({text:t,minScore:_r,embeddingCache:i})).map(({id:d,score:c})=>{let u=o.get(d)?.layerItem;return{id:d,title:u?.title,name:u?.name??void 0,score:c}}),l;return n.length>0?l=`Vector search completed. Matching layers:
|
|
19
19
|
${n.map(d=>`- layerId=${d.id} | title=${d.title??""} | name=${d.name??""} | score=${d.score.toFixed(2)}`).join(`
|
|
20
|
-
`)}`:l="Vector search completed. No matching layers found.",await h({text:l},r),{...e,vectorSearchLayerResults:n}}catch(t){throw await h({text:`Error during vector search layers: ${t instanceof Error?t.message:String(t)}`},r),t}},Oe=.7,Nr=10,Ar=async(e,r)=>{try{let t=R(e.messages);await h({text:"Similarity search to find fields"},r);let a=b(r,"fieldSearch"),o=b(r,"layersAndFieldsRegistry"),i=b(r,"embeddingCache"),n=e.vectorSearchLayerResults?.map(c=>c.id)??[];if(n.length===0)return await h({text:"No candidate layers for field search"},r),e;let l=(await a.searchFields({text:t,layerIds:n,minScore:Oe,topResults:Nr,embeddingCache:i})).map(({layerId:c,results:u})=>{let
|
|
20
|
+
`)}`:l="Vector search completed. No matching layers found.",await h({text:l},r),{...e,vectorSearchLayerResults:n}}catch(t){throw await h({text:`Error during vector search layers: ${t instanceof Error?t.message:String(t)}`},r),t}},Oe=.7,Nr=10,Ar=async(e,r)=>{try{let t=R(e.messages);await h({text:"Similarity search to find fields"},r);let a=b(r,"fieldSearch"),o=b(r,"layersAndFieldsRegistry"),i=b(r,"embeddingCache"),n=e.vectorSearchLayerResults?.map(c=>c.id)??[];if(n.length===0)return await h({text:"No candidate layers for field search"},r),e;let l=(await a.searchFields({text:t,layerIds:n,minScore:Oe,topResults:Nr,embeddingCache:i})).map(({layerId:c,results:u})=>{let m=o.get(c)?.fieldRegistry;return{layerId:c,layerName:o.get(c)?.layerItem.name,results:u.map(f=>{let p=m?.get(f.name);return{name:f.name,score:f.score,type:p?.type,alias:p?.alias,description:p?.description,statistics:p?.statistics}})}}),d;return l.length>0?d=`Vector search completed. Matching layers and fields:
|
|
21
21
|
${l.map(c=>`${c.layerName??c.layerId}:
|
|
22
22
|
${c.results.map(u=>` - ${u.name} (${u.score.toFixed(2)})`).join(`
|
|
23
23
|
`)}`).join(`
|
|
24
|
-
`)}`:d=`No vector search field results found for score over ${Oe}.`,await h({text:d},r),{...e,vectorSearchFieldResults:l}}catch(t){throw await h({text:`Error during vector search fields: ${t instanceof Error?t.message:String(t)}`},r),t}},G=(e,r)=>(t,a)=>{let o=a?.configurable?.services;for(let i of e)if(!o?.[i])throw new Error(`${r} requires services.${i} to be available.`);return t},qr=(e,r)=>G(["layerSearch","layersAndFieldsRegistry"],"Navigation Agent")(e,r),Rr=()=>new q(Ye).addNode("requireNavigationServices",qr).addNode("intentLLM",Lr).addNode("vectorSearchLayers",kr).addNode("vectorSearchFields",Ar).addNode("agent",Fr).addNode("tools",$r).addEdge(N,"requireNavigationServices").addEdge("requireNavigationServices","intentLLM").addConditionalEdges("intentLLM",e=>e.intent==="goToLayer"||e.intent==="goToFeatures"?"vectorSearchLayers":"agent",{vectorSearchLayers:"vectorSearchLayers",agent:"agent"}).addConditionalEdges("vectorSearchLayers",e=>e.intent==="goToFeatures"?"vectorSearchFields":"agent",{vectorSearchFields:"vectorSearchFields",agent:"agent"}).addEdge("vectorSearchFields","agent").addEdge("agent","tools").addEdge("tools",
|
|
24
|
+
`)}`:d=`No vector search field results found for score over ${Oe}.`,await h({text:d},r),{...e,vectorSearchFieldResults:l}}catch(t){throw await h({text:`Error during vector search fields: ${t instanceof Error?t.message:String(t)}`},r),t}},G=(e,r)=>(t,a)=>{let o=a?.configurable?.services;for(let i of e)if(!o?.[i])throw new Error(`${r} requires services.${i} to be available.`);return t},qr=(e,r)=>G(["layerSearch","layersAndFieldsRegistry"],"Navigation Agent")(e,r),Rr=()=>new q(Ye).addNode("requireNavigationServices",qr).addNode("intentLLM",Lr).addNode("vectorSearchLayers",kr).addNode("vectorSearchFields",Ar).addNode("agent",Fr).addNode("tools",$r).addEdge(N,"requireNavigationServices").addEdge("requireNavigationServices","intentLLM").addConditionalEdges("intentLLM",e=>e.intent==="goToLayer"||e.intent==="goToFeatures"?"vectorSearchLayers":"agent",{vectorSearchLayers:"vectorSearchLayers",agent:"agent"}).addConditionalEdges("vectorSearchLayers",e=>e.intent==="goToFeatures"?"vectorSearchFields":"agent",{vectorSearchFields:"vectorSearchFields",agent:"agent"}).addEdge("vectorSearchFields","agent").addEdge("agent","tools").addEdge("tools",I),Mr=String.raw`- **navigation** — Enables users to interact with the map by navigating to specific locations, layers, features, or extents.
|
|
25
25
|
This includes zooming, panning, centering, or geocoding based on user input. The agent is designed to handle explicit map movement requests. NOTE: DO NOT call this agent if the user asks "show me...", that is meant to be handled by another agent. If the query is about where a certain address is, call this agent.
|
|
26
26
|
|
|
27
27
|
Supported actions:
|
|
@@ -44,7 +44,7 @@ ${c.results.map(u=>` - ${u.name} (${u.score.toFixed(2)})`).join(`
|
|
|
44
44
|
|
|
45
45
|
`);return o[o.length-1]?.trim()===t?e:`${e}
|
|
46
46
|
|
|
47
|
-
${t}`},default:()=>""}),vectorSearchLayerIds:y(),vectorSearchFieldResults:y(),layerFieldInfo:y(),queryResponse:y()}),Cr=async(e,r)=>(await h({text:"Exiting Data Exploration agent"},r),e),H=async(e,r)=>{let t=e.tool_calls??[];if(t.length===0){await h({text:`LLM did not request any tool calls: ${String(e?.content)}`},r);return}await Promise.all(t.map(async a=>await h({text:`LLM invoked ${a.name} tool with arguments: ${JSON.stringify(a.args,null,2)}`},r)))},zr=["mapView"];function V(e){let r=e?.configurable?.context;if(!r||typeof r!="object")throw new Error("DataExplorationAgent context missing");let t=zr.filter(a=>!(a in r));if(t.length)throw new Error(`DataExplorationAgent context missing: ${t.join(", ")}`);return r}var jr=e=>{let r=e.map?.allLayers.filter(a=>a.type==="feature"),t=0;return r?.forEach(a=>{let o=a;o.featureEffect&&(o.featureEffect=null,t++)}),t>0?`Cleared filters from ${t} layer(s). View unchanged.`:"No active filters to clear. View unchanged."},Vr=async(e,r)=>{let{mapView:t}=V(r);return jr(t)},Or=w(Vr,{name:"clearFilters",description:"Clears all feature effects/filters from the map but does NOT change the current view. Use when user says 'clear filters', 'reset filters', 'remove filters', 'show all features', or wants to remove emphasis without navigating anywhere.",schema:s.object({})}),Dr=async e=>{e.map?.allLayers.filter(t=>t.type==="feature")?.forEach(t=>{let a=t;a.featureEffect&&(a.featureEffect=null)});let r=e.map.initialViewProperties?.viewpoint?.targetGeometry;return r?(await e.goTo(r),"Cleared all filters and returned to home extent."):"Cleared all filters. Could not determine home extent."},Pr=async(e,r)=>{let{mapView:t}=V(r);return await Dr(t)},Gr=w(Pr,{name:"resetMap",description:"Clears all feature effects/filters from the map AND zooms to the home extent (initial map view). Use when user says 'reset map', 'reset the map', 'start over', or wants to both clear filters and return to the initial view.",schema:s.object({})});function re(e){return"point"in e&&e.point!==void 0}function W(e){return"layerId"in e&&e.layerId!==void 0}var ne=async(e,r)=>{if(re(e)){let{point:t}=e;return{geometry:new we({x:t.x,y:t.y,spatialReference:t.spatialReference?{wkid:t.spatialReference.wkid}:r.spatialReference})}}if(W(e)){let t=r.map?.allLayers.find(a=>a.id===e.layerId);if(!t)return{error:`Could not find geometry layer with ID: ${e.layerId}`};try{let a=await t.queryFeatures({where:e.where,returnGeometry:!0,outSpatialReference:r.spatialReference});if(!a.features.length)return{error:`No features found in geometry layer with the specified where clause: ${e.where}`};let o;if(a.features.length===1){let i=a.features[0].geometry;if(!i)return{error:"The geometry of the first feature is undefined or null."};o=i}else{let i=a.features.map(l=>l.geometry),n=ie.executeMany(i);if(!n)return{error:"Failed to create a combined geometry."};o=n}return o.spatialReference||(o.spatialReference=r.spatialReference),{geometry:o}}catch(a){return{error:`Failed to query geometry: ${String(a)}`}}}return{error:"Invalid geometry configuration provided"}},Br=async(e,r,t,a,o,i)=>{let n=e.map?.allLayers.find(d=>d.id===r);if(!n)return{success:!1,error:`Layer '${r}' not found.`};let l=n.createQuery();l.where=t??"1=1",a&&(l.geometry=a,l.spatialRelationship="intersects",o&&(l.distance=o),i&&(l.units=i));try{let{extent:d,count:c}=await n.queryExtent(l);return!d||c===0?{success:!1,error:`No features found for filter (where: ${l.where}${a?", spatial filter used":""})`}:(await e.goTo(d),{success:!0})}catch(d){return{success:!1,error:d instanceof Error?d.message:String(d)}}},Qr=async(e,r,t,a,o,i)=>{let n=r.map?.allLayers.find(u=>u.id===e.layerId);if(!n)return`Could not find target layer with ID: ${e.layerId}`;let l;if(o){let u=await ne(o,r);if("error"in u)return u.error;l=u.geometry}if(n.featureEffect=null,n.featureEffect=new Ue({filter:new K({where:e.where,geometry:l,spatialRelationship:"intersects",distance:o?.distance,units:o?.units}),includedEffect:t,excludedEffect:a}),n.visible=!0,i)return`Applied feature effects to "${n.title??e.layerId}" within current map extent.`;let d=await Br(r,e.layerId,e.where,l,o?.distance,o?.units),c=n.title??e.layerId;return d.success?`Applied feature effects to target layer "${n.title??e.layerId}"${o&&"layerId"in o?` using geometry from layer "${o.layerId}"`:""}.`:`Applied filter to "${c}" but no features matched. ${d.error}`},Wr=["feet","kilometers","meters","miles","nautical-miles","us-nautical-miles"],M=s.enum(Wr),Ur=async({targetLayer:e,geometryFilter:r,useCurrentExtent:t,includedEffect:a="drop-shadow(2px, 2px, 2px, gray)",excludedEffect:o="grayscale(100%) opacity(60%) blur(2px)"},i)=>{let{mapView:n}=V(i);return await Qr(e,n,a,o,r,t)},Kr=s.object({layerId:s.string().describe("The layerId of the layer containing the geometry by which to filter."),where:s.string().describe("The SQL-92 where clause representing the features from which to filter."),distance:s.number().optional().describe("The buffer distance around the geometry."),units:M.optional().describe("The units for the distance buffer.")}),Hr=s.object({point:s.object({x:s.number().describe("X coordinate (longitude) from navigation result"),y:s.number().describe("Y coordinate (latitude) from navigation result"),spatialReference:s.object({wkid:s.number().describe("Spatial reference WKID (e.g., 4326 for WGS84)")}).optional().describe("Spatial reference. Defaults to map's spatial reference if not provided.")}).describe("Point coordinates from a previous navigation/geocoding result"),distance:s.number().optional().describe("Optional buffer distance around the point."),units:M.optional().describe("The units for the distance buffer.")}),Jr=s.object({targetLayer:s.object({layerId:s.string().describe("The layerId of the layer on which to set a feature effect."),where:s.string().describe("The SQL-92 where clause representing the features to emphasize.")}),geometryFilter:s.union([Kr,Hr]).optional().describe("Optional geometry-based filtering parameters for spatial queries."),useCurrentExtent:s.boolean().optional().describe("Set to true when the previous query used the current map extent as a spatial filter. This ensures the feature effect applies only to features visible in the current view. Default is false."),includedEffect:s.string().default("drop-shadow(2px, 2px, 2px, gray)").describe("The effect applied to features that meet the filter requirements. Valid effects include: bloom, blur, brightness, contrast, drop-shadow, grayscale, hue-rotate, invert, opacity, saturate, and sepia. Prefer default unless specified."),excludedEffect:s.string().default("grayscale(100%) opacity(60%) blur(2px)").describe("The effect applied to features that do not meet the filter requirements. Valid effects include: bloom, blur, brightness, contrast, drop-shadow, grayscale, hue-rotate, invert, opacity, saturate, and sepia. Prefer default unless specified.")}),Zr=w(Ur,{name:"setFeatureEffect",description:"Sets a feature effect on a given layer with given filter parameters and feature effects to emphasize certain features that meet a filter requirement. If no feature effect information is provided, then use the default effect provided.",schema:Jr}),ae=(e,r,t)=>{if(e&&typeof e!="function"){let a="getField"in t&&t.getField?.(e),o=a&&"getFieldDomain"in t&&t.getFieldDomain?t.getFieldDomain(a.name):null;if(o?.type==="coded-value"){let i=o.codedValues.find(n=>n.code===r);return i?i.name:null}}return null},Yr=(e,r,t)=>{let a=e.createQuery();return a.outFields=[r],a.where=t||"1=1",a.num=1,a},Xr=async(e,r,t,a)=>{let o=a.map?.allLayers.find(c=>c.id===e),i=Yr(o,r,t.where),n=(await o.queryFeatures(i)).features[0],l=n?n.attributes[r]:null,d=ae(r,l,o)||l;return{tool:"getAttribute",layerName:o.title??e,summary:`${r} = ${d}`,details:{fieldName:r,value:d,where:t.where}}};async function ea({layerId:e,fieldName:r,query:t},a){let{mapView:o}=V(a),i=await Xr(e,r,t,o);return JSON.stringify(i,null,2)}var ta=s.object({layerId:s.string().describe("The layerId of the layer containing the field from which to get a value."),fieldName:s.string().describe("The name of the field/attribute from which to get a field value."),query:s.object({where:s.string().describe("The SQL-92 where clause representing the feature from which to get an attribute value.")})}),ra=w(ea,{name:"getAttribute",description:"Returns an attribute value for a given feature.",schema:ta}),xe=(e,r,t)=>t?e.hasAllFeaturesInView&&e.availableFields===r:e.hasAllFeatures&&e.availableFields===r;function oe(e,r){let t=e??"";return r!=null&&r&&(t=t?`(${t}) AND (${r})`:r),t||null}var aa=async e=>{let{targetLayer:r,fieldName:t,statisticType:a,mapView:o,layersAndFieldsRegistry:i,geometryFilter:n}=e,l=o.map?.allLayers.find(S=>S.id===r.layerId);if(!l)throw new Error(`Layer '${r.layerId}' not found.`);let d=await o.whenLayerView(l),c=i.get(r.layerId)?.fieldRegistry.get(t),u=c?.alias;if(!c)throw new Error(`Field '${t}' not found.`);let f,m;if(n){let S=await ne(n,o);if("error"in S)throw new Error(S.error);if(!S.geometry)throw W(n)?new Error(`No features found matching: ${n.where}`):new Error("Failed to create geometry");W(n)?f={geometryLayerId:n.layerId,geometryWhere:n.where,distance:n.distance,units:n.units,applied:!0}:re(n)&&(f={point:n.point,distance:n.distance,units:n.units,applied:!0}),m=new K({geometry:S.geometry,distance:n.distance,units:n.units,spatialRelationship:"intersects"})}let p=xe(d,[t],!1),T=null,g=null,v=10;if(c.type!=="geometry"&&c.type!=="oid"&&c.type!=="global-id")try{let S={layer:l,useFeaturesInView:p,view:p?o:void 0,field:t,sqlWhere:oe(l.definitionExpression,r.where),...m&&{filter:m},outStatisticTypes:{include:[a]}};T=await be(S);let I=["string","small-integer","integer"],F=c.domain?.type==="coded-value"?c.domain:null;(I.includes(c.type)||F)&&(g=(await ve({layer:l,useFeaturesInView:p,view:p?o:void 0,field:t,sqlWhere:oe(l.definitionExpression,r.where),...m&&{filter:m}})).uniqueValueInfos.sort((j,ce)=>ce.count-j.count).slice(0,v)),g&&c.domain?.type==="coded-value"&&(g=g.map(j=>({...j,value:F?F.getName(j.value)??j.value:j.value})))}catch(S){console.error("Statistics error:",S)}return{tool:"getStatistics",layerName:l.title??r.layerId,summary:`${a} = ${typeof T?.[a]=="number"?T[a]:"N/A"}`,details:{fieldName:t,fieldAlias:u,statisticType:a,statistic:T?.[a]??null,summaryStatistics:T,uniqueValues:g,where:r.where,spatialFilterInfo:f}}};async function oa({targetLayer:e,fieldName:r,statisticType:t,geometryFilter:a},o){let i=b(o,"layersAndFieldsRegistry"),{mapView:n}=V(o),l=await aa({targetLayer:e,fieldName:r,statisticType:t,mapView:n,layersAndFieldsRegistry:i,geometryFilter:a});return JSON.stringify(l,null,2)}var ia=s.object({layerId:s.string().describe("The layerId of the layer containing the geometry by which to filter."),where:s.string().describe("The SQL-92 where clause representing the features from which to filter."),distance:s.number().optional().describe("The buffer distance around the geometry."),units:M.optional().describe("The units for the distance buffer.")}),na=s.object({point:s.object({x:s.number().describe("X coordinate (longitude) from navigation result"),y:s.number().describe("Y coordinate (latitude) from navigation result"),spatialReference:s.object({wkid:s.number().describe("Spatial reference WKID (e.g., 4326 for WGS84)")}).optional().describe("Spatial reference. Defaults to map's spatial reference if not provided.")}).describe("Point coordinates from a previous navigation/geocoding result"),distance:s.number().optional().describe("Optional buffer distance around the point."),units:M.optional().describe("The units for the distance buffer.")}),sa=s.object({targetLayer:s.object({layerId:s.string().describe("The layerId of the layer containing the field from which to get a value."),where:s.string().describe("The SQL-92 where clause representing the feature from which to get an attribute value.")}),geometryFilter:s.union([ia,na]).optional().describe("Geometry filter for spatial queries. Use 'point' option with x/y coordinates from navigation results to find features at that location (point-in-polygon). Use 'layerId/where' option to filter by features from another layer."),fieldName:s.string().describe("The name of the field for which to get statistics. STRICTLY DO NOT use OBJECTID. Use any other field"),statisticType:s.enum(["avg","max","median","min","stddev","sum","variance","nullcount","count"]).describe("The statistic type to calculate.")}),la=w(oa,{name:"getStatistics",description:`Computes a single aggregate statistic (max, min, avg, sum, median, stddev, variance) for a numeric field across matching features. Also returns frequency analysis for categorical fields.
|
|
47
|
+
${t}`},default:()=>""}),vectorSearchLayerIds:y(),vectorSearchFieldResults:y(),layerFieldInfo:y(),queryResponse:y()}),Cr=async(e,r)=>(await h({text:"Exiting Data Exploration agent"},r),e),H=async(e,r)=>{let t=e.tool_calls??[];if(t.length===0){await h({text:`LLM did not request any tool calls: ${String(e?.content)}`},r);return}await Promise.all(t.map(async a=>await h({text:`LLM invoked ${a.name} tool with arguments: ${JSON.stringify(a.args,null,2)}`},r)))},zr=["mapView"];function V(e){let r=e?.configurable?.context;if(!r||typeof r!="object")throw new Error("DataExplorationAgent context missing");let t=zr.filter(a=>!(a in r));if(t.length)throw new Error(`DataExplorationAgent context missing: ${t.join(", ")}`);return r}var jr=e=>{let r=e.map?.allLayers.filter(a=>a.type==="feature"),t=0;return r?.forEach(a=>{let o=a;o.featureEffect&&(o.featureEffect=null,t++)}),t>0?`Cleared filters from ${t} layer(s). View unchanged.`:"No active filters to clear. View unchanged."},Vr=async(e,r)=>{let{mapView:t}=V(r);return jr(t)},Or=w(Vr,{name:"clearFilters",description:"Clears all feature effects/filters from the map but does NOT change the current view. Use when user says 'clear filters', 'reset filters', 'remove filters', 'show all features', or wants to remove emphasis without navigating anywhere.",schema:s.object({})}),Dr=async e=>{e.map?.allLayers.filter(t=>t.type==="feature")?.forEach(t=>{let a=t;a.featureEffect&&(a.featureEffect=null)});let r=e.map.initialViewProperties?.viewpoint?.targetGeometry;return r?(await e.goTo(r),"Cleared all filters and returned to home extent."):"Cleared all filters. Could not determine home extent."},Pr=async(e,r)=>{let{mapView:t}=V(r);return await Dr(t)},Gr=w(Pr,{name:"resetMap",description:"Clears all feature effects/filters from the map AND zooms to the home extent (initial map view). Use when user says 'reset map', 'reset the map', 'start over', or wants to both clear filters and return to the initial view.",schema:s.object({})});function re(e){return"point"in e&&e.point!==void 0}function W(e){return"layerId"in e&&e.layerId!==void 0}var ne=async(e,r)=>{if(re(e)){let{point:t}=e;return{geometry:new we({x:t.x,y:t.y,spatialReference:t.spatialReference?{wkid:t.spatialReference.wkid}:r.spatialReference})}}if(W(e)){let t=r.map?.allLayers.find(a=>a.id===e.layerId);if(!t)return{error:`Could not find geometry layer with ID: ${e.layerId}`};try{let a=await t.queryFeatures({where:e.where,returnGeometry:!0,outSpatialReference:r.spatialReference});if(!a.features.length)return{error:`No features found in geometry layer with the specified where clause: ${e.where}`};let o;if(a.features.length===1){let i=a.features[0].geometry;if(!i)return{error:"The geometry of the first feature is undefined or null."};o=i}else{let i=a.features.map(l=>l.geometry),n=ie.executeMany(i);if(!n)return{error:"Failed to create a combined geometry."};o=n}return o.spatialReference||(o.spatialReference=r.spatialReference),{geometry:o}}catch(a){return{error:`Failed to query geometry: ${String(a)}`}}}return{error:"Invalid geometry configuration provided"}},Br=async(e,r,t,a,o,i)=>{let n=e.map?.allLayers.find(d=>d.id===r);if(!n)return{success:!1,error:`Layer '${r}' not found.`};let l=n.createQuery();l.where=t??"1=1",a&&(l.geometry=a,l.spatialRelationship="intersects",o&&(l.distance=o),i&&(l.units=i));try{let{extent:d,count:c}=await n.queryExtent(l);return!d||c===0?{success:!1,error:`No features found for filter (where: ${l.where}${a?", spatial filter used":""})`}:(await e.goTo(d),{success:!0})}catch(d){return{success:!1,error:d instanceof Error?d.message:String(d)}}},Qr=async(e,r,t,a,o,i)=>{let n=r.map?.allLayers.find(u=>u.id===e.layerId);if(!n)return`Could not find target layer with ID: ${e.layerId}`;let l;if(o){let u=await ne(o,r);if("error"in u)return u.error;l=u.geometry}if(n.featureEffect=null,n.featureEffect=new Ue({filter:new K({where:e.where,geometry:l,spatialRelationship:"intersects",distance:o?.distance,units:o?.units}),includedEffect:t,excludedEffect:a}),n.visible=!0,i)return`Applied feature effects to "${n.title??e.layerId}" within current map extent.`;let d=await Br(r,e.layerId,e.where,l,o?.distance,o?.units),c=n.title??e.layerId;return d.success?`Applied feature effects to target layer "${n.title??e.layerId}"${o&&"layerId"in o?` using geometry from layer "${o.layerId}"`:""}.`:`Applied filter to "${c}" but no features matched. ${d.error}`},Wr=["feet","kilometers","meters","miles","nautical-miles","us-nautical-miles"],M=s.enum(Wr),Ur=async({targetLayer:e,geometryFilter:r,useCurrentExtent:t,includedEffect:a="drop-shadow(2px, 2px, 2px, gray)",excludedEffect:o="grayscale(100%) opacity(60%) blur(2px)"},i)=>{let{mapView:n}=V(i);return await Qr(e,n,a,o,r,t)},Kr=s.object({layerId:s.string().describe("The layerId of the layer containing the geometry by which to filter."),where:s.string().describe("The SQL-92 where clause representing the features from which to filter."),distance:s.number().optional().describe("The buffer distance around the geometry."),units:M.optional().describe("The units for the distance buffer.")}),Hr=s.object({point:s.object({x:s.number().describe("X coordinate (longitude) from navigation result"),y:s.number().describe("Y coordinate (latitude) from navigation result"),spatialReference:s.object({wkid:s.number().describe("Spatial reference WKID (e.g., 4326 for WGS84)")}).optional().describe("Spatial reference. Defaults to map's spatial reference if not provided.")}).describe("Point coordinates from a previous navigation/geocoding result"),distance:s.number().optional().describe("Optional buffer distance around the point."),units:M.optional().describe("The units for the distance buffer.")}),Jr=s.object({targetLayer:s.object({layerId:s.string().describe("The layerId of the layer on which to set a feature effect."),where:s.string().describe("The SQL-92 where clause representing the features to emphasize.")}),geometryFilter:s.union([Kr,Hr]).optional().describe("Optional geometry-based filtering parameters for spatial queries."),useCurrentExtent:s.boolean().optional().describe("Set to true when the previous query used the current map extent as a spatial filter. This ensures the feature effect applies only to features visible in the current view. Default is false."),includedEffect:s.string().default("drop-shadow(2px, 2px, 2px, gray)").describe("The effect applied to features that meet the filter requirements. Valid effects include: bloom, blur, brightness, contrast, drop-shadow, grayscale, hue-rotate, invert, opacity, saturate, and sepia. Prefer default unless specified."),excludedEffect:s.string().default("grayscale(100%) opacity(60%) blur(2px)").describe("The effect applied to features that do not meet the filter requirements. Valid effects include: bloom, blur, brightness, contrast, drop-shadow, grayscale, hue-rotate, invert, opacity, saturate, and sepia. Prefer default unless specified.")}),Zr=w(Ur,{name:"setFeatureEffect",description:"Sets a feature effect on a given layer with given filter parameters and feature effects to emphasize certain features that meet a filter requirement. If no feature effect information is provided, then use the default effect provided.",schema:Jr}),ae=(e,r,t)=>{if(e&&typeof e!="function"){let a="getField"in t&&t.getField?.(e),o=a&&"getFieldDomain"in t&&t.getFieldDomain?t.getFieldDomain(a.name):null;if(o?.type==="coded-value"){let i=o.codedValues.find(n=>n.code===r);return i?i.name:null}}return null},Yr=(e,r,t)=>{let a=e.createQuery();return a.outFields=[r],a.where=t||"1=1",a.num=1,a},Xr=async(e,r,t,a)=>{let o=a.map?.allLayers.find(c=>c.id===e),i=Yr(o,r,t.where),n=(await o.queryFeatures(i)).features[0],l=n?n.attributes[r]:null,d=ae(r,l,o)||l;return{tool:"getAttribute",layerName:o.title??e,summary:`${r} = ${d}`,details:{fieldName:r,value:d,where:t.where}}};async function ea({layerId:e,fieldName:r,query:t},a){let{mapView:o}=V(a),i=await Xr(e,r,t,o);return JSON.stringify(i,null,2)}var ta=s.object({layerId:s.string().describe("The layerId of the layer containing the field from which to get a value."),fieldName:s.string().describe("The name of the field/attribute from which to get a field value."),query:s.object({where:s.string().describe("The SQL-92 where clause representing the feature from which to get an attribute value.")})}),ra=w(ea,{name:"getAttribute",description:"Returns an attribute value for a given feature.",schema:ta}),xe=(e,r,t)=>t?e.hasAllFeaturesInView&&e.availableFields===r:e.hasAllFeatures&&e.availableFields===r;function oe(e,r){let t=e??"";return r!=null&&r&&(t=t?`(${t}) AND (${r})`:r),t||null}var aa=async e=>{let{targetLayer:r,fieldName:t,statisticType:a,mapView:o,layersAndFieldsRegistry:i,geometryFilter:n}=e,l=o.map?.allLayers.find(S=>S.id===r.layerId);if(!l)throw new Error(`Layer '${r.layerId}' not found.`);let d=await o.whenLayerView(l),c=i.get(r.layerId)?.fieldRegistry.get(t),u=c?.alias;if(!c)throw new Error(`Field '${t}' not found.`);let m,f;if(n){let S=await ne(n,o);if("error"in S)throw new Error(S.error);if(!S.geometry)throw W(n)?new Error(`No features found matching: ${n.where}`):new Error("Failed to create geometry");W(n)?m={geometryLayerId:n.layerId,geometryWhere:n.where,distance:n.distance,units:n.units,applied:!0}:re(n)&&(m={point:n.point,distance:n.distance,units:n.units,applied:!0}),f=new K({geometry:S.geometry,distance:n.distance,units:n.units,spatialRelationship:"intersects"})}let p=xe(d,[t],!1),T=null,g=null,v=10;if(c.type!=="geometry"&&c.type!=="oid"&&c.type!=="global-id")try{let S={layer:l,useFeaturesInView:p,view:p?o:void 0,field:t,sqlWhere:oe(l.definitionExpression,r.where),...f&&{filter:f},outStatisticTypes:{include:[a]}};T=await be(S);let E=["string","small-integer","integer"],F=c.domain?.type==="coded-value"?c.domain:null;(E.includes(c.type)||F)&&(g=(await ve({layer:l,useFeaturesInView:p,view:p?o:void 0,field:t,sqlWhere:oe(l.definitionExpression,r.where),...f&&{filter:f}})).uniqueValueInfos.sort((j,ce)=>ce.count-j.count).slice(0,v)),g&&c.domain?.type==="coded-value"&&(g=g.map(j=>({...j,value:F?F.getName(j.value)??j.value:j.value})))}catch(S){console.error("Statistics error:",S)}return{tool:"getStatistics",layerName:l.title??r.layerId,summary:`${a} = ${typeof T?.[a]=="number"?T[a]:"N/A"}`,details:{fieldName:t,fieldAlias:u,statisticType:a,statistic:T?.[a]??null,summaryStatistics:T,uniqueValues:g,where:r.where,spatialFilterInfo:m}}};async function oa({targetLayer:e,fieldName:r,statisticType:t,geometryFilter:a},o){let i=b(o,"layersAndFieldsRegistry"),{mapView:n}=V(o),l=await aa({targetLayer:e,fieldName:r,statisticType:t,mapView:n,layersAndFieldsRegistry:i,geometryFilter:a});return JSON.stringify(l,null,2)}var ia=s.object({layerId:s.string().describe("The layerId of the layer containing the geometry by which to filter."),where:s.string().describe("The SQL-92 where clause representing the features from which to filter."),distance:s.number().optional().describe("The buffer distance around the geometry."),units:M.optional().describe("The units for the distance buffer.")}),na=s.object({point:s.object({x:s.number().describe("X coordinate (longitude) from navigation result"),y:s.number().describe("Y coordinate (latitude) from navigation result"),spatialReference:s.object({wkid:s.number().describe("Spatial reference WKID (e.g., 4326 for WGS84)")}).optional().describe("Spatial reference. Defaults to map's spatial reference if not provided.")}).describe("Point coordinates from a previous navigation/geocoding result"),distance:s.number().optional().describe("Optional buffer distance around the point."),units:M.optional().describe("The units for the distance buffer.")}),sa=s.object({targetLayer:s.object({layerId:s.string().describe("The layerId of the layer containing the field from which to get a value."),where:s.string().describe("The SQL-92 where clause representing the feature from which to get an attribute value.")}),geometryFilter:s.union([ia,na]).optional().describe("Geometry filter for spatial queries. Use 'point' option with x/y coordinates from navigation results to find features at that location (point-in-polygon). Use 'layerId/where' option to filter by features from another layer."),fieldName:s.string().describe("The name of the field for which to get statistics. STRICTLY DO NOT use OBJECTID. Use any other field"),statisticType:s.enum(["avg","max","median","min","stddev","sum","variance","nullcount","count"]).describe("The statistic type to calculate.")}),la=w(oa,{name:"getStatistics",description:`Computes a single aggregate statistic (max, min, avg, sum, median, stddev, variance) for a numeric field across matching features. Also returns frequency analysis for categorical fields.
|
|
48
48
|
|
|
49
49
|
USE THIS TOOL FOR:
|
|
50
50
|
- "What is the average/maximum/minimum/total [field]?" \u2014 aggregate computations
|
|
@@ -56,7 +56,7 @@ DO NOT USE FOR:
|
|
|
56
56
|
- "Show / list / find features" \u2014 use queryFeatures instead
|
|
57
57
|
- Simple counts of features matching a condition \u2014 use queryFeatures instead
|
|
58
58
|
|
|
59
|
-
Only call this tool when the answer requires computing an aggregate (avg, max, min, sum, median, stddev) over a field's values, not just counting or listing features.`,schema:sa}),ca=async(e,r,t,a,o)=>{let i=t.map?.allLayers.find(
|
|
59
|
+
Only call this tool when the answer requires computing an aggregate (avg, max, min, sum, median, stddev) over a field's values, not just counting or listing features.`,schema:sa}),ca=async(e,r,t,a,o)=>{let i=t.map?.allLayers.find(f=>f.id===e.layerId),n=await t.whenLayerView(i),l=i.title??e.layerId,d;if(a){let f=await ne(a,t);if("error"in f)return{tool:"getTopFeatures",layerName:l,summary:"Geometry lookup failed",details:{error:f.error}};if(!f.geometry)return{tool:"getTopFeatures",layerName:l,summary:"No features found for geometry filter",details:{error:`No features found matching: ${"where"in a?a.where:"unknown criteria"}`}};d=f.geometry}else o&&(d=t.extent.clone());let c=r.groupByFields&&r.groupByFields.length>0,u=i.objectIdField,m=e.outFields.length>2?e.outFields:["*"];!m.includes("*")&&!m.includes(u)&&m.push(u);try{let f;if(c){let g=new Ke({where:e.where||"1=1",outFields:m,orderByFields:e.orderByFields,geometry:d,spatialRelationship:d?"intersects":void 0,distance:a?.distance,units:a?.units,topFilter:new He({topCount:r.topCount,groupByFields:r.groupByFields,orderByFields:r.orderByFields})});f=await i.queryTopFeatures(g)}else{let g=i.createQuery();g.where=oe(i.definitionExpression,e.where||"1=1"),g.outFields=m,g.orderByFields=r.orderByFields,g.num=r.topCount,d&&(g.geometry=d,g.spatialRelationship="intersects"),a?.distance&&(g.distance=a.distance),a?.units&&(g.units=a.units),g.outSpatialReference=t.spatialReference;let v=xe(n,e.outFields,o??!1);try{f=v?await n.queryFeatures(g):await i.queryFeatures(g)}catch(S){console.warn("Client-side query failed, falling back to server:",S),f=await i.queryFeatures(g)}}let p=f.features.map(g=>g.attributes[u]),T=f.features.map(g=>{let v=g.attributes,S={};return i.fields.forEach(E=>{if(E.name===i.objectIdField){S[E.name]=v[E.name];return}let F=v[E.name],j=ae(E.name,F,i),ce=E.alias||E.name;S[ce]=j??F}),S});return{tool:"getTopFeatures",layerName:l,summary:`Top ${r.topCount} features extracted`,details:{topCount:r.topCount,attributes:T,objectIds:p,objectIdField:u,where:e.where,orderByFields:r.orderByFields,...c&&{groupByFields:r.groupByFields}}}}catch(f){return{tool:"getTopFeatures",layerName:l,summary:"Query failed",details:{error:f instanceof Error?f.message:String(f)}}}},da=async({targetLayer:e,topFilter:r,geometryFilter:t,useCurrentExtent:a},o)=>{let{mapView:i}=V(o),n=await ca(e,r,i,t,a);return JSON.stringify(n,null,2)},ua=s.object({layerId:s.string().describe("The layerId of the layer containing the geometry by which to filter."),where:s.string().describe("The SQL-92 where clause representing the features from which to filter."),distance:s.number().optional().describe("The buffer distance around the geometry."),units:M.optional().describe("The units for the distance buffer.")}),ha=s.object({point:s.object({x:s.number().describe("X coordinate (longitude) from navigation result"),y:s.number().describe("Y coordinate (latitude) from navigation result"),spatialReference:s.object({wkid:s.number().describe("Spatial reference WKID (e.g., 4326 for WGS84)")}).optional().describe("Spatial reference. Defaults to map's spatial reference if not provided.")}).describe("Point coordinates from a previous navigation/geocoding result"),distance:s.number().optional().describe("Optional buffer distance around the point."),units:M.optional().describe("The units for the distance buffer.")}),ma=s.object({targetLayer:s.object({layerId:s.string().describe("The layerId of the layer containing the field from which to get a value."),where:s.string().describe("The SQL-92 where clause representing the feature from which to get an attribute value."),orderByFields:s.array(s.string().describe("The field(s) and order for which to sort the resulting features.")),outFields:s.array(s.string().describe('The fields to include in the output that will be presented to the user. This should include identifying information about the resulting features, like a name or id, along with the values desired in the output. If unsure, choose all fields ("*").').default("*"))}),geometryFilter:s.union([ua,ha]).optional().describe("Geometry filter for spatial queries. Use 'point' option with x/y coordinates from navigation results to find features at that location (point-in-polygon). Use 'layerId/where' option to filter by features from another layer."),topFilter:s.object({topCount:s.number().describe("Number of top features to return per group."),orderByFields:s.array(s.string().describe("Field(s) to rank by with ASC/DESC. Must be existing field names, not aggregate functions.")),groupByFields:s.array(s.string().describe("Field(s) to group results by. Returns top N per group."))}),useCurrentExtent:s.boolean().optional().describe("Set to true ONLY when user explicitly asks about features 'in my view', 'on my map', 'I am looking at'. Default is false (queries entire layer).")}),fa=w(da,{name:"getTopFeatures",description:'Returns top N features ranked by an existing field value. Use for "highest", "lowest", "top N" questions where ranking is based on a field that already exists in the data (e.g., population, value, date, depth). orderByFields must be actual field names with ASC/DESC. Do NOT use aggregate functions like COUNT(), SUM(), AVG() - those require getStatistics.',schema:ma}),fe=25,pa=async(e,r,t,a)=>{let o=r.map?.allLayers.find(g=>g.id===e.layerId),i=await r.whenLayerView(o),n=o.title??e.layerId,l;if(t){let g=await ne(t,r);if("error"in g){let v={error:g.error};return W(t)?(v.geometryLayerId=t.layerId,v.geometryWhere=t.where):re(t)&&(v.point=t.point),{tool:"queryFeatures",layerName:n,summary:"Geometry lookup failed",details:v}}if(!g.geometry){let v={};return W(t)?(v.error=`No features found matching: ${t.where}`,v.geometryLayerId=t.layerId,v.geometryWhere=t.where):re(t)&&(v.error="Failed to create point geometry",v.point=t.point),{tool:"queryFeatures",layerName:n,summary:"No features found for geometry filter",details:v}}l=g.geometry}else a&&(l=r.extent.clone());let d=xe(i,e.outFields,a??!1),c=o.createQuery();c.where=oe(o.definitionExpression,e.where||"1=1"),c.outFields=e.outFields.length?e.outFields:["*"],c.orderByFields=e.orderByFields,l&&(c.geometry=l,c.spatialRelationship="intersects"),t?.distance&&(c.distance=t.distance),t?.units&&(c.units=t.units),c.outSpatialReference=r.spatialReference;let u,m;try{u=d?await i.queryFeatureCount(c):await o.queryFeatureCount(c),u>0&&u<=fe&&(m=d?await i.queryFeatures(c):await o.queryFeatures(c),m&&m.features.forEach(g=>{let v=g.attributes;o.fields.forEach(S=>{let E=v[S.name],F=ae(S.name,E,o);F&&(v[S.name]=F)})}))}catch(g){console.warn("Client-side query failed, falling back to server:",g),u=await o.queryFeatureCount(c),u>0&&u<=fe&&(m=await o.queryFeatures(c),m&&m.features.forEach(v=>{o.fields.forEach(S=>{let E=v.attributes[S.name],F=ae(S.name,E,o);F&&(v.attributes[S.name]=F)})}))}let f=o.objectIdField,p=m?.features.map(g=>g.attributes[f]),T=m?.features.map(g=>g.attributes);return{tool:"queryFeatures",layerName:n,summary:`${u} features found`,details:{totalCount:u,where:e.where,orderByFields:e.orderByFields,outFields:e.outFields,...p&&{objectIds:p,objectIdField:f},...T&&{attributes:T},...u>fe&&{note:`${u} features found.`}}}};async function ga({targetLayer:e,geometryFilter:r,useCurrentExtent:t},a){let{mapView:o}=V(a),i=await pa(e,o,r,t);return JSON.stringify(i,null,2)}var ya=s.object({layerId:s.string().describe("The layerId of the layer containing the geometry by which to filter."),where:s.string().describe("The SQL-92 where clause representing the features from which to filter."),distance:s.number().optional().describe("The buffer distance around the geometry."),units:M.optional().describe("The units for the distance buffer.")}),wa=s.object({point:s.object({x:s.number().describe("X coordinate (longitude) from navigation result"),y:s.number().describe("Y coordinate (latitude) from navigation result"),spatialReference:s.object({wkid:s.number().describe("Spatial reference WKID (e.g., 4326 for WGS84)")}).optional().describe("Spatial reference. Defaults to map's spatial reference if not provided.")}).describe("Point coordinates from a previous navigation/geocoding result"),distance:s.number().optional().describe("Optional buffer distance around the point."),units:M.optional().describe("The units for the distance buffer.")}),ba=s.object({targetLayer:s.object({layerId:s.string().describe("The layerId of the layer containing the field from which to get a value."),where:s.string().describe("SQL-92 where clause. IMPORTANT: When using geometryFilter.point for point-in-polygon queries, set this to '1=1' to return all features that intersect the point. Only add attribute filters if the user specifically requests them in addition to the spatial query."),orderByFields:s.array(s.string().describe("The field(s) and order for which to sort the resulting features.")),outFields:s.array(s.string().describe('The fields to include in the output that will be presented to the user. This should include identifying information about the resulting features, like a name or id, along with the values desired in the output. If unsure, choose all fields ("*").').default("*"))}),geometryFilter:s.union([ya,wa]).optional().describe("Geometry filter for spatial queries. Use 'point' option with x/y coordinates from navigation results to find features at that location (point-in-polygon). Use 'layerId/where' option to filter by features from another layer."),useCurrentExtent:s.boolean().optional().describe("Set to true ONLY when user explicitly asks about features 'in my view', 'on my map', 'I am looking at'. Default is false (queries entire layer).")}),va=w(ga,{name:"queryFeatures",description:`Queries features from a layer. Returns the total count of matching features, plus individual feature attributes if \u226425 features match.
|
|
60
60
|
|
|
61
61
|
USE THIS TOOL FOR:
|
|
62
62
|
- "Show / display / list features where..." \u2014 finding and listing features
|
|
@@ -65,13 +65,13 @@ USE THIS TOOL FOR:
|
|
|
65
65
|
- Spatial queries \u2014 finding features near/within/intersecting other features
|
|
66
66
|
- Any question where the user wants to SEE or COUNT matching features
|
|
67
67
|
|
|
68
|
-
This is the DEFAULT tool for most queries. When in doubt, use this tool.`,schema:ba}),et=[ra,la,fa,va],tt=[Zr,Gr,Or],se=()=>{let e=new Date().getTimezoneOffset(),r=e<=0?"+":"-",t=Math.floor(Math.abs(e)/60).toString().padStart(2,"0"),a=(Math.abs(e)%60).toString().padStart(2,"0"),o=`${r}${t}:${a}`;return{userTimezone:Intl.DateTimeFormat().resolvedOptions().timeZone,userTimezoneOffset:o}},Sa=async(e,r)=>{await h({text:"Requesting LLM for layer filter results"},r);let t=await _("data_explore_filter_prompt");if(!r?.configurable)throw new Error("config.configurable is required for layer filter tools");let{userTimezone:a,userTimezoneOffset:o}=se(),i={layerFieldInfo:e.layerFieldInfo,userTimezone:a,userTimezoneOffset:o,queryResponse:e.queryResponse},n=await D({promptText:t,modelTier:"advanced",messages:x(e.messages),inputVariables:i,tools:tt}),l=[...e.messages,n];if(!((n.tool_calls?.length??0)>0))return await h({text:"LLM determined no filter changes needed"},r),{...e,messages:l};let d=[...l,n],c=n.content.toString();return await H(n,r),{...e,messages:d,outputMessage:c}},Ta=async(e,r)=>{await h({text:"Requesting LLM for layer query results"},r);let t=await _("data_explore_query_prompt");if(!r?.configurable)throw new Error("config.configurable is required for layer query tools");let{userTimezone:a,userTimezoneOffset:o}=se(),i={layerFieldInfo:e.layerFieldInfo,userTimezone:a,userTimezoneOffset:o},n=await D({promptText:t,modelTier:"advanced",messages:x(e.messages),inputVariables:i,tools:et}),l=[...e.messages,n],d=n.content.toString();return await H(n,r),{...e,messages:l,outputMessage:d}},xa=async(e,r)=>{try{await h({text:"Requesting LLM for summary on query results"},r);let t=await _("summarize_query_response_prompt"),a={queryResponse:e.queryResponse},o=await X({promptText:t,messages:x(e.messages),inputVariables:a}),i=typeof o=="string"?o:o.content,n=new O(i);return await h({text:`Received response from LLM: ${i}`},r),{...e,outputMessage:i,messages:[...e.messages,n]}}catch(t){throw await h({text:"Error during filter LLM request"},r),new Error(`Error during filter LLM request: ${t instanceof Error?t.message:String(t)}`)}};async function Ea(e,r){let t=await new z(tt).invoke({messages:x(e.messages)},r),a=[...e.messages,...t.messages],o=t.messages.map(n=>new O({content:n.content,additional_kwargs:n.additional_kwargs}));await h({text:`Finished executing layer filter tool: ${t.messages.map(n=>n.content).join(", ")}`},r);let i=[...a,...o];return{...e,messages:i}}var Ia=new z(et);async function Fa(e,r){let{messages:t}=await Ia.invoke({messages:x(e.messages)},r),a=[],o=[];for(let n of t){let l=n.content,d;typeof l!="string"&&(d={tool:n.name??"unknown",layerName:"unknown",summary:"Query failed",details:{error:"Skipping non-string tool output:",raw:l}});try{typeof l=="string"?d=JSON.parse(l):d={tool:n.name??"unknown",layerName:"unknown",summary:"Query failed",details:{error:"Invalid tool output type",raw:l}}}catch{d={tool:n.name??"unknown",layerName:"unknown",summary:"Query failed",details:{error:l}}}a.push(d),d.details&&typeof d.details=="object"&&"error"in d.details?o.push(`- ${d.tool}: Error - ${String(d.details.error)}`):o.push(`- ${d.layerName}: ${d.summary}`)}let i=[...e.messages,...t];return await h({text:`Finished executing layer query tool: ${o.join(", ")}`},r),{...e,messages:i,queryResponse:a}}var $a=10,La=["string","small-integer","integer"],_a=async(e,r)=>{let t=null,a=null;try{if(r.type!=="geometry"&&r.type!=="oid"&&r.type!=="global-id"){t=await be({layer:e,field:r.name});let o=r.domain?.type==="coded-value"?r.domain:null;(La.includes(r.type)||o)&&(a=(await ve({layer:e,field:r.name})).uniqueValueInfos.sort((i,n)=>n.count-i.count).slice(0,$a),o&&(a=a.map(i=>({...i,value:o.getName(i.value)??i.value}))))}}catch(o){console.error(`Error fetching statistics for field ${r.name}:`,o)}return{summaryStatistics:t,uniqueValues:a}};async function Ee(e,r,t){let a=[],o=[];for(let i of e){let n=function(
|
|
68
|
+
This is the DEFAULT tool for most queries. When in doubt, use this tool.`,schema:ba}),et=[ra,la,fa,va],tt=[Zr,Gr,Or],se=()=>{let e=new Date().getTimezoneOffset(),r=e<=0?"+":"-",t=Math.floor(Math.abs(e)/60).toString().padStart(2,"0"),a=(Math.abs(e)%60).toString().padStart(2,"0"),o=`${r}${t}:${a}`;return{userTimezone:Intl.DateTimeFormat().resolvedOptions().timeZone,userTimezoneOffset:o}},Sa=async(e,r)=>{await h({text:"Requesting LLM for layer filter results"},r);let t=await _("data_explore_filter_prompt");if(!r?.configurable)throw new Error("config.configurable is required for layer filter tools");let{userTimezone:a,userTimezoneOffset:o}=se(),i={layerFieldInfo:e.layerFieldInfo,userTimezone:a,userTimezoneOffset:o,queryResponse:e.queryResponse},n=await D({promptText:t,modelTier:"advanced",messages:x(e.messages),inputVariables:i,tools:tt}),l=[...e.messages,n];if(!((n.tool_calls?.length??0)>0))return await h({text:"LLM determined no filter changes needed"},r),{...e,messages:l};let d=[...l,n],c=n.content.toString();return await H(n,r),{...e,messages:d,outputMessage:c}},Ta=async(e,r)=>{await h({text:"Requesting LLM for layer query results"},r);let t=await _("data_explore_query_prompt");if(!r?.configurable)throw new Error("config.configurable is required for layer query tools");let{userTimezone:a,userTimezoneOffset:o}=se(),i={layerFieldInfo:e.layerFieldInfo,userTimezone:a,userTimezoneOffset:o},n=await D({promptText:t,modelTier:"advanced",messages:x(e.messages),inputVariables:i,tools:et}),l=[...e.messages,n],d=n.content.toString();return await H(n,r),{...e,messages:l,outputMessage:d}},xa=async(e,r)=>{try{await h({text:"Requesting LLM for summary on query results"},r);let t=await _("summarize_query_response_prompt"),a={queryResponse:e.queryResponse},o=await X({promptText:t,messages:x(e.messages),inputVariables:a}),i=typeof o=="string"?o:o.content,n=new O(i);return await h({text:`Received response from LLM: ${i}`},r),{...e,outputMessage:i,messages:[...e.messages,n]}}catch(t){throw await h({text:"Error during filter LLM request"},r),new Error(`Error during filter LLM request: ${t instanceof Error?t.message:String(t)}`)}};async function Ea(e,r){let t=await new z(tt).invoke({messages:x(e.messages)},r),a=[...e.messages,...t.messages],o=t.messages.map(n=>new O({content:n.content,additional_kwargs:n.additional_kwargs}));await h({text:`Finished executing layer filter tool: ${t.messages.map(n=>n.content).join(", ")}`},r);let i=[...a,...o];return{...e,messages:i}}var Ia=new z(et);async function Fa(e,r){let{messages:t}=await Ia.invoke({messages:x(e.messages)},r),a=[],o=[];for(let n of t){let l=n.content,d;typeof l!="string"&&(d={tool:n.name??"unknown",layerName:"unknown",summary:"Query failed",details:{error:"Skipping non-string tool output:",raw:l}});try{typeof l=="string"?d=JSON.parse(l):d={tool:n.name??"unknown",layerName:"unknown",summary:"Query failed",details:{error:"Invalid tool output type",raw:l}}}catch{d={tool:n.name??"unknown",layerName:"unknown",summary:"Query failed",details:{error:l}}}a.push(d),d.details&&typeof d.details=="object"&&"error"in d.details?o.push(`- ${d.tool}: Error - ${String(d.details.error)}`):o.push(`- ${d.layerName}: ${d.summary}`)}let i=[...e.messages,...t];return await h({text:`Finished executing layer query tool: ${o.join(", ")}`},r),{...e,messages:i,queryResponse:a}}var $a=10,La=["string","small-integer","integer"],_a=async(e,r)=>{let t=null,a=null;try{if(r.type!=="geometry"&&r.type!=="oid"&&r.type!=="global-id"){t=await be({layer:e,field:r.name});let o=r.domain?.type==="coded-value"?r.domain:null;(La.includes(r.type)||o)&&(a=(await ve({layer:e,field:r.name})).uniqueValueInfos.sort((i,n)=>n.count-i.count).slice(0,$a),o&&(a=a.map(i=>({...i,value:o.getName(i.value)??i.value}))))}}catch(o){console.error(`Error fetching statistics for field ${r.name}:`,o)}return{summaryStatistics:t,uniqueValues:a}};async function Ee(e,r,t){let a=[],o=[];for(let i of e){let n=function(f){let p=r.get(f)?.layerItem;return p?[p.name&&`Name: ${p.name}`,p.title&&`Title: ${p.title}`,p.description&&`Description: ${p.description}`].filter(Boolean).join(" | "):f},{layerId:l,results:d}=i,c=t.map?.allLayers.find(f=>f.id===l),u=r.get(l)?.fieldRegistry;if(!u)continue;let m=a.find(f=>f.layerId===l);m||(m={layerId:l,layerSummary:n(l),fieldInfos:[]},a.push(m));for(let f of d){let p=u.get(f.name);if(p){if(!p.statistics){let T=_a(c,p).then(g=>{u.set(p.name,{...p,statistics:g}),p.statistics=g});o.push(T)}m.fieldInfos.push(p)}}}return await Promise.all(o),a}var ka=async(e,r)=>{try{await h({text:"Getting statistics for vector search results"},r);let t=b(r,"layersAndFieldsRegistry"),{mapView:a}=V(r),o=await Ee(e.vectorSearchFieldResults,t,a);return await h({text:"Statistics retrieved"},r),{...e,layerFieldInfo:o}}catch(t){throw await h({text:"Error during fetching statistics"},r),new Error(`Error during fetching statistics: ${t instanceof Error?t.message:String(t)}`)}},De=.7,Na=10,Aa=async(e,r)=>{try{let t=R(e.messages);await h({text:"Similarity search to find fields"},r);let a=b(r,"fieldSearch"),o=b(r,"layersAndFieldsRegistry"),i=b(r,"embeddingCache"),n=await a.searchFields({text:t,layerIds:e.vectorSearchLayerIds,minScore:De,topResults:Na,embeddingCache:i}),l=n.map(({layerId:c,results:u})=>{let m=u.map(f=>` - ${f.name} (${f.score.toFixed(2)})`).join(`
|
|
69
69
|
`);return`${o.get(c)?.layerItem.name??c}:
|
|
70
|
-
${
|
|
70
|
+
${m}`}).join(`
|
|
71
71
|
`),d;return n.length>0?d=`Vector search completed. Matching layers and fields with scores:
|
|
72
|
-
${l}`:d=`No vector search results found for score over ${De}.`,await h({text:d},r),{...e,vectorSearchFieldResults:n}}catch(t){throw await h({text:`Error during vector search: ${t instanceof Error?t.message:String(t)}`},r),new Error(`Vector search failed: ${t instanceof Error?t.message:String(t)}`)}},qa=.7,Ra=async(e,r)=>{try{let t=R(e.messages);await h({text:`Similarity search to find layers: ${t}`},r);let a=b(r,"layerSearch"),o=b(r,"layersAndFieldsRegistry"),i=b(r,"embeddingCache"),n=await a.searchLayers({text:t,minScore:qa,embeddingCache:i}),l=n.map(u=>u.id),d=n.map(({id:u,score:
|
|
72
|
+
${l}`:d=`No vector search results found for score over ${De}.`,await h({text:d},r),{...e,vectorSearchFieldResults:n}}catch(t){throw await h({text:`Error during vector search: ${t instanceof Error?t.message:String(t)}`},r),new Error(`Vector search failed: ${t instanceof Error?t.message:String(t)}`)}},qa=.7,Ra=async(e,r)=>{try{let t=R(e.messages);await h({text:`Similarity search to find layers: ${t}`},r);let a=b(r,"layerSearch"),o=b(r,"layersAndFieldsRegistry"),i=b(r,"embeddingCache"),n=await a.searchLayers({text:t,minScore:qa,embeddingCache:i}),l=n.map(u=>u.id),d=n.map(({id:u,score:m})=>`${o.get(u)?.layerItem.name??u} (${m.toFixed(2)})`).join(`
|
|
73
73
|
`),c;return l.length>0?c=`Vector search completed. Matching layers with scores:
|
|
74
|
-
${d}`:c="Vector search completed. No matching layers found.",await h({text:c},r),{...e,vectorSearchLayerIds:l}}catch(t){throw await h({text:`Error during vector search: ${t instanceof Error?t.message:String(t)}`},r),new Error(`Vector search failed: ${t instanceof Error?t.message:String(t)}`)}},Ma=(e,r)=>G(["layerSearch","fieldSearch","layersAndFieldsRegistry"],"Data Exploration Agent")(e,r),Ca=()=>new q(Xe).addNode("requireDataExplorationServices",Ma).addNode("vectorSearchLayers",Ra).addNode("vectorSearchFields",Aa).addNode("fieldStatistics",ka).addNode("queryAgent",Ta).addNode("queryTools",Fa).addNode("summarizeQueryResponseLLM",xa).addNode("filterAgent",Sa).addNode("filterTools",Ea).addNode("earlyExit",Cr).addEdge(N,"requireDataExplorationServices").addEdge("requireDataExplorationServices","vectorSearchLayers").addConditionalEdges("vectorSearchLayers",e=>e.vectorSearchLayerIds.length?"vectorSearchFields":"earlyExit").addConditionalEdges("vectorSearchFields",e=>e.vectorSearchFieldResults.length?"fieldStatistics":"earlyExit").addEdge("fieldStatistics","queryAgent").addConditionalEdges("queryAgent",e=>(e.messages[e.messages.length-1]?.tool_calls?.length??0)>0?"queryTools":"filterAgent").addConditionalEdges("queryTools",e=>e.queryResponse.length?"summarizeQueryResponseLLM":"filterAgent").addEdge("summarizeQueryResponseLLM","filterAgent").addConditionalEdges("filterAgent",e=>(e.messages[e.messages.length-1]?.tool_calls?.length??0)>0?"filterTools":
|
|
74
|
+
${d}`:c="Vector search completed. No matching layers found.",await h({text:c},r),{...e,vectorSearchLayerIds:l}}catch(t){throw await h({text:`Error during vector search: ${t instanceof Error?t.message:String(t)}`},r),new Error(`Vector search failed: ${t instanceof Error?t.message:String(t)}`)}},Ma=(e,r)=>G(["layerSearch","fieldSearch","layersAndFieldsRegistry"],"Data Exploration Agent")(e,r),Ca=()=>new q(Xe).addNode("requireDataExplorationServices",Ma).addNode("vectorSearchLayers",Ra).addNode("vectorSearchFields",Aa).addNode("fieldStatistics",ka).addNode("queryAgent",Ta).addNode("queryTools",Fa).addNode("summarizeQueryResponseLLM",xa).addNode("filterAgent",Sa).addNode("filterTools",Ea).addNode("earlyExit",Cr).addEdge(N,"requireDataExplorationServices").addEdge("requireDataExplorationServices","vectorSearchLayers").addConditionalEdges("vectorSearchLayers",e=>e.vectorSearchLayerIds.length?"vectorSearchFields":"earlyExit").addConditionalEdges("vectorSearchFields",e=>e.vectorSearchFieldResults.length?"fieldStatistics":"earlyExit").addEdge("fieldStatistics","queryAgent").addConditionalEdges("queryAgent",e=>(e.messages[e.messages.length-1]?.tool_calls?.length??0)>0?"queryTools":"filterAgent").addConditionalEdges("queryTools",e=>e.queryResponse.length?"summarizeQueryResponseLLM":"filterAgent").addEdge("summarizeQueryResponseLLM","filterAgent").addConditionalEdges("filterAgent",e=>(e.messages[e.messages.length-1]?.tool_calls?.length??0)>0?"filterTools":I).addEdge("filterTools",I).addEdge("earlyExit",I),za=String.raw`- **data exploration** — User is asking about the feature layer’s data (e.g. counts, summaries, statistics, field values), either for all features, a subset based on a condition, or for a subset based on the current view. And/Or user wants to include or exclude features based on field values, or visually style features differently (e.g., highlight or deemphasize them).
|
|
75
75
|
The Data Exploration Agent will automatically zoom to the affected features for action taken by this agent. In this case, no need to call navigation tool separately.
|
|
76
76
|
_Example: “Only show stations where Brand is Shell”_
|
|
77
77
|
_Example: “Make Shell stations stand out on the map”_
|
|
@@ -79,9 +79,9 @@ ${d}`:c="Vector search completed. No matching layers found.",await h({text:c},r)
|
|
|
79
79
|
This also includes questions that ask which feature meets a given condition or where a particular feature in the data is located (e.g., “Where is the spring with the highest elevation?”). However, this agent does not handle addresses.
|
|
80
80
|
_Example: “How many features are there?”_
|
|
81
81
|
_Example: “What’s the average population?”_
|
|
82
|
-
_Example: “Which values are in the status field?”_`,Ll={id:"dataExploration",name:"Data Exploration Agent",description:za,createGraph:Ca,workspace:Xe},Pe=.7,ja=10,Va=async(e,r)=>{try{let t=R(e.messages);await h({text:"Similarity search to find fields"},r);let a=b(r,"fieldSearch"),o=b(r,"layersAndFieldsRegistry"),i=b(r,"embeddingCache"),n=await a.searchFields({text:t,layerIds:e.vectorSearchLayerIds,minScore:Pe,topResults:ja,embeddingCache:i}),l=n.map(({layerId:c,results:u})=>{let
|
|
82
|
+
_Example: “Which values are in the status field?”_`,Ll={id:"dataExploration",name:"Data Exploration Agent",description:za,createGraph:Ca,workspace:Xe},Pe=.7,ja=10,Va=async(e,r)=>{try{let t=R(e.messages);await h({text:"Similarity search to find fields"},r);let a=b(r,"fieldSearch"),o=b(r,"layersAndFieldsRegistry"),i=b(r,"embeddingCache"),n=await a.searchFields({text:t,layerIds:e.vectorSearchLayerIds,minScore:Pe,topResults:ja,embeddingCache:i}),l=n.map(({layerId:c,results:u})=>{let m=u.map(f=>` - ${f.name} (${f.score.toFixed(2)})`).join(`
|
|
83
83
|
`);return`${o.get(c)?.layerItem.name??c}:
|
|
84
|
-
${
|
|
84
|
+
${m}`}).join(`
|
|
85
85
|
`),d;return n.length>0?d=`Vector search completed. Matching layers and fields with scores:
|
|
86
86
|
${l}`:d=`No vector search results found for score over ${Pe}.`,await h({text:d},r),{...e,vectorSearchFieldResults:n}}catch(t){throw await h({text:`Error during vector search: ${t instanceof Error?t.message:String(t)}`},r),new Error(`Vector search failed: ${t instanceof Error?t.message:String(t)}`)}},Oa=.7,Da=async(e,r)=>{try{let t=R(e.messages);await h({text:`Similarity search to find layers: ${t}`},r);let a=b(r,"layerSearch"),o=b(r,"layersAndFieldsRegistry"),i=await a.searchLayers({text:t,minScore:Oa}),n=i.map(c=>c.id),l=i.map(({id:c,score:u})=>`${o.get(c)?.layerItem.name??c} (${u.toFixed(2)})`).join(`
|
|
87
87
|
`),d;return n.length>0?d=`Vector search completed. Matching layers with scores:
|
|
@@ -91,7 +91,7 @@ ${l}`:d="Vector search completed. No matching layers found.",await h({text:d},r)
|
|
|
91
91
|
|
|
92
92
|
`);return o[o.length-1]?.trim()===t?e:`${e}
|
|
93
93
|
|
|
94
|
-
${t}`},default:()=>""}),vectorSearchLayerIds:y(),vectorSearchFieldResults:y(),layerFieldInfo:y()}),eo=async(e,r)=>(await h({text:"Exiting Layer Filter agent"},r),e),to=(e,r)=>G(["layerSearch","fieldSearch","layersAndFieldsRegistry"],"Layer Filter Agent")(e,r),ro=()=>new q(st).addNode("requireLayerFilterServices",to).addNode("vectorSearchLayers",Da).addNode("vectorSearchFields",Va).addNode("fieldStatistics",Pa).addNode("agent",Ya).addNode("tools",Xa).addNode("earlyExit",eo).addEdge(N,"requireLayerFilterServices").addEdge("requireLayerFilterServices","vectorSearchLayers").addConditionalEdges("vectorSearchLayers",e=>e.vectorSearchLayerIds.length?"vectorSearchFields":"earlyExit").addConditionalEdges("vectorSearchFields",e=>e.vectorSearchFieldResults.length?"fieldStatistics":"earlyExit").addEdge("fieldStatistics","agent").addConditionalEdges("agent",e=>(e.messages[e.messages.length-1]?.tool_calls?.length??0)>0?"tools":"earlyExit").addEdge("tools","earlyExit").addEdge("earlyExit",
|
|
94
|
+
${t}`},default:()=>""}),vectorSearchLayerIds:y(),vectorSearchFieldResults:y(),layerFieldInfo:y()}),eo=async(e,r)=>(await h({text:"Exiting Layer Filter agent"},r),e),to=(e,r)=>G(["layerSearch","fieldSearch","layersAndFieldsRegistry"],"Layer Filter Agent")(e,r),ro=()=>new q(st).addNode("requireLayerFilterServices",to).addNode("vectorSearchLayers",Da).addNode("vectorSearchFields",Va).addNode("fieldStatistics",Pa).addNode("agent",Ya).addNode("tools",Xa).addNode("earlyExit",eo).addEdge(N,"requireLayerFilterServices").addEdge("requireLayerFilterServices","vectorSearchLayers").addConditionalEdges("vectorSearchLayers",e=>e.vectorSearchLayerIds.length?"vectorSearchFields":"earlyExit").addConditionalEdges("vectorSearchFields",e=>e.vectorSearchFieldResults.length?"fieldStatistics":"earlyExit").addEdge("fieldStatistics","agent").addConditionalEdges("agent",e=>(e.messages[e.messages.length-1]?.tool_calls?.length??0)>0?"tools":"earlyExit").addEdge("tools","earlyExit").addEdge("earlyExit",I),ao=String.raw`- **layer filter** — User wants to include or exclude features based on field values, or visually style features differently (e.g., highlight or deemphasize them).
|
|
95
95
|
The Layer Filter Agent will automatically zoom to the affected features for action taken by this agent. In this case, no need to call navigation tool separately.
|
|
96
96
|
_Example: “Only show stations where Brand is Shell”_
|
|
97
97
|
_Example: “Make Shell stations stand out on the map”_
|
|
@@ -99,23 +99,23 @@ ${t}`},default:()=>""}),vectorSearchLayerIds:y(),vectorSearchFieldResults:y(),la
|
|
|
99
99
|
|
|
100
100
|
`);return o[o.length-1]?.trim()===t?e:`${e}
|
|
101
101
|
|
|
102
|
-
${t}`},default:()=>""}),vectorSearchLayerIds:y(),vectorSearchFieldResults:y(),layerFieldInfo:y(),queryResponses:y()}),oo=async(e,r)=>(await h({text:"Exiting Layer Query agent"},r),e);function J(e){let r=e?.configurable?.context;if(!r||typeof r!="object")throw new Error("LayerQueryAgent context missing");let t=rt.filter(a=>!(a in r));if(t.length)throw new Error(`LayerQueryAgent context missing: ${t.join(", ")}`);return r}var io=async(e,r)=>{try{await h({text:"Getting statistics for vector search results"},r);let t=b(r,"layersAndFieldsRegistry"),{mapView:a}=J(r),o=await Ee(e.vectorSearchFieldResults,t,a);return await h({text:"Statistics retrieved"},r),{...e,layerFieldInfo:o}}catch(t){throw await h({text:"Error during fetching statistics"},r),new Error(`Error during fetching statistics: ${t instanceof Error?t.message:String(t)}`)}},Ge=.7,no=10,so=async(e,r)=>{try{let t=R(e.messages);await h({text:"Similarity search to find fields"},r);let a=b(r,"fieldSearch"),o=b(r,"layersAndFieldsRegistry"),i=b(r,"embeddingCache"),n=await a.searchFields({text:t,layerIds:e.vectorSearchLayerIds,minScore:Ge,topResults:no,embeddingCache:i}),l=n.map(({layerId:c,results:u})=>{let
|
|
102
|
+
${t}`},default:()=>""}),vectorSearchLayerIds:y(),vectorSearchFieldResults:y(),layerFieldInfo:y(),queryResponses:y()}),oo=async(e,r)=>(await h({text:"Exiting Layer Query agent"},r),e);function J(e){let r=e?.configurable?.context;if(!r||typeof r!="object")throw new Error("LayerQueryAgent context missing");let t=rt.filter(a=>!(a in r));if(t.length)throw new Error(`LayerQueryAgent context missing: ${t.join(", ")}`);return r}var io=async(e,r)=>{try{await h({text:"Getting statistics for vector search results"},r);let t=b(r,"layersAndFieldsRegistry"),{mapView:a}=J(r),o=await Ee(e.vectorSearchFieldResults,t,a);return await h({text:"Statistics retrieved"},r),{...e,layerFieldInfo:o}}catch(t){throw await h({text:"Error during fetching statistics"},r),new Error(`Error during fetching statistics: ${t instanceof Error?t.message:String(t)}`)}},Ge=.7,no=10,so=async(e,r)=>{try{let t=R(e.messages);await h({text:"Similarity search to find fields"},r);let a=b(r,"fieldSearch"),o=b(r,"layersAndFieldsRegistry"),i=b(r,"embeddingCache"),n=await a.searchFields({text:t,layerIds:e.vectorSearchLayerIds,minScore:Ge,topResults:no,embeddingCache:i}),l=n.map(({layerId:c,results:u})=>{let m=u.map(f=>` - ${f.name} (${f.score.toFixed(2)})`).join(`
|
|
103
103
|
`);return`${o.get(c)?.layerItem.name??c}:
|
|
104
|
-
${
|
|
104
|
+
${m}`}).join(`
|
|
105
105
|
`),d;return n.length>0?d=`Vector search completed. Matching layers and fields with scores:
|
|
106
106
|
${l}`:d=`No vector search results found for score over ${Ge}.`,await h({text:d},r),{...e,vectorSearchFieldResults:n}}catch(t){throw await h({text:`Error during vector search: ${t instanceof Error?t.message:String(t)}`},r),new Error(`Vector search failed: ${t instanceof Error?t.message:String(t)}`)}},lo=.7,co=async(e,r)=>{try{let t=R(e.messages);await h({text:`Similarity search to find layers: ${t}`},r);let a=b(r,"layerSearch"),o=b(r,"layersAndFieldsRegistry"),i=await a.searchLayers({text:t,minScore:lo}),n=i.map(c=>c.id),l=i.map(({id:c,score:u})=>`${o.get(c)?.layerItem.name??c} (${u.toFixed(2)})`).join(`
|
|
107
107
|
`),d;return n.length>0?d=`Vector search completed. Matching layers with scores:
|
|
108
|
-
${l}`:d="Vector search completed. No matching layers found.",await h({text:d},r),{...e,vectorSearchLayerIds:n}}catch(t){throw await h({text:`Error during vector search: ${t instanceof Error?t.message:String(t)}`},r),new Error(`Vector search failed: ${t instanceof Error?t.message:String(t)}`)}},uo=(e,r,t)=>{let a=e.createQuery();return a.outFields=[r],a.where=t||"1=1",a.num=1,a},ho=async(e,r,t,a)=>{let o=a.map?.allLayers.find(d=>d.id===e),i=uo(o,r,t.where),n=(await o.queryFeatures(i)).features[0],l=n?n.attributes[r]:null;return{tool:"getAttribute",layerName:o.title??e,summary:`${r} = ${l}`,details:{fieldName:r,value:l,where:t.where}}};async function mo({layerId:e,fieldName:r,query:t},a){let{mapView:o}=J(a),i=await ho(e,r,t,o);return JSON.stringify(i,null,2)}var fo=s.object({layerId:s.string().describe("The layerId of the layer containing the field from which to get a value."),fieldName:s.string().describe("The name of the field/attribute from which to get a field value."),query:s.object({where:s.string().describe("The SQL-92 where clause representing the feature from which to get an attribute value.")})}),po=w(mo,{name:"getAttribute",description:"Returns an attribute value for a given feature.",schema:fo}),Fe=async(e,r)=>{let t=r.map?.allLayers.find(i=>i.id===e.layerId);if(!t)return{error:`Could not find geometry layer with ID: ${e.layerId}`};let a=await t.queryFeatures({where:e.where,returnGeometry:!0});if(!a.features.length)return{error:`No features found in geometry layer with the specified where clause: ${e.where}`};let o;if(a.features.length===1){let i=a.features[0].geometry;if(!i)return{error:"The geometry of the first feature is undefined or null."};o=i}else{let i=a.features.map(l=>l.geometry),n=ie.executeMany(i);if(!n)return{error:"Failed to create a combined geometry."};o=n}return{geometry:o}},go=async e=>{let{targetLayer:r,fieldName:t,statisticType:a,mapView:o,layersAndFieldsRegistry:i,geometryLayer:n}=e,l=o.map?.allLayers.find(p=>p.id===r.layerId);if(!l)throw new Error(`Layer '${r.layerId}' not found.`);let d=i.get(r.layerId)?.fieldRegistry.get(t);if(!d)throw new Error(`Field '${t}' not found.`);let c;if(n){let p=await Fe(n,o);if("error"in p)throw new Error(p.error);if(c=p.geometry,n.distance&&n.units){let T=Je.execute(c,n.distance,{unit:n.units==="us-nautical-miles"?"nautical-miles":n.units});T&&(c=T)}}else c=o.extent.clone();let u=new K({geometry:c,spatialRelationship:"intersects"}),f=null,m=null;try{f=await be({layer:l,field:t,sqlWhere:r.where,filter:u,outStatisticTypes:{include:[a]}}),d.type==="string"&&(m=(await ve({layer:l,field:t,sqlWhere:r.where,filter:u})).uniqueValueInfos)}catch(p){console.error("Statistics error:",p)}return{tool:"getStatistics",layerName:l.title??r.layerId,summary:`${a} = ${typeof f?.[a]=="number"?f[a]:"N/A"}`,details:{fieldName:t,statisticType:a,statistic:f?.[a]??null,summaryStatistics:f,uniqueValues:m,where:r.where}}},yo=["feet","kilometers","meters","miles","nautical-miles","us-nautical-miles"],wo=s.enum(yo);async function bo({targetLayer:e,fieldName:r,statisticType:t,geometryLayer:a},o){let i=b(o,"layersAndFieldsRegistry"),{mapView:n}=J(o),l=await go({targetLayer:e,fieldName:r,statisticType:t,mapView:n,layersAndFieldsRegistry:i,geometryLayer:a});return JSON.stringify(l,null,2)}var vo=s.object({targetLayer:s.object({layerId:s.string().describe("The layerId of the layer containing the field from which to get a value."),where:s.string().describe("The SQL-92 where clause representing the feature from which to get an attribute value.")}),geometryLayer:s.union([s.object({layerId:s.string().describe("The layerId of the layer containing the geometry by which to filter."),where:s.string().describe("The SQL-92 where clause representing the features from which to filter features from the targetLayer by geometry."),distance:s.number().optional().describe("The distance by which to query from the input geometry."),units:wo.optional().describe("The units used to query by geometry and distance.")}),s.object({}).strict()]).optional().describe("Optional geometry-based filtering parameters for spatial queries."),fieldName:s.string().describe("The name of the field for which to get statistics."),statisticType:s.enum(["avg","max","median","min","stddev","sum","variance","nullcount","count"]).describe("The statistic type to calculate.")}),So=w(bo,{name:"getStatistics",description:"Returns one or more summary statistics for the given field. Statistic types include: count, maximum, minimum, average, median, standard deviation, variance, mode, sum, nullcount (number of features without a value for a given field), unique values. Statistics can be returned for number, date, and string fields. Only call this tool when the question requires filtering (e.g. a WHERE clause or spatial constraint) that cannot be satisfied by precomputed stats.",schema:vo}),To=async(e,r,t,a)=>{let o=t.map?.allLayers.find(c=>c.id===e.layerId),i=a?await Fe(a,t):{geometry:void 0},n="geometry"in i?i.geometry:void 0,l=new Ke({where:e.where||"1=1",outFields:e.outFields.length?e.outFields:["*"],orderByFields:e.orderByFields,geometry:n,spatialRelationship:n?"intersects":void 0,distance:a?.distance,units:a?.units,topFilter:new He({topCount:r.topCount,groupByFields:r.groupByFields,orderByFields:r.orderByFields})}),d=await o.queryTopFeatures(l);return{tool:"getTopFeatures",layerName:o.title??e.layerId,summary:`Top ${r.topCount} features extracted`,details:{topCount:r.topCount,features:d.features,where:e.where}}},xo=async({targetLayer:e,topFilter:r,geometryLayer:t},a)=>{let{mapView:o}=J(a),i=await To(e,r,o,t);return JSON.stringify(i,null,2)},Eo=s.object({targetLayer:s.object({layerId:s.string().describe("The layerId of the layer containing the field from which to get a value."),where:s.string().describe("The SQL-92 where clause representing the feature from which to get an attribute value."),orderByFields:s.array(s.string().describe("The field(s) and order for which to sort the resulting features.")),outFields:s.array(s.string().describe("The fields to include in the output that will be presented to the user. This should include identifying information about the resulting features, like a name or id, along with the values desired in the output."))}),geometryLayer:s.object({layerId:s.string().describe("The layerId of the layer containing the geometry by which to filter."),where:s.string().describe("The SQL-92 where clause representing the features from which to filter features from the targetLayer by geometry."),distance:s.number().describe("The distance by which to query from the input geometry."),units:M.describe("The units used to query by geometry and distance.")}).optional().describe("Optional geometry-based filtering parameters for spatial queries."),topFilter:s.object({topCount:s.number().describe("The SQL-92 where clause representing the feature from which to get an attribute value."),orderByFields:s.array(s.string().describe("The field(s) and order for which to sort the resulting features.")),groupByFields:s.array(s.string().describe("The field(s) for which to group by the top features."))})}),Io=w(xo,{name:"getTopFeatures",description:"Returns the top n features from a layer",schema:Eo}),Fo=async(e,r,t)=>{let a=r.map?.allLayers.find(d=>d.id===e.layerId),o=t?await Fe(t,r):{geometry:void 0},i="geometry"in o?o.geometry:void 0,n=new St({where:e.where||"1=1",outFields:e.outFields.length?e.outFields:["*"],orderByFields:e.orderByFields,geometry:i,spatialRelationship:i?"intersects":void 0,distance:t?.distance,units:t?.units}),l=await a.queryFeatures(n);return{tool:"queryFeatures",layerName:a.title??e.layerId,summary:`${l.features.length} features found`,details:{totalCount:l.features.length,features:l.features.slice(0,10),where:e.where}}};async function $o({targetLayer:e,geometryLayer:r},t){let{mapView:a}=J(t),o=await Fo(e,a,r);return JSON.stringify(o,null,2)}var Lo=s.object({targetLayer:s.object({layerId:s.string().describe("The layerId of the layer containing the field from which to get a value."),where:s.string().describe("The SQL-92 where clause representing the feature from which to get an attribute value."),orderByFields:s.array(s.string().describe("The field(s) and order for which to sort the resulting features.")),outFields:s.array(s.string().describe("The fields to include in the output that will be presented to the user. This should include identifying information about the resulting features, like a name or id, along with the values desired in the output."))}),geometryLayer:s.object({layerId:s.string().describe("The layerId of the layer containing the geometry by which to filter."),where:s.string().describe("The SQL-92 where clause representing the features from which to filter features from the targetLayer by geometry."),distance:s.number().describe("The distance by which to query from the input geometry."),units:M.describe("The units used to query by geometry and distance.")}).optional().describe("Optional geometry-based filtering parameters for spatial queries.")}),_o=w($o,{name:"queryFeatures",description:"Queries for one or more features from a given layer.",schema:Lo}),ct=[_o,So,po,Io],ko=async(e,r)=>{await h({text:"Requesting LLM for layer query results"},r);let t=await _("data_query_prompt");if(!r?.configurable)throw new Error("config.configurable is required for layer query tools");let{userTimezone:a,userTimezoneOffset:o}=se(),i={layerFieldInfo:e.layerFieldInfo,userTimezone:a,userTimezoneOffset:o},n=await D({promptText:t,modelTier:"advanced",messages:x(e.messages),inputVariables:i,tools:ct});if(!(n.tool_calls&&Array.isArray(n.tool_calls)&&n.tool_calls.length>0))return{...e,messages:[...e.messages,n]};let l=n.content.toString()||"LLM requested tool calls.";return await H(n,r),{...e,outputMessage:l,messages:[...e.messages,n]}},No=new z(ct);async function Ao(e,r){let{messages:t}=await No.invoke({messages:x(e.messages)},r),a=[],o=[];for(let l of t){let d=l.content;if(typeof d!="string"){console.warn("Skipping non-string tool output:",d);continue}let c;try{c=JSON.parse(d)}catch{console.warn("Skipping invalid JSON from tool:",d);continue}a.push(c),o.push(`- ${c.layerName}: ${c.summary}`)}if(o.length===0)return{...e,queryResponses:a};let i=new O({content:`Query results:
|
|
108
|
+
${l}`:d="Vector search completed. No matching layers found.",await h({text:d},r),{...e,vectorSearchLayerIds:n}}catch(t){throw await h({text:`Error during vector search: ${t instanceof Error?t.message:String(t)}`},r),new Error(`Vector search failed: ${t instanceof Error?t.message:String(t)}`)}},uo=(e,r,t)=>{let a=e.createQuery();return a.outFields=[r],a.where=t||"1=1",a.num=1,a},ho=async(e,r,t,a)=>{let o=a.map?.allLayers.find(d=>d.id===e),i=uo(o,r,t.where),n=(await o.queryFeatures(i)).features[0],l=n?n.attributes[r]:null;return{tool:"getAttribute",layerName:o.title??e,summary:`${r} = ${l}`,details:{fieldName:r,value:l,where:t.where}}};async function mo({layerId:e,fieldName:r,query:t},a){let{mapView:o}=J(a),i=await ho(e,r,t,o);return JSON.stringify(i,null,2)}var fo=s.object({layerId:s.string().describe("The layerId of the layer containing the field from which to get a value."),fieldName:s.string().describe("The name of the field/attribute from which to get a field value."),query:s.object({where:s.string().describe("The SQL-92 where clause representing the feature from which to get an attribute value.")})}),po=w(mo,{name:"getAttribute",description:"Returns an attribute value for a given feature.",schema:fo}),Fe=async(e,r)=>{let t=r.map?.allLayers.find(i=>i.id===e.layerId);if(!t)return{error:`Could not find geometry layer with ID: ${e.layerId}`};let a=await t.queryFeatures({where:e.where,returnGeometry:!0});if(!a.features.length)return{error:`No features found in geometry layer with the specified where clause: ${e.where}`};let o;if(a.features.length===1){let i=a.features[0].geometry;if(!i)return{error:"The geometry of the first feature is undefined or null."};o=i}else{let i=a.features.map(l=>l.geometry),n=ie.executeMany(i);if(!n)return{error:"Failed to create a combined geometry."};o=n}return{geometry:o}},go=async e=>{let{targetLayer:r,fieldName:t,statisticType:a,mapView:o,layersAndFieldsRegistry:i,geometryLayer:n}=e,l=o.map?.allLayers.find(p=>p.id===r.layerId);if(!l)throw new Error(`Layer '${r.layerId}' not found.`);let d=i.get(r.layerId)?.fieldRegistry.get(t);if(!d)throw new Error(`Field '${t}' not found.`);let c;if(n){let p=await Fe(n,o);if("error"in p)throw new Error(p.error);if(c=p.geometry,n.distance&&n.units){let T=Je.execute(c,n.distance,{unit:n.units==="us-nautical-miles"?"nautical-miles":n.units});T&&(c=T)}}else c=o.extent.clone();let u=new K({geometry:c,spatialRelationship:"intersects"}),m=null,f=null;try{m=await be({layer:l,field:t,sqlWhere:r.where,filter:u,outStatisticTypes:{include:[a]}}),d.type==="string"&&(f=(await ve({layer:l,field:t,sqlWhere:r.where,filter:u})).uniqueValueInfos)}catch(p){console.error("Statistics error:",p)}return{tool:"getStatistics",layerName:l.title??r.layerId,summary:`${a} = ${typeof m?.[a]=="number"?m[a]:"N/A"}`,details:{fieldName:t,statisticType:a,statistic:m?.[a]??null,summaryStatistics:m,uniqueValues:f,where:r.where}}},yo=["feet","kilometers","meters","miles","nautical-miles","us-nautical-miles"],wo=s.enum(yo);async function bo({targetLayer:e,fieldName:r,statisticType:t,geometryLayer:a},o){let i=b(o,"layersAndFieldsRegistry"),{mapView:n}=J(o),l=await go({targetLayer:e,fieldName:r,statisticType:t,mapView:n,layersAndFieldsRegistry:i,geometryLayer:a});return JSON.stringify(l,null,2)}var vo=s.object({targetLayer:s.object({layerId:s.string().describe("The layerId of the layer containing the field from which to get a value."),where:s.string().describe("The SQL-92 where clause representing the feature from which to get an attribute value.")}),geometryLayer:s.union([s.object({layerId:s.string().describe("The layerId of the layer containing the geometry by which to filter."),where:s.string().describe("The SQL-92 where clause representing the features from which to filter features from the targetLayer by geometry."),distance:s.number().optional().describe("The distance by which to query from the input geometry."),units:wo.optional().describe("The units used to query by geometry and distance.")}),s.object({}).strict()]).optional().describe("Optional geometry-based filtering parameters for spatial queries."),fieldName:s.string().describe("The name of the field for which to get statistics."),statisticType:s.enum(["avg","max","median","min","stddev","sum","variance","nullcount","count"]).describe("The statistic type to calculate.")}),So=w(bo,{name:"getStatistics",description:"Returns one or more summary statistics for the given field. Statistic types include: count, maximum, minimum, average, median, standard deviation, variance, mode, sum, nullcount (number of features without a value for a given field), unique values. Statistics can be returned for number, date, and string fields. Only call this tool when the question requires filtering (e.g. a WHERE clause or spatial constraint) that cannot be satisfied by precomputed stats.",schema:vo}),To=async(e,r,t,a)=>{let o=t.map?.allLayers.find(c=>c.id===e.layerId),i=a?await Fe(a,t):{geometry:void 0},n="geometry"in i?i.geometry:void 0,l=new Ke({where:e.where||"1=1",outFields:e.outFields.length?e.outFields:["*"],orderByFields:e.orderByFields,geometry:n,spatialRelationship:n?"intersects":void 0,distance:a?.distance,units:a?.units,topFilter:new He({topCount:r.topCount,groupByFields:r.groupByFields,orderByFields:r.orderByFields})}),d=await o.queryTopFeatures(l);return{tool:"getTopFeatures",layerName:o.title??e.layerId,summary:`Top ${r.topCount} features extracted`,details:{topCount:r.topCount,features:d.features,where:e.where}}},xo=async({targetLayer:e,topFilter:r,geometryLayer:t},a)=>{let{mapView:o}=J(a),i=await To(e,r,o,t);return JSON.stringify(i,null,2)},Eo=s.object({targetLayer:s.object({layerId:s.string().describe("The layerId of the layer containing the field from which to get a value."),where:s.string().describe("The SQL-92 where clause representing the feature from which to get an attribute value."),orderByFields:s.array(s.string().describe("The field(s) and order for which to sort the resulting features.")),outFields:s.array(s.string().describe("The fields to include in the output that will be presented to the user. This should include identifying information about the resulting features, like a name or id, along with the values desired in the output."))}),geometryLayer:s.object({layerId:s.string().describe("The layerId of the layer containing the geometry by which to filter."),where:s.string().describe("The SQL-92 where clause representing the features from which to filter features from the targetLayer by geometry."),distance:s.number().describe("The distance by which to query from the input geometry."),units:M.describe("The units used to query by geometry and distance.")}).optional().describe("Optional geometry-based filtering parameters for spatial queries."),topFilter:s.object({topCount:s.number().describe("The SQL-92 where clause representing the feature from which to get an attribute value."),orderByFields:s.array(s.string().describe("The field(s) and order for which to sort the resulting features.")),groupByFields:s.array(s.string().describe("The field(s) for which to group by the top features."))})}),Io=w(xo,{name:"getTopFeatures",description:"Returns the top n features from a layer",schema:Eo}),Fo=async(e,r,t)=>{let a=r.map?.allLayers.find(d=>d.id===e.layerId),o=t?await Fe(t,r):{geometry:void 0},i="geometry"in o?o.geometry:void 0,n=new St({where:e.where||"1=1",outFields:e.outFields.length?e.outFields:["*"],orderByFields:e.orderByFields,geometry:i,spatialRelationship:i?"intersects":void 0,distance:t?.distance,units:t?.units}),l=await a.queryFeatures(n);return{tool:"queryFeatures",layerName:a.title??e.layerId,summary:`${l.features.length} features found`,details:{totalCount:l.features.length,features:l.features.slice(0,10),where:e.where}}};async function $o({targetLayer:e,geometryLayer:r},t){let{mapView:a}=J(t),o=await Fo(e,a,r);return JSON.stringify(o,null,2)}var Lo=s.object({targetLayer:s.object({layerId:s.string().describe("The layerId of the layer containing the field from which to get a value."),where:s.string().describe("The SQL-92 where clause representing the feature from which to get an attribute value."),orderByFields:s.array(s.string().describe("The field(s) and order for which to sort the resulting features.")),outFields:s.array(s.string().describe("The fields to include in the output that will be presented to the user. This should include identifying information about the resulting features, like a name or id, along with the values desired in the output."))}),geometryLayer:s.object({layerId:s.string().describe("The layerId of the layer containing the geometry by which to filter."),where:s.string().describe("The SQL-92 where clause representing the features from which to filter features from the targetLayer by geometry."),distance:s.number().describe("The distance by which to query from the input geometry."),units:M.describe("The units used to query by geometry and distance.")}).optional().describe("Optional geometry-based filtering parameters for spatial queries.")}),_o=w($o,{name:"queryFeatures",description:"Queries for one or more features from a given layer.",schema:Lo}),ct=[_o,So,po,Io],ko=async(e,r)=>{await h({text:"Requesting LLM for layer query results"},r);let t=await _("data_query_prompt");if(!r?.configurable)throw new Error("config.configurable is required for layer query tools");let{userTimezone:a,userTimezoneOffset:o}=se(),i={layerFieldInfo:e.layerFieldInfo,userTimezone:a,userTimezoneOffset:o},n=await D({promptText:t,modelTier:"advanced",messages:x(e.messages),inputVariables:i,tools:ct});if(!(n.tool_calls&&Array.isArray(n.tool_calls)&&n.tool_calls.length>0))return{...e,messages:[...e.messages,n]};let l=n.content.toString()||"LLM requested tool calls.";return await H(n,r),{...e,outputMessage:l,messages:[...e.messages,n]}},No=new z(ct);async function Ao(e,r){let{messages:t}=await No.invoke({messages:x(e.messages)},r),a=[],o=[];for(let l of t){let d=l.content;if(typeof d!="string"){console.warn("Skipping non-string tool output:",d);continue}let c;try{c=JSON.parse(d)}catch{console.warn("Skipping invalid JSON from tool:",d);continue}a.push(c),o.push(`- ${c.layerName}: ${c.summary}`)}if(o.length===0)return{...e,queryResponses:a};let i=new O({content:`Query results:
|
|
109
109
|
${o.join(`
|
|
110
110
|
`)}`}),n=`Query results:
|
|
111
111
|
${o.join(`
|
|
112
|
-
`)}`;return{...e,outputMessage:n,messages:[...e.messages,...t,i],queryResponses:a}}var qo=async(e,r)=>{try{await h({text:"Requesting LLM for summary on query results"},r);let t=await _("summarize_query_response_prompt"),a={queryResponse:e.queryResponses},o=await X({promptText:t,messages:x(e.messages),inputVariables:a}),i=typeof o=="string"?o:o.content;return e.messages=[...e.messages,new O(i)],e.outputMessage=i,await h({text:`Received response from LLM: ${i}`},r),e}catch(t){throw await h({text:"Error during filter LLM request"},r),new Error(`Error during filter LLM request: ${t instanceof Error?t.message:String(t)}`)}},Ro=(e,r)=>G(["layerSearch","fieldSearch","layersAndFieldsRegistry"],"Layer Query Agent")(e,r),Mo=()=>new q(lt).addNode("requireLayerQueryServices",Ro).addNode("vectorSearchLayers",co).addNode("vectorSearchFields",so).addNode("fieldStatistics",io).addNode("agent",ko).addNode("tools",Ao).addNode("summarizeQueryResponseLLM",qo).addNode("earlyExit",oo).addEdge(N,"requireLayerQueryServices").addEdge("requireLayerQueryServices","vectorSearchLayers").addConditionalEdges("vectorSearchLayers",e=>e.vectorSearchLayerIds.length?"vectorSearchFields":"earlyExit").addConditionalEdges("vectorSearchFields",e=>e.vectorSearchFieldResults.length?"fieldStatistics":"earlyExit").addEdge("fieldStatistics","agent").addEdge("agent","tools").addConditionalEdges("tools",e=>e.queryResponses.length?"summarizeQueryResponseLLM":"earlyExit").addEdge("summarizeQueryResponseLLM",
|
|
112
|
+
`)}`;return{...e,outputMessage:n,messages:[...e.messages,...t,i],queryResponses:a}}var qo=async(e,r)=>{try{await h({text:"Requesting LLM for summary on query results"},r);let t=await _("summarize_query_response_prompt"),a={queryResponse:e.queryResponses},o=await X({promptText:t,messages:x(e.messages),inputVariables:a}),i=typeof o=="string"?o:o.content;return e.messages=[...e.messages,new O(i)],e.outputMessage=i,await h({text:`Received response from LLM: ${i}`},r),e}catch(t){throw await h({text:"Error during filter LLM request"},r),new Error(`Error during filter LLM request: ${t instanceof Error?t.message:String(t)}`)}},Ro=(e,r)=>G(["layerSearch","fieldSearch","layersAndFieldsRegistry"],"Layer Query Agent")(e,r),Mo=()=>new q(lt).addNode("requireLayerQueryServices",Ro).addNode("vectorSearchLayers",co).addNode("vectorSearchFields",so).addNode("fieldStatistics",io).addNode("agent",ko).addNode("tools",Ao).addNode("summarizeQueryResponseLLM",qo).addNode("earlyExit",oo).addEdge(N,"requireLayerQueryServices").addEdge("requireLayerQueryServices","vectorSearchLayers").addConditionalEdges("vectorSearchLayers",e=>e.vectorSearchLayerIds.length?"vectorSearchFields":"earlyExit").addConditionalEdges("vectorSearchFields",e=>e.vectorSearchFieldResults.length?"fieldStatistics":"earlyExit").addEdge("fieldStatistics","agent").addEdge("agent","tools").addConditionalEdges("tools",e=>e.queryResponses.length?"summarizeQueryResponseLLM":"earlyExit").addEdge("summarizeQueryResponseLLM",I).addEdge("earlyExit",I),Co=String.raw`- **layerQuery** — User is asking about the feature layer’s data (e.g. counts, summaries, statistics, field values), either for all features, a subset based on a condition, or for a subset based on the current view. CRITICAL: Always call the Layer Filter Agent after this agent.
|
|
113
113
|
This also includes questions that ask which feature meets a given condition or where a particular feature in the data is located (e.g., “Where is the spring with the highest elevation?”).
|
|
114
114
|
_Example: “How many features are there?”_
|
|
115
115
|
_Example: “What’s the average population?”_
|
|
116
|
-
_Example: “Which values are in the status field?”_`,kl={id:"layerQuery",name:"Layer Query Agent",description:Co,createGraph:Mo,workspace:lt},Be=.7,zo=10,jo=async(e,r)=>{try{let t=R(e.messages);await h({text:"Similarity search to find fields"},r);let a=b(r,"fieldSearch"),o=b(r,"layersAndFieldsRegistry"),i=b(r,"embeddingCache"),n=await a.searchFields({text:t,layerIds:e.vectorSearchLayerIds,minScore:Be,topResults:zo,embeddingCache:i}),l=n.map(({layerId:c,results:u})=>{let
|
|
116
|
+
_Example: “Which values are in the status field?”_`,kl={id:"layerQuery",name:"Layer Query Agent",description:Co,createGraph:Mo,workspace:lt},Be=.7,zo=10,jo=async(e,r)=>{try{let t=R(e.messages);await h({text:"Similarity search to find fields"},r);let a=b(r,"fieldSearch"),o=b(r,"layersAndFieldsRegistry"),i=b(r,"embeddingCache"),n=await a.searchFields({text:t,layerIds:e.vectorSearchLayerIds,minScore:Be,topResults:zo,embeddingCache:i}),l=n.map(({layerId:c,results:u})=>{let m=u.map(f=>` - ${f.name} (${f.score.toFixed(2)})`).join(`
|
|
117
117
|
`);return`${o.get(c)?.layerItem.name??c}:
|
|
118
|
-
${
|
|
118
|
+
${m}`}).join(`
|
|
119
119
|
`),d;return n.length>0?d=`Vector search completed. Matching layers and fields with scores:
|
|
120
120
|
${l}`:d=`No vector search results found for score over ${Be}.`,await h({text:d},r),{...e,vectorSearchFieldResults:n}}catch(t){throw await h({text:`Error during vector search: ${t instanceof Error?t.message:String(t)}`},r),new Error(`Vector search failed: ${t instanceof Error?t.message:String(t)}`)}},Vo=.7,Oo=async(e,r)=>{try{let t=R(e.messages);await h({text:`Similarity search to find layers: ${t}`},r);let a=b(r,"layerSearch"),o=b(r,"layersAndFieldsRegistry"),i=await a.searchLayers({text:t,minScore:Vo}),n=i.map(c=>c.id),l=i.map(({id:c,score:u})=>`${o.get(c)?.layerItem.name??c} (${u.toFixed(2)})`).join(`
|
|
121
121
|
`),d;return n.length>0?d=`Vector search completed. Matching layers with scores:
|
|
@@ -194,7 +194,7 @@ Fields: This style requires a single field which may be a string, number, or dat
|
|
|
194
194
|
|
|
195
195
|
`);return o[o.length-1]?.trim()===t?e:`${e}
|
|
196
196
|
|
|
197
|
-
${t}`},default:()=>""}),vectorSearchLayerIds:y(),vectorSearchFieldResults:y(),layerFieldInfo:y(),selectedLayerId:y()}),rn=async(e,r)=>(await h({text:"Exiting Layer Styling agent"},r),e),an=async(e,r)=>{try{await h({text:"Populating layer and field info"},r);let t=[];for(let a of e.vectorSearchFieldResults){let o=function(u){let
|
|
197
|
+
${t}`},default:()=>""}),vectorSearchLayerIds:y(),vectorSearchFieldResults:y(),layerFieldInfo:y(),selectedLayerId:y()}),rn=async(e,r)=>(await h({text:"Exiting Layer Styling agent"},r),e),an=async(e,r)=>{try{await h({text:"Populating layer and field info"},r);let t=[];for(let a of e.vectorSearchFieldResults){let o=function(u){let m=l.get(u)?.layerItem;return m?[m.name&&`Name: ${m.name}`,m.title&&`Title: ${m.title}`,m.description&&`Description: ${m.description}`].filter(Boolean).join(" | "):u},{layerId:i,results:n}=a,l=b(r,"layersAndFieldsRegistry"),d=l.get(i)?.fieldRegistry;if(!d)continue;let c=t.find(u=>u.layerId===i);c||(c={layerId:i,layerSummary:o(i),fieldInfos:[]},t.push(c));for(let u of n){let m=d.get(u.name);m&&c.fieldInfos.push(m)}}return await h({text:"Populated layerFieldInfo"},r),{...e,layerFieldInfo:t}}catch(t){throw await h({text:"Error populating layerFieldInfo"},r),new Error(`Error populating layerFieldInfo: ${t instanceof Error?t.message:String(t)}`)}},on=(e,r)=>{let t=e.vectorSearchLayerIds??[];if(t.length<=1)return{...e,selectedLayerId:e.vectorSearchLayerIds[0]};let{hitlResponse:a}=r.configurable;if(!a||a.agentId!==Qe.id||a.id!=="reviewLayerSelection"){let i={agentId:Qe.id,id:"reviewLayerSelection",kind:"singleSelection",message:"Choose a layer to apply the styles.",metadata:[...t]};throw new _e(i)}let o=null;return Array.isArray(a.payload)&&a.payload.length>0&&(o=a.payload[0]),{...e,selectedLayerId:o??e.vectorSearchLayerIds[0]}},nn=(e,r)=>G(["layerSearch","fieldSearch","layersAndFieldsRegistry"],"Layer Styling Agent")(e,r),sn=()=>new q(ut).addNode("requireLayerStylingServices",nn).addNode("vectorSearchLayers",Oo).addNode("layerSelectionHITL",on).addNode("vectorSearchFields",jo).addNode("populateLayerFieldInfo",an).addNode("agent",en).addNode("tools",tn).addNode("earlyExit",rn).addEdge(N,"requireLayerStylingServices").addEdge("requireLayerStylingServices","vectorSearchLayers").addConditionalEdges("layerSelectionHITL",e=>e.vectorSearchLayerIds.length?"vectorSearchFields":"earlyExit").addConditionalEdges("vectorSearchFields",e=>e.vectorSearchFieldResults.length?"populateLayerFieldInfo":"earlyExit").addEdge("populateLayerFieldInfo","agent").addEdge("agent","tools").addEdge("tools",I).addEdge("earlyExit",I),ln=String.raw`- **layerStyling** — User wants to change how features are drawn or styled on the map based on their data, such as applying color, size, transparency, symbols, or charts according to field values.
|
|
198
198
|
_Example: “Color points by sales amount”_
|
|
199
199
|
_Example: “Show population density with a color gradient”_
|
|
200
200
|
_Example: “Create a relationship map between height and depth”_
|
|
@@ -210,7 +210,7 @@ ${t}`},default:()=>""})}),cn=e=>{if(!e||e.size===0)return"No layers available in
|
|
|
210
210
|
${r}`},dn=e=>{let r=e?.list()??[];return r.length?r.map(t=>`- ${t.agent.name}: ${t.agent.description}`).join(`
|
|
211
211
|
`):"No agents currently available."};async function un(e,r){let t=await _("help_prompt"),a=b(r,"layersAndFieldsRegistry"),o=b(r,"agentRegistry"),i={layerSummary:cn(a),agents:dn(o)},n=await X({promptText:t,messages:x(e.messages),inputVariables:i}),l=new O(n),d=[...e.messages,l],c=`${e.outputMessage}
|
|
212
212
|
|
|
213
|
-
${n}`.trim();return{...e,messages:d,outputMessage:c}}var hn=(e,r)=>G(["agentRegistry"],"Help Agent")(e,r),mn=()=>new q(ht).addNode("requireHelpServices",hn).addNode("agent",un).addEdge(N,"requireHelpServices").addEdge("requireHelpServices","agent").addEdge("agent",
|
|
213
|
+
${n}`.trim();return{...e,messages:d,outputMessage:c}}var hn=(e,r)=>G(["agentRegistry"],"Help Agent")(e,r),mn=()=>new q(ht).addNode("requireHelpServices",hn).addNode("agent",un).addEdge(N,"requireHelpServices").addEdge("requireHelpServices","agent").addEdge("agent",I),fn=String.raw`- **help** — Enables users to ask questions about the map, layers, fields, and it's capabilities.
|
|
214
214
|
|
|
215
215
|
_Example: “Tell me about this map”_
|
|
216
216
|
_Example: “List all layers in this map”_
|
|
@@ -230,7 +230,7 @@ ${n}`.trim();return{...e,messages:d,outputMessage:c}}var hn=(e,r)=>G(["agentRegi
|
|
|
230
230
|
${t}`},default:()=>""}),intent:y({reducer:(e,r)=>r})}),ee={conversationId:""},pn=["linkChartView"],gn=["knowledgeGraph"];function le(e){let r=e?.configurable?.context;if(!r||typeof r!="object")throw new Error("ArcgisKnowledgeAgent context missing");let t=pn.filter(a=>!(a in r));if(t.length)throw new Error(`Link Chart context missing: ${t.join(", ")}`);return r}function $e(e){let r=e?.configurable?.context;if(!r||typeof r!="object")throw new Error("ArcgisKnowledgeAgent context missing");let t=gn.filter(a=>!(a in r));if(t.length)throw new Error(`Knowledge Graph context missing: ${t.join(", ")}`);return r}var pe=class{constructor(r){this.dataModel=r,this.kind="GraphQueryGenerationRequest",this.explainQuery=!0,this.schemaInformation=ge.fromDataModel(r)}},ge=class e{constructor(){this.schemaType="ArcgisGraphSchema",this.entityTypes=[],this.relationshipTypes=[],this.identifierInfo={mappingInfo:{identifierMapsTo:"UniformPropertyIdentifier",identifierPropertyName:"globalid"}}}static fromDataModel(r){let t=new e;for(let a of r.entityTypes)t.entityTypes.push(U.fromEntityType(a));for(let a of r.relationshipTypes)t.relationshipTypes.push(ye.fromRelationshipType(a));return t.identifierInfo={mappingInfo:{identifierMapsTo:yn(r.identifierInfo.identifierMappingInfo.identifierInfoType),identifierPropertyName:r.identifierInfo.identifierMappingInfo.uniformPropertyIdentifier.identifierPropertyName}},t.spatialReference=JSON.parse(JSON.stringify(r.spatialReference)),t}},U=class e{constructor(){this.name="",this.properties=[]}static fromEntityType(r){let t=new e;t.name=r.name,t.alias=r.alias?r.alias:void 0,t.role=wn(r.role);for(let a of r.properties){let o={name:a.name,alias:a.alias?a.alias:void 0,fieldType:a.fieldType,role:bn(a.role),geometryDef:a.fieldType==="esriFieldTypeGeometry"?{geometryType:a.geometryType??"esriGeometryAny",hasM:a.hasM?a.hasM:void 0,hasZ:a.hasZ?a.hasZ:void 0}:void 0};t.properties.push(o)}return t}},ye=class extends U{constructor(){super(...arguments),this.observedEndPoints=[]}static fromRelationshipType(r){let t=U.fromEntityType(r);t.observedEndPoints=[];for(let a of r.endPoints)t.observedEndPoints.push({originEntityType:a.originEntityType,destinationEntityType:a.destinationEntityType});return t}},yn=e=>{switch(e){case"esriIdentifierInfoTypeUNSPECIFIED":return"UNSPECIFIED";case"esriIdentifierInfoTypeDatabaseNative":return"DatabaseNative";case"esriIdentifierInfoTypeUniformProperty":return"UniformPropertyIdentifier";default:return e}},wn=e=>{switch(e){case"Regular":return"esriGraphNamedObjectRegular";case"Provenance":return"esriGraphNamedObjectProvenance";case"Document":return"esriGraphNamedObjectDocument";default:return e}};function bn(e){switch(e){case"esriGraphPropertyRegular":return"Regular";case"esriGraphPropertyDocumentName":return"Document_Name";case"esriGraphPropertyDocumentTitle":return"Document_Title";case"esriGraphPropertyDocumentUrl":return"Document_Url";case"esriGraphPropertyDocumentText":return"Document_Text";case"esriGraphPropertyDocumentKeywords":return"Document_Keywords";case"esriGraphPropertyDocumentContentType":return"Document_ContentType";case"esriGraphPropertyDocumentMetadata":return"Document_Metadata";case"esriGraphPropertyDocumentFileExtension":return"Document_FileExtension";case"esriGraphPropertyProvenanceInstanceId":return"Provenance_InstanceId";case"esriGraphPropertyProvenanceSourceType":return"Provenance_SourceType";case"esriGraphPropertyProvenanceSourceName":return"Provenance_SourceName";case"esriGraphPropertyProvenanceSource":return"Provenance_Source";case"esriGraphPropertyProvenanceComment":return"Provenance_Comment";case"esriGraphPropertyProvenanceTypeName":return"Provenance_TypeName";case"esriGraphPropertyProvenancePropertyName":return"Provenance_PropertyName";default:return"Regular"}}async function vn(e,r,t,a){let{graphQuery:o,explanation:i}=await Le(e,r,t,a);return`Generated Graph Query:
|
|
231
231
|
${o}
|
|
232
232
|
|
|
233
|
-
Explanation: ${i}`}async function Le(e,r,t,a){let o={message:e,context:new pe(r)};ee.conversationId&&(o.conversationId=ee.conversationId),await h({text:"Attempting to generate a cypher query from your prompt..."},a);let i=await ze(`${t}/chat`,{method:"post",body:JSON.stringify(o),headers:{"Content-Type":"application/json",token:je.findCredential(P.getDefault().url)?.token??""}});if(i.httpStatus!==200)throw new Error(`Graph query service returned an error: ${i.httpStatus}`,{cause:i.data});ee.conversationId||(ee.conversationId=i.data.conversationId);let n=!1,l=Date.now(),d=i.data.sequenceNumber,c="",u="",
|
|
233
|
+
Explanation: ${i}`}async function Le(e,r,t,a){let o={message:e,context:new pe(r)};ee.conversationId&&(o.conversationId=ee.conversationId),await h({text:"Attempting to generate a cypher query from your prompt..."},a);let i=await ze(`${t}/chat`,{method:"post",body:JSON.stringify(o),headers:{"Content-Type":"application/json",token:je.findCredential(P.getDefault().url)?.token??""}});if(i.httpStatus!==200)throw new Error(`Graph query service returned an error: ${i.httpStatus}`,{cause:i.data});ee.conversationId||(ee.conversationId=i.data.conversationId);let n=!1,l=Date.now(),d=i.data.sequenceNumber,c="",u="",m=1;for(;!n;){await new Promise(p=>setTimeout(p,1e3)),await h({text:`Periodically requesting status of job from ArcGIS AI Services${"...".substring(0,m)}`},a),m=m%3+1;let f=await ze(`${t}/chat`,{method:"post",body:JSON.stringify({conversationId:i.data.conversationId,inquiryId:i.data.inquiryId,ackSequenceNumber:d}),headers:{"Content-Type":"application/json",token:je.findCredential(P.getDefault().url)?.token??""}});if(f.httpStatus!==200)throw new Error(`Graph query service polling returned an error: ${f.httpStatus}`,{cause:f.data});if(f.data.context)c=f.data.context.graphQuery,u=f.data.message||"";else if(!f.data.hasMore)n=!0;else if(Date.now()-l>6e4)throw new Error("Graph query service polling timed out after 1 minute.");d=f.data.sequenceNumber}return{graphQuery:c,explanation:u}}function te(e,r){if(!(!e||typeof e!="object")){if(Tn(e))for(let t of e.path)te(t,r);else if(Sn(e))r.set(`${e.typeName}__${e.id}`,{id:e.id,typeName:e.typeName});else if(Array.isArray(e))for(let t of e)te(t,r);else if(xn(e))for(let t of Object.values(e.properties??{}))te(t,r)}}function Sn(e){return!e||typeof e!="object"||Array.isArray(e)?!1:"id"in e&&"typeName"in e}function Tn(e){return!e||typeof e!="object"||Array.isArray(e)?!1:e&&"path"in e&&Array.isArray(e.path)}function xn(e){return!e||typeof e!="object"||Array.isArray(e)||"id"in e?!1:"properties"in e&&typeof e.properties=="object"}function En(e,r){let t=[];for(let a of[...r.dataModel.entityTypes,...r.dataModel.relationshipTypes]){let o=e.getMemberIdsByType(a.name);for(let i of o)t.push({id:i,typeName:a.name})}return t}var In=async e=>{let r=new Map,t=e.resultRowsStream.getReader();for(;;){let{done:a,value:o}=await t.read();if(a)break;for(let i of o)for(let n of i)te(n,r)}return Array.from(r.values())};async function Fn(e,r,t,a,o){let{graphQuery:i,explanation:n}=await Le(e,r.dataModel,t,o);await h({text:`Attempting to execute query: ${i.substring(0,500)}${i.length>500?"...":""}`},o);let l=await Ot(r,new Ze({openCypherQuery:i}),{signal:o?.signal,timeout:o?.timeout}),d=await In(l);return await h({text:`Query Results parsed into ${d.length} unique relationships and entities. Atempting to add to link chart...`},o),await a.map.addRecords(d),a.goTo(a.map.diagramNodesExtent),`Link Chart updated successfully. Cypher Query used:
|
|
234
234
|
${i}
|
|
235
235
|
|
|
236
236
|
Explanation: ${n}`}async function $n({prompt:e},r){let{knowledgeGraph:t}=$e(r),{linkChartView:a}=le(r),o=P.getDefault().helperServices,i=await _("arcgis_knowledge_current_lc_context"),n=En(a.map,t),l=`${e}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.0/LICENSE.txt */
|
|
2
|
-
import c from"./
|
|
2
|
+
import c from"./MUPZUO2E.js";import b from"./LM63GUX3.js";import{a as r,c as a}from"./S6VLY5RD.js";import"./AIKIUPMV.js";import"./2LSVWAZO.js";import{v as s,z as e}from"./BPQHDASZ.js";import"./2GMCG6SX.js";export default $arcgis.t(([,{f:i}])=>{var t=class extends s{constructor(){super(...arguments),this.agent=i}static{this.properties={referenceElement:1}}#t;getContext(){if(!this.#t)throw new Error("arcgis-assistant-help-agent requires a mapView");return{mapView:this.#t}}load(){this.#t=r(this,"arcgis-assistant-help-agent"),a(this)}};e("arcgis-assistant-help-agent",t);return t},b,c)
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.0/LICENSE.txt */
|
|
2
|
-
import{b as e,c as i}from"./S6VLY5RD.js";import"./AIKIUPMV.js";import"./2LSVWAZO.js";import{v as s,z as a}from"./
|
|
2
|
+
import{b as e,c as i}from"./S6VLY5RD.js";import"./AIKIUPMV.js";import"./2LSVWAZO.js";import{v as s,z as a}from"./BPQHDASZ.js";import"./2GMCG6SX.js";var t=class extends s{static{this.properties={agent:0,context:0}}async getContext(){return e(this.context)?await this.context():this.context}load(){i(this)}};a("arcgis-assistant-agent",t);export{t as ArcgisAssistantAgent};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.0/LICENSE.txt */
|
|
2
|
-
import{a as n}from"./
|
|
2
|
+
import{a as n}from"./52GK3WHG.js";import"./2LSVWAZO.js";import{g as a,h as e,n as s,v as c,z as l}from"./BPQHDASZ.js";import"./2GMCG6SX.js";var o=a``,i=class extends c{constructor(){super(...arguments),this.#t=[],this._messages=n({blocking:!0}),this.arcgisCancel=s(),this.arcgisSubmit=s()}static{this.properties={type:1,message:1,options:0}}static{this.styles=o}#t;_renderInterruptOptions(){switch(this.type){case"single-select":return e`<calcite-list selection-mode=single-persist .label=${this._messages.optionsLabel} @calciteListChange=${t=>this.#t=t.target.selectedItems[0]?.value}>${this.options?.map(t=>e`<calcite-list-item .label=${t} .value=${t}></calcite-list-item>`)}</calcite-list>`;case"multi-select":return e`<calcite-list selection-mode=multiple .label=${this._messages.optionsLabel} @calciteListChange=${t=>this.#t=t.target.selectedItems.map(r=>r.value)}>${this.options?.map(t=>e`<calcite-list-item .label=${t} .value=${t}></calcite-list-item>`)}</calcite-list>`;case"boolean-choice":return null;case"text-input":return e`<calcite-input .label=${this._messages.enterTextLabel} @calciteInputInput=${t=>this.#t=t.target.value}></calcite-input>`}}render(){return e`<calcite-panel .description=${this.message}>${this._renderInterruptOptions()}<calcite-button slot=footer-end appearance=outline @click=${()=>this.arcgisCancel.emit()}>${this._messages.cancelButtonLabel}</calcite-button><calcite-button slot=footer-end appearance=solid @click=${()=>this.arcgisSubmit.emit(this.type==="boolean-choice"?!0:this.#t)}>${this._messages.submitButtonLabel}</calcite-button></calcite-panel>`}};l("arcgis-assistant-interrupt",i);export{i as ArcgisAssistantInterrupt};
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.0/LICENSE.txt */
|
|
2
|
-
import c from"./
|
|
2
|
+
import c from"./MUPZUO2E.js";import b from"./LM63GUX3.js";import{a as i,c as e}from"./S6VLY5RD.js";import"./AIKIUPMV.js";import"./2LSVWAZO.js";import{v as a,z as s}from"./BPQHDASZ.js";import"./2GMCG6SX.js";export default $arcgis.t(([,{a:r}])=>{var t=class extends a{constructor(){super(...arguments),this.agent=r}static{this.properties={referenceElement:1}}#t;getContext(){if(!this.#t)throw new Error("arcgis-assistant-navigation-agent requires a mapView");return{mapView:this.#t}}load(){this.#t=i(this,"arcgis-assistant-navigation-agent"),e(this)}};s("arcgis-assistant-navigation-agent",t);return t},b,c)
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.0/LICENSE.txt */
|
|
2
|
-
import c from"./
|
|
2
|
+
import c from"./MUPZUO2E.js";import b from"./LM63GUX3.js";import{a as e,c as a}from"./S6VLY5RD.js";import"./AIKIUPMV.js";import"./2LSVWAZO.js";import{v as s,z as r}from"./BPQHDASZ.js";import"./2GMCG6SX.js";export default $arcgis.t(([,{e:i}])=>{var t=class extends s{constructor(){super(...arguments),this.agent=i}static{this.properties={referenceElement:1}}#t;getContext(){if(!this.#t)throw new Error("arcgis-assistant-layer-styling-agent requires a mapView");return{mapView:this.#t}}load(){this.#t=e(this,"arcgis-assistant-layer-styling-agent"),a(this)}};r("arcgis-assistant-layer-styling-agent",t);return t},b,c)
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.0/LICENSE.txt */
|
|
2
|
-
import{a as v}from"./
|
|
2
|
+
import{a as v}from"./52GK3WHG.js";import"./2LSVWAZO.js";import{g as u,h as i,n as r,t as d,u as p,v as g,x as m,z as y}from"./BPQHDASZ.js";import"./2GMCG6SX.js";export default $arcgis.t(([{watch:_},f])=>{var w=u`.assistant-chat-entry__input-container{display:flex;flex-direction:column}.assistant-chat-entry__footer-start{display:flex;gap:var(--calcite-spacing-md);flex-wrap:wrap;align-items:center}.assistant-chat-entry__footer-end{display:flex;gap:var(--calcite-spacing-md);align-items:center}.assistant-chat-entry__status-indicator{width:9px;height:9px;border-radius:100%;background-color:var(--calcite-color-status-success)}.assistant-chat-entry__status-indicator[data-status=working]{background-color:var(--calcite-color-status-warning)}.assistant-chat-entry__status-indicator[data-status=error]{background-color:var(--calcite-color-status-danger)}.assistant-chat-entry__status-text{text-transform:capitalize}`,n=class extends g{constructor(){super(...arguments),this.#s=d(),this.#t=-1,this.#a="",this._messages=v({blocking:!0}),this.keyboardShortcutsDisabled=!1,this.awaitingResponse=!1,this.inputValue="",this.messages=new f([]),this.arcgisCancel=r(),this.arcgisSubmit=r()}static{this.properties={_userMessages:16,keyboardShortcutsDisabled:5,entryPlaceholder:1,awaitingResponse:5,inputValue:1,status:1,messages:0}}static{this.styles=w}#s;#t;#a;get _userMessages(){return this.messages.toArray().filter(t=>t.role==="user").map(({content:t})=>t)}loaded(){this.manager.onLifecycle(()=>[_(()=>this.inputValue,t=>{this.#s.value&&(this.#s.value.value=t)},{initial:!0})])}async _submitMessage(){if(this.awaitingResponse){this.arcgisCancel.emit();return}let t=this.#s.value?.value.trim();t&&(this.arcgisSubmit.emit(t),this.#t=-1,this.#a="",this.#s.value&&(this.#s.value.value="",await this.#s.value.setFocus()))}async _navigateHistory(t,o){let s=this.#s.value;if(!s)return;let a=this._userMessages;if(a.length===0)return;let c=s.value??"",l=s.shadowRoot?.querySelector("textarea"),e=l?.selectionStart,h=l?.selectionEnd;if(!(e==null||h==null)&&!(e!==h||t==="up"&&e!==0||t==="down"&&e!==c.length)){if(t==="up"){this.#t===-1?(this.#a=c,this.#t=a.length-1):this.#t=Math.max(0,this.#t-1),s.value=a[this.#t]??"",o.preventDefault();return}this.#t!==-1&&(this.#t<a.length-1?(this.#t+=1,s.value=a[this.#t]??""):(this.#t=-1,s.value=this.#a),o.preventDefault())}}render(){return i`<div class="assistant-chat-entry__input-container"><calcite-text-area .value=${this.#s.value?.value} .placeholder=${this.entryPlaceholder??this._messages.entryPlaceholder} resize=vertical @keydown=${async t=>{t.altKey||t.ctrlKey||t.metaKey||t.shiftKey||this.keyboardShortcutsDisabled||(t.key==="Enter"?(t.preventDefault(),await this._submitMessage()):t.key==="ArrowUp"?await this._navigateHistory("up",t):t.key==="ArrowDown"&&await this._navigateHistory("down",t))}} ${p(this.#s)}><div slot=footer-start class="assistant-chat-entry__footer-start"><slot name=entry-actions-start></slot></div><div slot=footer-end class="assistant-chat-entry__footer-end">${this.status?i`<div id=tooltip-status class="assistant-chat-entry__status-indicator" data-status=${this.status??m}></div><calcite-tooltip reference-element=tooltip-status offset-distance=12><span class="assistant-chat-entry__status-text">${this.status}</span></calcite-tooltip>`:null}<calcite-button .iconStart=${this.awaitingResponse?"circle-stop":"send"} slot=footer-end round @click=${()=>void this._submitMessage()}>${this.awaitingResponse?this._messages.stopButtonLabel:this._messages.askButtonLabel}</calcite-button></div></calcite-text-area></div>`}};y("arcgis-assistant-chat-entry",n);return n},"core/reactiveUtils","core/Collection")
|
package/dist/cdn/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.0/LICENSE.txt */
|
|
2
|
-
import{p as e,y as s}from"./
|
|
2
|
+
import{p as e,y as s}from"./BPQHDASZ.js";import"./2GMCG6SX.js";var t=e(s,{"arcgis-assistant":[()=>import("./HLPUBPCI.js"),"_messages:,copyEnabled,description,entryMessage,feedbackEnabled,heading,keepSuggestedPrompts,logEnabled,messages:,orchestrator:,referenceElement,suggestedPrompts:;clearChatHistory,submitMessage;register"],"arcgis-assistant-agent":[()=>import("./ONNF5H7M.js"),"agent:,context:;getContext"],"arcgis-assistant-data-exploration-agent":[()=>import("./JGIGJE4O.js"),"referenceElement;;getContext"],"arcgis-assistant-help-agent":[()=>import("./OCPIIJ2S.js"),"referenceElement;;getContext"],"arcgis-assistant-layer-filter-agent":[()=>import("./AUBCU3OY.js"),"referenceElement;;getContext"],"arcgis-assistant-layer-query-agent":[()=>import("./BFHTVXW6.js"),"referenceElement;;getContext"],"arcgis-assistant-layer-styling-agent":[()=>import("./YNFGT5LD.js"),"referenceElement;;getContext"],"arcgis-assistant-navigation-agent":[()=>import("./XSCK3GGX.js"),"referenceElement;;getContext"],"arcgis-assistant-chat":[()=>import("./JUAPAUGI.js"),"copyEnabled,feedbackEnabled,loading,loadingMessage,logEnabled,messages:,user"],"arcgis-assistant-chat-card":[()=>import("./36II53D3.js"),"_messages:,content,copyEnabled,error,feedbackEnabled,loading,loadingMessage,log:,logEnabled,message:,messageRole,user"],"arcgis-assistant-chat-card-content":[()=>import("./46V7X5JS.js"),"content,loading,loadingMessage,type"],"arcgis-assistant-chat-entry":[()=>import("./ZMGGKF6I.js"),"_messages:,awaitingResponse,entryPlaceholder,inputValue,keyboardShortcutsDisabled,messages:,status"],"arcgis-assistant-interrupt":[()=>import("./P6OWXBI4.js"),"_messages:,message,options:,type"],"arcgis-assistant-shell":[()=>import("./23RHBIQG.js"),"_messages:,awaitingResponse,description,entryMessage,entryMessageClosed,heading,inputValue,loading,messages:,status,suggestedPrompts:"]});t({resourcesUrl:import.meta.url});var a=new CSSStyleSheet;a.replaceSync("@layer{:not([hydrated]):is(arcgis-assistant,arcgis-assistant-agent,arcgis-assistant-data-exploration-agent,arcgis-assistant-help-agent,arcgis-assistant-layer-filter-agent,arcgis-assistant-layer-query-agent,arcgis-assistant-layer-styling-agent,arcgis-assistant-navigation-agent,arcgis-assistant-chat,arcgis-assistant-chat-card,arcgis-assistant-chat-card-content,arcgis-assistant-chat-entry,arcgis-assistant-interrupt,arcgis-assistant-shell){visibility:hidden}}");document.adoptedStyleSheets=[...document.adoptedStyleSheets,a];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,s)
|
package/dist/chunks/runtime.js
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
import "../cdn/main.css";
|
|
3
3
|
import { makeRuntime as e } from "@arcgis/lumina";
|
|
4
4
|
import { trackAccess as s, createObservable as a, createTrackingTarget as r, runTracked as c } from "@arcgis/core/applications/Components/reactiveUtils.js";
|
|
5
|
-
const t = e({ defaultAssetPath: "https://js.arcgis.com/5.0.
|
|
5
|
+
const t = e({ defaultAssetPath: "https://js.arcgis.com/5.0.9/ai-components/", hydratedAttribute: "hydrated" }), { customElement: n, getAssetPath: i, setAssetPath: d } = t;
|
|
6
6
|
t.t = s;
|
|
7
7
|
t.o = a;
|
|
8
8
|
t.c = r;
|