@arcgis/ai-components 5.2.0-next.3 → 5.2.0-next.5
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/agent-utils/LLMAgent.js +22 -22
- package/dist/cdn/{S6W6HV4T.js → 3BKUCFKS.js} +1 -1
- package/dist/cdn/{YY2SBO3V.js → 3WINIQWY.js} +1 -1
- package/dist/cdn/{4HU7735A.js → CXWBEDXN.js} +1 -1
- package/dist/cdn/{GSEPHN3A.js → DO2P3PWF.js} +24 -24
- package/dist/cdn/{JY6LLOUJ.js → ERBQSEPQ.js} +1 -1
- package/dist/cdn/{V5YEZSRY.js → GBNUMN4J.js} +1 -1
- package/dist/cdn/{FHVXO2WG.js → GJUXVEOF.js} +4 -4
- package/dist/cdn/J5CMRCPS.js +3 -0
- package/dist/cdn/{MDVYQQUG.js → M6F4MXDK.js} +1 -1
- package/dist/cdn/index.js +1 -1
- package/dist/chunks/adapter.js +6 -6
- package/dist/chunks/generateLayerDescriptions.js +223 -203
- package/dist/chunks/orchestrator.js +240 -201
- package/dist/docs/api.json +1 -1
- package/dist/docs/docs.json +1 -1
- package/dist/docs/web-types.json +1 -1
- package/dist/utils/index.d.ts +8 -3
- package/dist/utils/index.js +22 -18
- package/package.json +4 -4
- package/dist/cdn/ON2V5XI2.js +0 -3
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import b from"./
|
|
2
|
+
import b from"./GJUXVEOF.js";import a from"./DO2P3PWF.js";import{Fb as f,a as h,b as l}from"./462JBSEV.js";import{a as y,c as E}from"./HB5A5R2E.js";import"./AMP6IALT.js";import"./OAVEHGB6.js";import{v as u,y as d}from"./OH64RMOR.js";import"./YIMNOUTF.js";export default $arcgis.t(([,,,,,,,,,,,,,,,{f:p,n:x},{I:c,J:H,a:S,m:_,n:w,o:m,p:v}])=>{var C=[H],b=e=>{if(!e||e.size===0)return"No layers available in this map.";let t=Array.from(e.values()).map(({layerItem:o,fieldRegistry:a},s)=>{let r=Array.from(a.values()).map(n=>n.name).slice(0,10).join(", "),i=a.size>10?` (and ${a.size-10} more)`:"";return`${s+1}. "${o.title}". Description: ${o.description}
|
|
3
3
|
Fields: ${r}${i}`}).join(`
|
|
4
4
|
|
|
5
5
|
`);return`This map contains ${e.size} layer(s):
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import d from"./
|
|
2
|
+
import d from"./3WINIQWY.js";import c from"./GJUXVEOF.js";import a from"./DO2P3PWF.js";import{Fb as k,Q as V,a as N,b as E}from"./462JBSEV.js";import{a as D,c as O}from"./HB5A5R2E.js";import"./AMP6IALT.js";import"./OAVEHGB6.js";import{v as b,y as A}from"./OH64RMOR.js";import"./YIMNOUTF.js";export default $arcgis.t(([,,,,,,,,,,K,X,,,{f:n,l:z,n:T},{C:R,D:G,E:L,F:P,G:F,H:U,a:j,m:S,n:M,o:p,p:Q},C])=>{var Y=async(e,t)=>(await n({text:"Exiting Data Exploration agent"},t),e),Z=async(e,t)=>{await n({text:"Requesting LLM for layer filter results"},t);let a=await S("data_explore_filter_prompt");if(!t?.configurable)throw new Error("config.configurable is required for layer filter tools");let{userTimezone:c,userTimezoneOffset:l}=L(),s={layerFieldInfo:e.layerFieldInfo,userTimezone:c,userTimezoneOffset:l,queryResponse:e.queryResponse,assignedTask:e.agentExecutionContext.assignedTask,userRequest:e.agentExecutionContext.userRequest,priorSteps:e.agentExecutionContext.priorSteps},r=await T({promptText:a,modelTier:"advanced",messages:e.dataExplorationMessages,inputVariables:s,tools:F}),i=[...e.dataExplorationMessages,r];if(!((r.tool_calls?.length??0)>0))return await n({text:"LLM determined no filter changes needed"},t),{...e,dataExplorationMessages:i};let u=[...i,r],o=r.content.toString();return await C(r,t),{...e,dataExplorationMessages:u,outputMessage:o}},ee=async(e,t)=>{await n({text:"Requesting LLM for layer query results"},t);let a=await S("data_explore_query_prompt");if(!t?.configurable)throw new Error("config.configurable is required for layer query tools");let{userTimezone:c,userTimezoneOffset:l}=L(),s=e.agentExecutionContext.sharedState.lastNavigatedFeatures,r=s&&typeof s=="object"&&"value"in s?s.value:s,i="none";if(r!=null)try{i=JSON.stringify(r)}catch{i="none"}let u={layerFieldInfo:e.layerFieldInfo,userTimezone:c,userTimezoneOffset:l,assignedTask:e.agentExecutionContext.assignedTask,userRequest:e.agentExecutionContext.userRequest,priorSteps:e.agentExecutionContext.priorSteps,lastNavigatedFeatures:i},o=await T({promptText:a,modelTier:"advanced",messages:e.dataExplorationMessages,inputVariables:u,tools:P}),m=o.content.toString();return await C(o,t),{...e,dataExplorationMessages:[...e.dataExplorationMessages,o],outputMessage:m,status:"success",summary:m?M(m):"Query executed."}},te=async(e,t)=>{try{await n({text:"Requesting LLM for summary on query results"},t);let a=await S("summarize_query_response_prompt"),c={queryResponse:e.queryResponse,assignedTask:e.agentExecutionContext.assignedTask,userRequest:e.agentExecutionContext.userRequest,priorSteps:e.agentExecutionContext.priorSteps},l=await z({promptText:a,modelTier:"fast",messages:e.dataExplorationMessages,inputVariables:c}),s=typeof l=="string"?l:l.content,r=new V(s);await n({text:`Received response from LLM: ${s}`},t);let i=s;return{...e,outputMessage:i,status:"success",summary:i?M(i):"Summary generated.",dataExplorationMessages:[...e.dataExplorationMessages,r]}}catch(a){throw await n({text:"Error during filter LLM request"},t),new Error(`Error during filter LLM request: ${a instanceof Error?a.message:String(a)}`)}};async function ae(e,t){let a=await new j(F).invoke({messages:e.dataExplorationMessages},t);return await n({text:`Finished executing layer filter tool: ${a.messages.map(c=>c.content).join(", ")}`},t),{...e}}var se=10,re=["string","small-integer","integer"],ie=async(e,t,{includeSummaryStatistics:a=!0,includeUniqueValues:c=!0}={})=>{let l=null,s=null;try{if(t.type!=="geometry"&&t.type!=="oid"&&t.type!=="global-id"){a&&(l=await K({layer:e,field:t.name}));let r=t.domain?.type==="coded-value"?t.domain:null;c&&(re.includes(t.type)||r)&&(s=(await X({layer:e,field:t.name})).uniqueValueInfos.sort((i,u)=>u.count-i.count).slice(0,se),r&&(s=s.map(i=>({...i,value:r.getName(i.value)??i.value}))))}}catch(r){console.error(`Error fetching statistics for field ${t.name}:`,r)}return{summaryStatistics:l,uniqueValues:s}};function oe(e,t){return["string","small-integer","integer"].includes(e)||t==="coded-value"}async function ne(e,t,a,c=!0){let l=[],s=[],r=[];for(let i of e){let u=function(g){let d=t.get(g)?.layerItem;return d?[d.name&&`Name: ${d.name}`,d.title&&`Title: ${d.title}`,d.description&&`Description: ${d.description}`].filter(Boolean).join(" | "):g},{layerId:o,results:m}=i,f=a.map?.allLayers.find(g=>g.id===o),w=t.get(o)?.fieldRegistry;if(!w)continue;let h=l.find(g=>g.layerId===o);h||(h={layerId:o,layerSummary:u(o),fieldInfos:[]},l.push(h));for(let g of m){let d=w.get(g.name);if(!d)continue;let y=d.statistics,v=c&&!y?.summaryStatistics,q=oe(d.type,d.domain?.type)&&!y?.uniqueValues,_=v||q;if(r.push({layerId:o,fieldName:d.name,didFetchStatistics:_}),_){let J=ie(f,d,{includeSummaryStatistics:v,includeUniqueValues:q}).then($=>{let x={summaryStatistics:y?.summaryStatistics??null,uniqueValues:y?.uniqueValues??null};v&&(x.summaryStatistics=$.summaryStatistics),q&&(x.uniqueValues=$.uniqueValues),w.set(d.name,{...d,statistics:x}),d.statistics=x});s.push(J)}h.fieldInfos.push(d)}}return await Promise.all(s),{layerFieldInfo:l,didFetchStatistics:s.length>0,fieldStatisticsFetchStatus:r}}var W=/\b(average|avg|mean|median|max(?:imum)?|min(?:imum)?|sum|total|count|std(?:dev|\s*deviation)|variance|null\s*count|missing\s*values?|range)\b/iu;function le(e,t){return W.test(e)||W.test(t)}var de=async(e,t)=>{try{await n({text:"Preparing field information for vector search results"},t);let a=p(t,"layersAndFieldsRegistry"),{mapView:c}=G(t),{assignedTask:l,userRequest:s}=e.agentExecutionContext,r=le(l,s),{layerFieldInfo:i,didFetchStatistics:u,fieldStatisticsFetchStatus:o}=await ne(e.vectorSearchFieldResults,a,c,r);u?await n({text:"Statistics fetched"},t):await n({text:"Statistics skipped"},t);for(let m of o)await n({text:` - ${m.fieldName} - stats ${m.didFetchStatistics?"fetched":"skipped"}`},t);return await n({text:"Field information prepared"},t),{...e,layerFieldInfo:i}}catch(a){throw await n({text:"Error during fetching statistics"},t),new Error(`Error during fetching statistics: ${a instanceof Error?a.message:String(a)}`)}},B=.7,ce=10,ue=async(e,t)=>{try{await n({text:"Similarity search to find fields"},t);let a=p(t,"fieldSearch"),c=p(t,"layersAndFieldsRegistry"),l=p(t,"embeddingCache"),s=await a.searchFields({text:e.agentExecutionContext.assignedTask,layerIds:e.vectorSearchLayerIds,minScore:B,topResults:ce,embeddingCache:l}),r=s.map(({layerId:u,results:o})=>{let m=o.map(f=>` - ${f.name} (${f.score.toFixed(2)})`).join(`
|
|
3
3
|
`);return`${c.get(u)?.layerItem.name??u}:
|
|
4
4
|
${m}`}).join(`
|
|
5
5
|
`),i;return s.length>0?i=`Vector search completed. Matching layers and fields with scores:
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import a from"./
|
|
2
|
+
import a from"./DO2P3PWF.js";import{Bb as j,L as q,M as ee,R as z,Za as I,_a as h,g as ge,j as V,k as Q,kb as g,qb as be,u as we}from"./462JBSEV.js";export default $arcgis.t(([$e,M,Ce,,Ne,oe,tt,{addressToLocations:rt},ot,at,Re,{createRenderer:nt},{getSchemesByTag:it,getSchemes:st},{getBackgroundColorTheme:ke},{createAgeRenderer:lt,createContinuousRenderer:ct},{getSchemesByTag:pe},{createContinuousRenderer:ut},{createRenderer:dt},{getSchemesByTag:pt},{createRenderer:mt},{getSchemesByTag:ht},{createRenderer:ft},{getSchemesByTag:yt},{createRenderer:gt},{getSchemesByTag:wt},{createAgeRenderer:bt,createContinuousRenderer:vt},{createRenderer:Tt},{getSchemesByTag:St},xt,_e,qe,{formatDateOnly:Et,convertDateFormatToIntlOptions:U,formatTimeOnly:It,formatDate:Fe},$t,Nt,kt,Ft,Mt,ze,,{fetchKnowledgeGraph:Me,executeQueryStreaming:At,executeSearchStreaming:Ct},Rt,{a:i,c:L,d:ve,f:T,g:S,m:Te}])=>{var Ie=e=>Array.isArray(e)&&e.every(q),Ze=e=>typeof e=="object"&&e!=null&&"messages"in e&&Ie(e.messages),Ye=e=>typeof e=="object"&&e!=null&&"lg_tool_call"in e,B=class extends be{tools;handleToolErrors=!0;trace=!1;constructor(e,t){let{name:r,tags:o,handleToolErrors:a}=t??{};super({name:r,tags:o,func:(n,s)=>this.run(n,s)}),this.tools=e,this.handleToolErrors=a??this.handleToolErrors}async runTool(e,t){let r=this.tools.find(o=>o.name===e.name);try{if(r===void 0)throw new Error(`Tool "${e.name}" not found.`);let o=await r.invoke({...e,type:"tool_call"},t);return q(o)&&o.getType()==="tool"||Q(o)?o:new ee({status:"success",name:r.name,content:typeof o=="string"?o:JSON.stringify(o),tool_call_id:e.id})}catch(o){if(!this.handleToolErrors||we(o))throw o;return new ee({status:"error",content:`Error: ${o.message}
|
|
3
3
|
Please fix your mistakes.`,name:e.name,tool_call_id:e.id??""})}}async run(e,t){let r;if(Ye(e))r=[await this.runTool(e.lg_tool_call,t)];else{let n;if(Ie(e))n=e;else if(Ze(e))n=e.messages;else throw new Error("ToolNode only accepts BaseMessage[] or { messages: BaseMessage[] } as input.");let s=new Set(n.filter(u=>u.getType()==="tool").map(u=>u.tool_call_id)),l;for(let u=n.length-1;u>=0;u-=1){let c=n[u];if(z(c)){l=c;break}}if(l==null||!z(l))throw new Error("ToolNode only accepts AIMessages as input.");r=await Promise.all(l.tool_calls?.filter(u=>u.id==null||!s.has(u.id)).map(u=>this.runTool(u,t))??[])}if(!r.some(Q))return Array.isArray(e)?r:{messages:r};let o=[],a=null;for(let n of r)Q(n)?n.graph===V.PARENT&&Array.isArray(n.goto)&&n.goto.every(s=>ge(s))?a?a.goto.push(...n.goto):a=new V({graph:V.PARENT,goto:n.goto}):o.push(n):o.push(Array.isArray(e)?[n]:{messages:[n]});return a&&o.push(a),o}};var Fn=g.Root({llmInputMessages:g({reducer:(e,t)=>j([],t),default:()=>[]})});var O=(e,t)=>t??e,ji=g.Root({...ve(),intent:g({reducer:O}),vectorSearchLayerResults:g({reducer:O,default:()=>[]}),vectorSearchFieldResults:g({reducer:O}),navigationInternalState:g({reducer:O,default:()=>({toolCallMessage:void 0})})});async function _t(e,t){let r=M.getDefault().helperServices,o=r.geocode.find(d=>d.name==="ArcGIS World Geocoding Service")??r.geocode[0];if(!o)throw new Error("No geocoding service found in helperServices.");let a=o.url,n=`${oe.assetsPath?.endsWith("/")?oe.assetsPath:`${oe.assetsPath}/`}esri/images/search/search-symbol-32.png`,s=(await rt(a,{address:{SingleLine:e},outFields:["Match_addr"]}))?.[0];if(!s?.extent||!s.location)throw new Error(`Could not find location for: ${e}`);let l=new ot({url:n,width:24,height:24}),u=new tt({geometry:s.location,symbol:l});t.graphics.removeAll(),t.graphics.add(u),await t.goTo(s.extent);let c={address:s.address??"",location:s.location?s.location.toJSON():null,extent:s.extent?s.extent.toJSON():null};return{text:`Successfully zoomed to ${e}.`,sharedStatePatch:{lastResolvedLocation:{value:c}}}}var qt=["mapView"];function $(e){let t=e?.configurable?.context;if(!t||typeof t!="object")throw new Error("NavigationAgent context missing");let r=qt.filter(o=>!(o in t));if(r.length)throw new Error(`NavigationAgent context missing: ${r.join(", ")}`);return t}async function zt({address:e},t){let{mapView:r}=$(t);return await _t(e,r)}var jt=i.object({address:i.string().describe("The full address or place name to locate.")}),Li=h(zt,{name:"goToAddress",description:"Geocodes an address using Esri's World Geocoding Service and zooms the map to that location.",schema:jt});async function Lt(e,t){let r=t.map.bookmarks;if(!r||r.length===0)throw new Error("No bookmarks found in the map.");let o=r.find(n=>n.name===e);if(!o)throw new Error(`Bookmark with name "${e}" not found.`);let a=o.viewpoint;if(!a)throw new Error(`Bookmark with name "${e}" does not have a valid viewpoint.`);return await t.goTo(a),{text:`Navigated to bookmark: ${e}`}}async function Ot({bookmarkName:e},t){let{mapView:r}=$(t);return await Promise.resolve(Lt(e,r))}var Dt=I.object({bookmarkName:I.string().describe("The name of the bookmark to navigate to.")}),Oi=h(Ot,{name:"goToBookmark",description:"Go to the extent of the bookmark with the given name.",schema:Dt});async function Pt(e,t,r){let o=r.map?.allLayers.find(s=>s.id===e);if(!o)return{text:`Error: Layer with id ${e} not found`};let a=t?.trim()?t:"1=1",n=o.createQuery();n.where=a;try{let{extent:s,count:l}=await o.queryExtent(n);if(l===0)return{text:`No features found in ${o.title} matching: ${a}`,where:a};if(s)await r.goTo(s);else return{text:`Error: Unable to determine extent for ${o.title}`,where:a};let u={layerId:e,layerTitle:o.title??e,where:a,count:l};return{text:`Successfully zoomed to ${l} feature(s) in ${o.title} matching: ${a}`,where:a,sharedStatePatch:{lastNavigatedFeatures:{value:u}}}}catch(s){return console.error("Error in goToFeatures:",s),{text:`Error: ${s instanceof Error?s.message:"Unknown error"}`,where:a}}}async function Gt({layerId:e,where:t},r){let{mapView:o}=$(r);return await Pt(e,t,o)}var Vt=I.object({layerId:I.string().describe("The layerId of the layer to zoom to."),where:I.string().describe("The sql-92 where clause used to query features to zoom to")}),Di=h(Gt,{name:"goToFeatures",description:"Go to the features that match the given filter related to the given layerId.",schema:Vt});async function Qt(e){let t=new at({xmin:-180,ymin:-90,xmax:180,ymax:90,spatialReference:{wkid:4326}}).expand(.7);return await e.goTo(t),{text:"Successfully zoomed to world extent"}}async function Bt(e,t){let{mapView:r}=$(t);return await Qt(r)}var Ut=I.object({}),Pi=h(Bt,{name:"goToFullExtent",description:"Zooms the map to the full world extent using Esri's Geocoding Service.",schema:Ut});async function Kt(e){let t=e.map.initialViewProperties?.viewpoint?.targetGeometry;if(t)await e.goTo(t);else throw new Error("Initial extent is undefined");return{text:"Successfully zoomed to home extent"}}async function Wt(e,t){let{mapView:r}=$(t);return await Kt(r)}var Ht=i.object({}),Gi=h(Wt,{name:"goToHomeExtent",description:"Go to the initial web map view extent",schema:Ht});async function Jt(e,t){await t.when();let r=t.map?.allLayers.find(a=>a.id===e);if(!r)return console.warn(`[goToLayer] No matching FeatureLayer found for: ${e}`),{text:`Could not find layer for: ${e}`};let o;return(r.type==="link-chart"||r.type==="knowledge-graph-sublayer")&&t.map?.activeLinkChartLayer?o=t.map.diagramNodesExtent:o=r.fullExtent,o?(await t.goTo(o),r.visible=!0,{text:`Successfully zoomed to: ${r.title??""}`}):{text:"Layer has no defined extent. Cannot zoom to layer."}}async function Zt({layerId:e},t){let{mapView:r}=$(t);return await Jt(e,r)}var Yt=I.object({layerId:I.string().describe("The id of the layer to navigate to")}),Vi=h(Zt,{name:"goToLayer",description:"Zooms the map view to the full extent of the top matching layer.",schema:Yt});async function Xt(e,t){return await t.goTo({scale:e}),{text:`Successfully zoomed to: ${e}`}}async function er({scale:e},t){let{mapView:r}=$(t);return await Xt(e,r)}var tr=i.object({scale:i.number().describe("The map scale of the view to go to.")}),Qi=h(er,{name:"goToScale",description:"Go to the specified view scale.",schema:tr});async function rr(e,t,r){let o={target:new Re({longitude:e.longitude,latitude:e.latitude,spatialReference:{wkid:4326}})};return r?.zoom!==void 0&&(o.zoom=r.zoom),r?.scale!==void 0&&(o.scale=r.scale),await t.goTo(o),{text:`Successfully navigated to: ${[`(${e.latitude}\xB0, ${e.longitude}\xB0)`,r?.zoom!==void 0?`zoom ${r.zoom}`:"",r?.scale!==void 0?`scale 1:${r.scale}`:""].filter(Boolean).join(", ")}`}}async function or({center:e,zoom:t,scale:r},o){let{mapView:a}=$(o);return await rr(e,a,{zoom:t,scale:r})}var ar=i.object({center:i.object({longitude:i.number().describe("The longitude (x-coordinate) of the point to navigate to."),latitude:i.number().describe("The latitude (y-coordinate) of the point to navigate to.")}),zoom:i.number().optional().describe("The zoom level. Higher values = more zoomed in."),scale:i.number().optional().describe("The map scale. Alternative to zoom. Smaller numbers = more zoomed in.")}),Bi=h(or,{name:"goToViewpoint",description:"Go to the specified viewpoint. This can contain a combination of scale, center, zoom, etc.",schema:ar});async function nr(e,t){return await t.goTo({zoom:e}),{text:`Successfully zoomed to: ${e}`}}async function ir({zoom:e},t){let{mapView:r}=$(t);return await nr(e,r)}var sr=i.object({zoom:i.number().min(1).max(20).describe("The zoom level of the view to go to.")}),Ui=h(ir,{name:"goToZoom",description:'Go to the specified zoom level. If input is generic (e.g. "zoom in", then only zoom to the next appropriate level - increase level for zooming in and decrease for zooming out.).',schema:sr}),Ae=Object.assign({"../agents/arcgisKnowledge/prompts/arcgis_knowledge_current_lc_context.md":()=>import("./KMQ3SP4I.js").then(e=>e.default),"../agents/arcgisKnowledge/prompts/arcgis_knowledge_current_map_context.md":()=>import("./5QAHYX7Y.js").then(e=>e.default),"../agents/arcgisKnowledge/prompts/arcgis_knowledge_lucene_generation_prompt.md":()=>import("./5ZZGKP7N.js").then(e=>e.default),"../agents/arcgisKnowledge/prompts/arcgis_knowledge_summarize_result_prompt.md":()=>import("./AXDZBBNL.js").then(e=>e.default),"../agents/arcgisKnowledge/prompts/arcgis_knowledge_tool_prompt.md":()=>import("./ZS2TZ6BF.js").then(e=>e.default),"../agents/dataExploration/prompts/data_explore_filter_prompt.md":()=>import("./LQ6R5YRN.js").then(e=>e.default),"../agents/dataExploration/prompts/data_explore_query_prompt.md":()=>import("./X2ZDYHCG.js").then(e=>e.default),"../agents/dataExploration/prompts/summarize_query_response_prompt.md":()=>import("./ZLXN7NMF.js").then(e=>e.default),"../agents/help/prompts/help_prompt.md":()=>import("./F2AHA4GB.js").then(e=>e.default),"../agents/layerStyling/prompts/layer_styling_prompt.md":()=>import("./FX7UOGHP.js").then(e=>e.default),"../agents/navigation/prompts/navigation_intent_prompt.md":()=>import("./NE7E52YR.js").then(e=>e.default),"../agents/navigation/prompts/navigation_tool_prompt.md":()=>import("./6YMR4QSD.js").then(e=>e.default)});async function ne(e){let t=Object.entries(Ae).find(([r])=>r.endsWith(`/${e}.md`));if(!t)throw new Error(`Prompt not found: ${e}
|
|
4
4
|
Available prompts:
|
|
5
5
|
${Object.keys(Ae).join(`
|
|
@@ -115,11 +115,11 @@ ${l}
|
|
|
115
115
|
Explanation: ${u}`):(await n?.map?.allLayers.find(p=>p.type==="knowledge-graph")?.addRecords(d),`Map updated successfully. Cypher Query used:
|
|
116
116
|
${l}
|
|
117
117
|
|
|
118
|
-
Explanation: ${u}`)}var Be="addRecords",xa=i.object({prompt:i.string().describe("The user's inquiry into the knowledge graph that needs to be run.")}),Ea=async({prompt:e},t)=>{let{knowledgeGraph:r}=await G(t),o=X(t),{view:a}=o,n=M.getDefault().helperServices,s=e;if(C(a)){let u=a.map,
|
|
118
|
+
Explanation: ${u}`)}var Be="addRecords",xa=i.object({prompt:i.string().describe("The user's inquiry into the knowledge graph that needs to be run.")}),Ea=async({prompt:e},t)=>{let{knowledgeGraph:r}=await G(t),o=X(t),{view:a}=o,n=M.getDefault().helperServices,s=e;if(!C(a)&&a.map){let u=a.map,c=await ne("arcgis_knowledge_current_lc_context"),d=va(u,r);s=`${e}
|
|
119
119
|
|
|
120
|
-
${
|
|
120
|
+
${c}${JSON.stringify(d)}`}else{let u=a.map,{allNamedTypesFullyDynamic:c,idTypePairs:d,dynamicTypes:p}=Ta(u),m=await ne("arcgis_knowledge_current_map_context");if(s=`${e}
|
|
121
121
|
|
|
122
|
-
${
|
|
122
|
+
${m}${JSON.stringify(d)} and all entities or relationships with the the following typeNames in the array: ${JSON.stringify(p)}`,c)throw new Error("No records have been added to the map because all data in the knowledge graph is contained in the map.")}let l=await Sa(s,r,`${n.aiAssistantServices.url}${n.aiAssistantServices.graphQueryAssistant}`,o,t);return{toolName:Be,status:"success",summary:l}},hs=h(Ea,{name:Be,description:"Adds records (entities or relationships) to the current link chart visualization from an inquiry into the knowledge graph data. The inquiry will retrieve data from the graph database that will serve as the basis for the records to be added to the link chart. The user should have explicitly requested to add records to the current link chart from their prompt.",schema:xa});async function Ia(e,t){return await t.map?.applyLayout(e),await Y(t),`Successfully applied layout: ${e}.`}var ue="applyLayout",$a=i.object({layout:i.enum(["organic-standard","organic-community","basic-grid","hierarchical-bottom-to-top","radial-root-centric","tree-left-to-right","geographic-organic-standard","chronological-mono-timeline","chronological-multi-timeline"]).describe("The layout mode to apply to the link chart. The value must be one of the following: organic-standard, organic-community, basic-grid, hierarchical-bottom-to-top, radial-root-centric, tree-left-to-right, geographic-organic-standard, chronological-mono-timeline, chronological-multi-timeline")}),Na=async({layout:e},t)=>{let{view:r}=X(t);if(C(r))return{toolName:ue,status:"error",errorMessage:"The applyLayout tool can only be used with a LinkChartView.",error:new Error};{let o=await Ia(e,r);return{toolName:ue,status:"success",summary:o}}},fs=h(Na,{name:ue,description:"Apply a diagram layout to the link chart",schema:$a});async function ka(e,t){return t.map?.changeNonspatialDataDisplay(e),await Y(t),`Successfully applied nonspatial visibility setting: ${e}.`}var de="changeNonspatialVisibility",Fa=i.object({setting:i.enum(["hidden","visible"]).describe("The setting of nonspatial visibility")}),Ma=async({setting:e},t)=>{let{view:r}=X(t);if(C(r))return{toolName:de,status:"error",errorMessage:"The changeNonspatialVisibility tool can only be used with a LinkChartView.",error:new Error};{let o=await ka(e,r);return{toolName:de,status:"success",summary:o}}},ys=h(Ma,{name:de,description:"Change whether or not nonspatial data is visible in the link chart. The value must be either 'hidden' or 'visible'.",schema:Fa});async function Aa(e,t,r,o,a){let n;for(let s=1;s<=F;s++){let{graphQuery:l,explanation:u}=await fe(e,t.dataModel,r,a,n);try{await T({text:`Attempting to create link chart from derived query: ${l}`},a);let c=await Mt.fromCypherQuery(t,new ze({openCypherQuery:l}));await T({text:"Link chart created successfully, loading..."},a),await c.load();let d=o.map;return o.map=c,await o.when(),await Ce.whenOnce(()=>!o.updating),c.entityCount===0&&c.relationshipCount===0?(o.map===c&&(o.map=d),c.destroy(),{type:"error",message:`Query returned no results. Cypher Query used to create the link chart:
|
|
123
123
|
${l}
|
|
124
124
|
|
|
125
125
|
Explanation: ${u}`}):(await Y(o),{type:"success",message:`Link chart created successfully. Cypher Query used to create the link chart:
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
+
import{a as I,b as _}from"./7GH7VSB2.js";import{a as P}from"./H7422XUG.js";import"./MH5RPXHM.js";import a from"./DO2P3PWF.js";import{Fb as H,Q as F,W as O,a as D,b as W,eb as j,u as q}from"./462JBSEV.js";import{a as B}from"./AMP6IALT.js";import"./OAVEHGB6.js";import{g as $,h as g,l as A,n as u,t as b,u as E,v as L,w as v,y as M}from"./OH64RMOR.js";import"./YIMNOUTF.js";export default $arcgis.t(([_e,{whenOnce:ke,watch:Ce,when:Re},$e,ee,te,K,se,re,,,Ae,{property:w,subclass:Le},{b:N,e:z,f:m,h:S,i:U,j:V,k:T}])=>{var ie=async s=>{let e=await ne(),t=await N("default"),i=te.getDefault(),r=(await ee.getCredential(`${i.url}/sharing`)).token,n={type:"generateEmbeddings",webmapEmbeddings:s,auth:{apiUrl:t,token:r}};return e.postMessage(n),await new Promise((a,l)=>{let o=d=>{d.data==="completed"&&(e.removeEventListener("message",o),a())},c=d=>{e.removeEventListener("message",o),l(d instanceof Error?d:new Error("Embeddings worker error"))};e.addEventListener("message",o),e.addEventListener("error",c,{once:!0})}),e},ne=async()=>{{let s=(await import("./23EQTPO3.js")).default;return new s}},ae=s=>{s.currentIntent="none"},oe=async(s,e)=>{let t=S(e);if(s.agentExecutionContext.userRequest){let r=new O(s.agentExecutionContext.userRequest.trim());s.agentExecutionContext.messages=[...s.agentExecutionContext.messages,r],ae(s)}let i=t?.services.agentRegistry.list().map(r=>r.agent.id)??[];return await m({text:`Available agents: ${[...i].join(", ")}`},e),await m({text:"Analyzing user input"},e),s},ce=async(s,e)=>(await m({text:"Exiting..."},e),s),G=s=>typeof s=="object"&&s!==null&&!Array.isArray(s),le=(s,e)=>{if(!G(s)){s!==void 0&&console.warn(`Agent "${e}" returned invalid sharedStatePatch. Ignoring it.`);return}let t={};for(let[i,r]of Object.entries(s)){if(!G(r)||!("value"in r)){console.warn(`Agent "${e}" returned invalid sharedStatePatch entry for key "${i}". Ignoring that entry.`);continue}t[i]={value:r.value}}return t},de=s=>{let{previousSharedState:e,patch:t,agentId:i}=s;if(!t)return e;let r=Date.now(),n={...e};for(let[a,l]of Object.entries(t))l?.value!==void 0&&(n[a]={value:l.value,meta:{updatedByAgentId:i,updatedAt:r}});return n},Q=s=>typeof s!="string"?void 0:s.trim()||void 0,ge=s=>{switch(s){case"failed":return"Agent failed without a summary.";case"unknown":return"Agent returned with unknown status.";case"success":return"Agent completed without a summary.";default:return"Agent completed without a summary."}},he=(s,e)=>{let t=Q(e?.outputMessage),i=Q(e?.summary),r=e?.status,n=r==="success"||r==="failed"?r:"unknown";n==="unknown"&&console.warn(`Agent "${s}" returned missing/invalid status. Defaulting to "unknown".`);let a=le(e?.sharedStatePatch,s);return{outputMessage:t,summary:i??t??ge(n),status:n,sharedStatePatch:a}},J=4e3,ue=async(s,e)=>{let t=S(e);if(t?.abortSignal?.aborted)return await m({text:"Run cancelled; skipping agent execution"},e),{...s,currentIntent:"none",requiresFollowUp:!1};let{agentRegistry:i}=t?.services??{},r=i?.get(s.currentIntent);if(!r)return console.warn(`No agent found for intent: ${s.currentIntent}`),s;await m({text:`Executing registered agent: ${r.agent.name}`},e);let n={...e??{},configurable:{...t??{},agentId:r.agent.id,context:r.getContext?await r.getContext():void 0}},a;try{let c=await r.agent.createGraph().compile().invoke({agentExecutionContext:{...s.agentExecutionContext,messages:[...s.agentExecutionContext.messages],priorSteps:structuredClone(s.agentExecutionContext.priorSteps??[]),sharedState:structuredClone(s.agentExecutionContext.sharedState??{})}},n);a=he(r.agent.name,c),await m({text:`Finished executing registered agent: ${r.agent.name}`},e)}catch(c){if(q(c))throw c;let d=c instanceof Error?c.message:String(c);console.error(`Agent "${r.agent.name}" failed:`,c),await m({text:`Registered agent failed: ${r.agent.name}. ${d}`},e),a={status:"failed",outputMessage:`Agent execution failed: ${d}`,summary:`Agent execution failed: ${d}`}}let l=a.outputMessage,o=[...s.agentExecutionContext.messages];if(l){let c=l.length>J?`${l.slice(0,J-14)}
|
|
3
|
+
[truncated]`:l;o.push(new F(c))}return{...s,stepCount:s.stepCount+1,lastExecutedAgent:r.agent.id,requiresFollowUp:a.status==="failed"?!0:s.requiresFollowUp,finalOutputMessage:l??"",agentExecutionContext:{...s.agentExecutionContext,messages:o,priorSteps:[...s.agentExecutionContext.priorSteps??[],{agentId:r.agent.id,assignedTask:s.agentExecutionContext.assignedTask,summary:a?.summary||"No summary provided.",status:a?.status||"unknown"}],sharedState:de({previousSharedState:s.agentExecutionContext.sharedState,patch:a.sharedStatePatch,agentId:r.agent.id})}}},pe=3,me=()=>new H(z).addNode("ingestInput",oe).addNode("intentLLM",V).addNode("executeRegisteredAgent",ue).addNode("exit",ce).addEdge(D,"ingestInput").addEdge("ingestInput","intentLLM").addConditionalEdges("intentLLM",s=>s.currentIntent==="none"||s.currentIntent===s.lastExecutedAgent?"exit":"executeRegisteredAgent").addConditionalEdges("executeRegisteredAgent",s=>s.stepCount>=pe||!s.requiresFollowUp?"exit":"intentLLM").addEdge("exit",W),k=class{constructor(){this.agentRegistry=new Map}register(e){let{agent:t}=e;if(this.agentRegistry.has(t.id))throw new Error(`Duplicate agent id: ${t.id}`);this.agentRegistry.set(t.id,e)}get(e){return this.agentRegistry.get(e)}list(){return[...this.agentRegistry.values()]}},C=class{constructor(e,t){this.graph=e,this.config={...t}}async waitForUser(){return await new Promise((e,t)=>{this.resolveWait=e,this.rejectWait=t})}handle(e,t){try{let i={agentId:e.agentId,id:e.id,payload:t},r=this.graph.streamEvents(null,{...this.config,configurable:{...this.config.configurable,hitlResponse:i},subgraphs:!0,version:"v2"});this.resolveWait?.(r)}catch(i){this.rejectWait?.(i)}finally{this.resolveWait=void 0,this.rejectWait=void 0}}cancel(){this.rejectWait&&(this.rejectWait(new Error("Request cancelled by user.")),this.resolveWait=void 0,this.rejectWait=void 0)}},ye=async s=>{try{return await(await U()).embedDocuments(s)}catch(e){throw console.error("Failed to generate embeddings:",e),e}},X=async(s,e)=>{let t=e.get(s);if(t)return t;let i=await ye([s]);return e.set(s,i[0]),i[0]};async function we(s,e,t,i){let r=`req-${Date.now()}`,n={type:"layerSearch",precomputedEmbedding:i?await X(s,i):void 0,requestId:r,minScore:t};return await new Promise(a=>{let l=o=>{o.data.requestId===r&&a(o.data.results)};e.addEventListener("message",l,{once:!0}),e.postMessage(n)})}function fe(s){let{worker:e}=s;return{async searchLayers({text:t,minScore:i,embeddingCache:r}){return await we(t,e,i,r)}}}var ve=async({combinedQuery:s,layerIds:e,embeddingsWorker:t,minScore:i,topResults:r,embeddingCache:n})=>{let a=`req-${Date.now()}`,l=n?await X(s,n):void 0,o={type:"fieldSearch",layerIdForFieldsSearch:e,precomputedEmbedding:l,requestId:a,minScore:i,topResults:r};return await new Promise(c=>{let d=h=>{if(h.data.requestId!==a)return;let f=h.data.results.map(({layerId:Y,results:Z})=>({layerId:Y,results:Z}));c(f)};t.addEventListener("message",d,{once:!0}),t.postMessage(o)})};function be(s){let{worker:e}=s;return{async searchFields({text:t,layerIds:i,minScore:r,topResults:n,embeddingCache:a}){return await ve({combinedQuery:t,layerIds:i,embeddingsWorker:e,minScore:r,topResults:n,embeddingCache:a})}}}var Ee=s=>{let e=T.safeParse(s);if(!e.success)throw new Error("Embeddings response validation failed. Regenerate embeddings.");return e.data},xe=(s,e)=>{let t=new Map,i=new Map;if(e.allLayers.forEach(r=>{r instanceof se&&i.set(r.id,r)}),s.length!==i.size)throw new Error("Layer count mismatch during registry restoration. Regenerate embeddings.");for(let r of s){let n=i.get(r.id);if(!n)throw new Error(`Layer with ID ${r.id} not found in the original map during registry restoration. Regenerate embeddings.`);if(r.fields.length!==n.fields.length)throw new Error(`Field count mismatch for layer ID ${r.id} during registry restoration. Regenerate embeddings.`);let a={name:r.name,title:r.title,description:r.description},l=new Map;for(let o of r.fields){let c=n.fieldsIndex.get(o.name);if(!c)throw new Error(`Field with name ${o.name} not found in the original layer ${r.id} during registry restoration. Regenerate embeddings.`);l.set(o.name,{name:o.name,alias:n.getFieldAlias(o.name)??o.alias,description:o.description,type:c.type||"unknown",valueType:c.valueType||"unknown",domain:n.getFieldDomain(o.name)??void 0})}t.set(r.id,{layerItem:a,fieldRegistry:l})}return t},Se=async s=>{try{return(await re(s,{responseType:"json"})).data}catch(e){throw new Error(`Failed to fetch data from ${s}: ${String(e)}`)}},Ie=async s=>{let e=s.map;if(!e?.portalItem)throw new Error("WebMap portal item is missing.");let{resources:t}=await e.portalItem.fetchResources(),i=t.find(n=>n.resource.path==="embeddings-v01.json");if(!i?.resource.url)throw new Error("Embeddings resource 'embeddings-v01.json' not found in the webmap portal item.");let r=await Se(i.resource.url);return Ee(r)},x=class s{constructor(){this.orchestratorReady=!1,this.chatHistory=[],this.priorSteps=[],this.sharedState={},this.agentRegistry=new k,this.activeRunId="",this.cancelledRunIds=new Set,this.streamEpoch=0}static async init(e){let t=new s;try{if(e.view?.map){await K.whenOnce(()=>e.view.ready);let i=await Ie(e.view),r=xe(i.layers,e.view.map);t.layersAndFieldsRegistry=r,t.embeddingsWorker=await ie(i)}return e.agents?.forEach(i=>{t.agentRegistry.register(i)}),t.orchestratorReady=!0,t}catch(i){throw console.error("Orchestrator initialization failed:",i),i}}async*ask(e){if(!this.orchestratorReady)throw new Error("Orchestrator is not ready yet.");if(!this.agentRegistry.list().length)throw new Error("Orchestrator has no registered agents.");if(++this.streamEpoch,!e.trim())return;let t=String(Date.now());this.activeRunId=t,this.activeAbortController=new AbortController,this.graph||(this.graph=me().compile({checkpointer:new j}));let i=this.embeddingsWorker?fe({worker:this.embeddingsWorker}):void 0,r=this.embeddingsWorker?be({worker:this.embeddingsWorker}):void 0,n=new Map,a={version:"v2",streamMode:"custom",configurable:{thread_id:t,abortSignal:this.activeAbortController.signal,hitlResponse:null,services:{layerSearch:i,fieldSearch:r,layersAndFieldsRegistry:this.layersAndFieldsRegistry,agentRegistry:this.agentRegistry,embeddingCache:n}},subgraphs:!0},l=this.graph?.streamEvents({agentExecutionContext:{userRequest:e,messages:this.chatHistory,priorSteps:this.priorSteps,sharedState:this.sharedState}},a),o=++this.streamEpoch;if(yield*this.pipeStream(l,o,t),this.isRunCancelled(t)){yield{runId:t,timestamp:Date.now(),type:"cancelled",reason:"user"};return}for(;;){if(this.isRunCancelled(t)){yield{runId:t,timestamp:Date.now(),type:"cancelled",reason:"user"};return}let d=(await this.graph.getState(a,{subgraphs:!0})).tasks.find(h=>h.interrupts.length>0)?.interrupts[0]?.value;if(!d)break;this.currentInterrupt=d,this.interruptHandler=new C(this.graph,a),yield{runId:t,timestamp:Date.now(),type:"interrupt",interrupt:d};try{let h=await this.interruptHandler.waitForUser(),f=++this.streamEpoch;yield*this.pipeStream(h,f,t)}catch(h){if(this.isRunCancelled(t)){yield{runId:t,timestamp:Date.now(),type:"cancelled",reason:"user"};return}if(h){yield{runId:t,timestamp:Date.now(),type:"error",error:{message:h?.message}};return}}}if(this.isRunCancelled(t)){yield{runId:t,timestamp:Date.now(),type:"cancelled",reason:"user"};return}let c=(await this.graph.getState(a,{subgraphs:!0})).values;if(this.isRunCancelled(t)){yield{runId:t,timestamp:Date.now(),type:"cancelled",reason:"user"};return}this.chatHistory=c.agentExecutionContext.messages.length?c.agentExecutionContext.messages:this.chatHistory,this.priorSteps=c.agentExecutionContext.priorSteps?.slice(-5)??[],this.sharedState=c.agentExecutionContext.sharedState??{},yield{runId:t,timestamp:Date.now(),type:"completed",result:{content:c.finalOutputMessage}}}newConversation(){this.chatHistory=[],this.priorSteps=[],this.sharedState={}}resumeInterrupt(e){if(!this.currentInterrupt||!this.interruptHandler)throw new Error("No pending interrupt to resume.");this.interruptHandler.handle(this.currentInterrupt,e)}cancelInterrupt(){this.interruptHandler&&this.interruptHandler.cancel()}cancel(){this.activeRunId&&(this.cancelledRunIds.add(this.activeRunId),this.activeAbortController?.abort(),++this.streamEpoch,this.interruptHandler?.cancel())}async*pipeStream(e,t,i){for await(let r of e){if(this.isRunCancelled(i)||t!==this.streamEpoch)break;r.event==="on_custom_event"&&r.name==="trace_message"?yield{runId:i,timestamp:Date.now(),type:"trace",data:r.data}:r.name==="graph_ux_suggestion"&&(yield{runId:i,timestamp:Date.now(),type:"ux-suggestion",suggestion:r.data})}}isRunCancelled(e){return this.cancelledRunIds.has(e)}dispose(){this.embeddingsWorker&&(this.embeddingsWorker.terminate(),this.embeddingsWorker=void 0),this.orchestratorReady=!1}};var Me=$`:host{display:block;width:var(--arcgis-internal-panel-width, 100%);height:var(--arcgis-internal-expand-max-height, 100%)}.footer-container{display:flex;flex-direction:column;flex:1 1 0;gap:var(--calcite-spacing-md)}.content-container{display:flex;flex-direction:column;flex:1 1 0;min-height:0;position:relative;overflow:auto}.suggested-prompts-container{display:flex;justify-content:center;width:100%}.suggested-prompts{display:block;padding:var(--calcite-spacing-md);max-width:100%;box-sizing:border-box}.error-notice{padding:var(--calcite-spacing-sm)}`,Pe=Object.defineProperty,De=Object.getOwnPropertyDescriptor,y=(s,e,t,i)=>{for(var r=i>1?void 0:i?De(e,t):e,n=s.length-1,a;n>=0;n--)(a=s[n])&&(r=(i?a(e,t,r):a(r))||r);return i&&r&&Pe(e,t,r),r},p=class extends Ae{constructor(s){super(s),this.view=null,this.loading=!1,this.processing=!1,this.processingStep=""}async load(){this._set("loading",!0);try{await this._initialize()}finally{this._set("loading",!1)}}destroy(){this.orchestrator?.dispose(),super.destroy()}async _initialize(){this.removeHandles(),await Promise.all([this.portal.load(),this.view?.when()]),this.view&&await ke(()=>!this.view.updating),this._set("orchestrator",await x.init({agents:[...this.agents],view:this.view??void 0})),this.addHandles([Ce(()=>[this.view,this.agents],()=>{this._initialize()})])}clearChatHistory(){this.orchestrator?.newConversation()}async*ask(s,e){if(!this.orchestrator)throw new Error("Orchestrator not initialized yet.");this._set("processing",!0),this._set("processingStep","");let t=[],i;try{let r=this.orchestrator.ask(s);for await(let n of r){let a=n.runId;if(e?.aborted){yield{type:"cancelled",runId:a};break}switch(n.type){case"trace":{this._set("processingStep",n.data.text),t.push(n.data.text);break}case"completed":{let l=n.result,o=!!l.content.length,c=!!i?.length;if(!o&&!c){yield{type:"completed",error:"Could not process the request.",log:t,runId:a};return}let d=l.content;this._set("processingStep",""),yield{type:"completed",response:d,blocks:i,log:t,runId:a};return}case"ux-suggestion":{let l=n.suggestion;i=i?[...i,l]:[l];break}case"interrupt":{let{kind:l,message:o,metadata:c}=n.interrupt,d=Array.isArray(c)?c.filter(f=>typeof f=="string"):[],h=(()=>{switch(l){case"booleanChoice":return{type:"boolean-choice",message:o,options:d};case"singleSelection":return{type:"single-select",message:o,options:d};case"multipleSelection":return{type:"multi-select",message:o,options:d};case"textInput":return{type:"text-input",message:o};default:return{type:l,message:o,options:d}}})();this._set("processingStep","Waiting for user input..."),yield{type:"interrupt",payload:h,runId:a};break}case"cancelled":{yield{type:"cancelled",runId:a};return}case"error":{yield{type:"completed",error:n.error.message,log:t,runId:a};return}default:{console.warn("Unknown event type:",n);break}}}}catch(r){console.warn("Error during message processing:",r),yield{type:"completed",error:"An error occurred during message processing.",log:t,runId:"error"};return}finally{this._set("processing",!1)}}};y([w({readOnly:!0})],p.prototype,"orchestrator",2);y([w()],p.prototype,"agents",2);y([w()],p.prototype,"portal",2);y([w()],p.prototype,"view",2);y([w({readOnly:!0})],p.prototype,"loading",2);y([w({readOnly:!0})],p.prototype,"processing",2);y([w({readOnly:!0})],p.prototype,"processingStep",2);p=y([Le("OrchestratorController")],p);var We="Embeddings resource 'embeddings-v01.json' not found in the webmap portal item.",qe="Embeddings not found for this web map.",Fe="https://developers.arcgis.com/javascript/latest/agentic-apps/ai-webmap-setup/#embeddings",R=class extends L{constructor(){super(...arguments),this._messages=P({blocking:!0}),this.#e=b(),this.#a=b(),this.#t=b(),this.#s=null,this.#o=new Map,this.#r=$e.getDefault(),this.#i=e=>{e.stopPropagation(),this.cancelInterrupt()},this.#n=e=>{e.stopPropagation();let t=e.detail;this.submitInterrupt(t)},this.#c=e=>{e.stopPropagation(),this.keepSuggestedPrompts||(this.suggestedPrompts=[]);let t=e.detail;this._inputValue="",this.arcgisSubmit.emit(t),this.submitMessage(t)},this.#l=e=>{if(e.stopPropagation(),this.arcgisCancel.emit(),this._interrupt){this.orchestrator?.cancelInterrupt(),this._interrupt=null;return}this.#s?.abort()},this.#d=e=>{e.stopPropagation();let t=e.detail;this.arcgisFeedback.emit(t)},this.#g=e=>{e.stopPropagation();let t=e.detail;this._inputValue=t.prompt,this.arcgisPromptSelect.emit(t)},this.#h=e=>{this.arcgisSlottableRequest.emit(e.detail)},this._orchestratorController=null,this._interrupt=null,this._error=null,this._inputValue="",this.messages=new _e([]),this.referenceElement=null,this.suggestedPrompts=[],this.feedbackEnabled=!1,this.keepSuggestedPrompts=!1,this.logEnabled=!1,this.copyEnabled=!1,this.voiceInputEnabled=!1,this.readAloudEnabled=!1,this.arcgisCancel=u(),this.arcgisError=u(),this.arcgisFeedback=u(),this.arcgisInterrupt=u(),this.arcgisInterruptCancel=u(),this.arcgisInterruptSubmit=u(),this.arcgisPromptSelect=u(),this.arcgisReady=u(),this.arcgisSubmit=u(),this.arcgisSlottableRequest=u({bubbles:!1,composed:!1})}static{this.properties={_orchestratorController:16,_interrupt:16,_error:16,_inputValue:16,_user:16,awaitingResponse:32,awaitingResponseStep:32,interrupt:32,messages:0,orchestrator:32,entryMessage:1,heading:1,description:1,referenceElement:1,suggestedPrompts:0,feedbackEnabled:5,keepSuggestedPrompts:5,logEnabled:5,copyEnabled:5,voiceInputEnabled:5,readAloudEnabled:5}}static{this.styles=Me}#e;#a;#t;#s;#o;#r;#i;#n;#c;#l;#d;#g;#h;async#u(){try{let e=B(this.el,this.referenceElement);await e?.componentOnReady();let t=[...this.#o.values()];return t.length?(this._orchestratorController=new p({agents:t,portal:this.#r,view:e?.view}),await this._orchestratorController.load(),!0):(this._error="No agents found.",!1)}catch(e){return this._error=e?.message??"Error initializing orchestrator.",A(this)(e),!1}}get _user(){return this.#r?.user?.fullName||this.#r?.user?.username}get awaitingResponse(){return this._orchestratorController?.processing??!1}get awaitingResponseStep(){return this._orchestratorController?.processingStep??""}get interrupt(){return this._interrupt}get orchestrator(){return this._orchestratorController?.orchestrator}async clearChatHistory(){this._reset(),this._orchestratorController?.clearChatHistory()}cancelInterrupt(){this.arcgisInterruptCancel.emit(),this.orchestrator?.cancelInterrupt(),this._interrupt=null}register(e){this.#o.set(e.agent.id,e)}async submitMessage(e){let t=e.trim();if(!t||(this.messages.push({id:Date.now().toString(),role:"user",content:t}),!this._orchestratorController))return;let i=this._orchestratorController.ask(t,this.#s?.signal);for await(let r of i){let n=r.runId;switch(r.type){case"completed":this.messages.push({role:"assistant",content:r.response,blocks:r.blocks,log:r.log,error:r.error,id:n});break;case"interrupt":this._interrupt={...r.payload,id:n},this.arcgisInterrupt.emit(this._interrupt);break;case"cancelled":this.messages.push({role:"assistant",error:"Request cancelled.",id:n});break}}}submitInterrupt(e){this.arcgisInterruptSubmit.emit(e),this.orchestrator?.resumeInterrupt(e),this._interrupt=null}load(){this.manager.onLifecycle(this._reset.bind(this))}loaded(){this.manager.onLifecycle(()=>{this.#e.value?.addEventListener("arcgisPromptSelect",this.#g),this.#e.value?.addEventListener("arcgisSubmit",this.#c),this.#e.value?.addEventListener("arcgisCancel",this.#l),this.#e.value?.addEventListener("arcgisFeedback",this.#d);let e=Re(()=>!!this._interrupt&&!!this.#t.value,()=>{let t=this.#t.value;t.removeEventListener("arcgisSubmit",this.#n),t.removeEventListener("arcgisCancel",this.#i),t.addEventListener("arcgisSubmit",this.#n,{once:!0}),t.addEventListener("arcgisCancel",this.#i,{once:!0})});return queueMicrotask(()=>{this.#u().then(t=>{t?this.arcgisReady.emit():this._error&&this.arcgisError.emit(new Error(this._error))})}),()=>{e.remove(),this.#e.value?.removeEventListener("arcgisPromptSelect",this.#g),this.#t.value?.removeEventListener("arcgisSubmit",this.#n),this.#t.value?.removeEventListener("arcgisCancel",this.#i),this.#e.value?.removeEventListener("arcgisSubmit",this.#c),this.#e.value?.removeEventListener("arcgisCancel",this.#l),this.#e.value?.removeEventListener("arcgisFeedback",this.#d),this._orchestratorController?.destroy(),this._orchestratorController=null}})}_reset(){this.#s?.abort(),this._interrupt=null,this.messages.removeAll(),this._error=null,this._inputValue=""}_renderEntryMessage(){return this._interrupt?g`<slot name=interrupt><arcgis-assistant-interrupt .type=${this._interrupt.type} .message=${this._interrupt.message} .options=${this._interrupt.options} ${E(this.#t)}></arcgis-assistant-interrupt></slot>`:this._error?this._renderErrorNotice():this.entryMessage?this.messages.length>0?null:g`<calcite-notice open kind=info closable icon width=full><div slot=message>${this.entryMessage}</div></calcite-notice>`:g`<slot name=entry-message></slot>`}_renderErrorNotice(){return this._error?g`<calcite-notice closable slot=entry-message open kind=danger icon width=full>${this._error===We?g`<div slot=message>${qe}</div><calcite-link slot=link .href=${Fe} target=_blank title="Learn about web map embeddings">Read more</calcite-link>`:g`<div slot=message>${this._error}</div>`}</calcite-notice>`:null}_renderSuggestedPrompts(){return this.suggestedPrompts?.length?g`<div class="suggested-prompts-container"><arcgis-assistant-suggested-prompts class="suggested-prompts" .prompts=${this.suggestedPrompts}></arcgis-assistant-suggested-prompts></div>`:null}render(){return g`<calcite-panel .loading=${!this._orchestratorController&&!this._error||this._orchestratorController?.loading} .heading=${this.heading??this._messages.assistantLabel} .description=${this.description} ${E(this.#e)}><slot name=header-actions-start slot=header-actions-start></slot><slot name=header-actions-end slot=header-actions-end></slot><div class="content-container"><arcgis-assistant-chat .loading=${this.awaitingResponse} .messages=${this.messages}><slot name=message-starter slot=message-starter></slot><slot name=messages slot=messages>${this.messages.map(e=>e.role==="assistant"?g`<arcgis-assistant-message .message=${e} .feedbackEnabled=${this.feedbackEnabled} .logEnabled=${this.logEnabled} .copyEnabled=${this.copyEnabled} .readAloudEnabled=${this.readAloudEnabled} @arcgisSlottableRequest=${this.#h}><slot name=${I(e.id)??v} slot=${I(e.id)??v}>${e?.error?g`<calcite-notice class="error-notice" open icon kind=warning width=full><div slot=message>${e.error}</div></calcite-notice>`:g`<arcgis-assistant-message-text .content=${e?.content}></arcgis-assistant-message-text>`}</slot>${e.blocks?.map((t,i)=>g`<slot name=${_(e.id,i)??v} slot=${_(e.id,i)??v}><arcgis-assistant-message-block .block=${t}></arcgis-assistant-message-block></slot>`)}</arcgis-assistant-message>`:g`<arcgis-assistant-user-message .message=${e} .user=${this._user}></arcgis-assistant-user-message>`)}</slot><slot name=message-loading slot=message-loading><arcgis-assistant-message-loading .loading=${this.awaitingResponse} .loadingMessage=${this.awaitingResponseStep}></arcgis-assistant-message-loading></slot></arcgis-assistant-chat></div>${this._renderSuggestedPrompts()}<div class="footer-container" slot=footer>${this._renderEntryMessage()}<slot name=chat-entry><arcgis-assistant-chat-entry .awaitingResponse=${this.awaitingResponse} .inputValue=${this._inputValue} .messages=${this.messages} .voiceInputEnabled=${this.voiceInputEnabled} ${E(this.#a)}><slot name=entry-actions-start slot=entry-actions-start></slot><slot name=entry-actions-end slot=entry-actions-end><calcite-button .iconStart=${this.awaitingResponse?"circle-stop":"send"} @click=${()=>{this.#a.value?.submitMessage()}} round>${this.awaitingResponse?this._messages.stopButtonLabel:this._messages.askButtonLabel}</calcite-button></slot></arcgis-assistant-chat-entry></slot><slot name=footer-content></slot></div></calcite-panel>`}};M("arcgis-assistant",R);return R},"core/Collection","core/reactiveUtils","portal/Portal","identity/IdentityManager","portal/Portal","core/reactiveUtils","layers/FeatureLayer","request","identity/IdentityManager","layers/FeatureLayer","core/Accessor","core/accessorSupport/decorators",a)
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import c from"./
|
|
2
|
+
import c from"./3WINIQWY.js";import b from"./GJUXVEOF.js";import a from"./DO2P3PWF.js";import{Fb as I,a as w,b as h,q as E}from"./462JBSEV.js";import{a as v,c as F}from"./HB5A5R2E.js";import"./AMP6IALT.js";import"./OAVEHGB6.js";import{v as x,y as S}from"./OH64RMOR.js";import"./YIMNOUTF.js";export default $arcgis.t(([,,,,,,,,,,,,,,,{f:n,n:L},{A:z,B:u,a:$,m:C,o:y,p:N,q:A,r:R,s:T,t:b,u:_,v:V,w:q,x:j,y:k,z:M},D])=>{var B=.7,P=10,J=async(t,r)=>{try{await n({text:"Similarity search to find fields"},r);let e=y(r,"fieldSearch"),i=y(r,"layersAndFieldsRegistry"),o=y(r,"embeddingCache"),a=await e.searchFields({text:t.agentExecutionContext.assignedTask,layerIds:t.vectorSearchLayerIds,minScore:B,topResults:P,embeddingCache:o}),m=a.map(({layerId:c,results:d})=>{let g=d.map(s=>` - ${s.name} (${s.score.toFixed(2)})`).join(`
|
|
3
3
|
`);return`${i.get(c)?.layerItem.name??c}:
|
|
4
4
|
${g}`}).join(`
|
|
5
5
|
`),l;return a.length>0?l=`Vector search completed. Matching layers and fields with scores:
|
package/dist/cdn/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/* COPYRIGHT Esri - https://js.arcgis.com/5.2/LICENSE.txt */
|
|
2
|
-
import{p as s,x as e}from"./OH64RMOR.js";import"./YIMNOUTF.js";var a=s(e,{"arcgis-assistant":[()=>import("./
|
|
2
|
+
import{p as s,x as e}from"./OH64RMOR.js";import"./YIMNOUTF.js";var a=s(e,{"arcgis-assistant":[()=>import("./J5CMRCPS.js"),"_messages:,awaitingResponse:,awaitingResponseStep:,copyEnabled,description,entryMessage,feedbackEnabled,heading,interrupt:,keepSuggestedPrompts,logEnabled,messages:,orchestrator:,readAloudEnabled,referenceElement,suggestedPrompts:,voiceInputEnabled;clearChatHistory,submitMessage;cancelInterrupt,register,submitInterrupt"],"arcgis-assistant-agent":[()=>import("./FX5JFRDL.js"),"agent:,context:;getContext"],"arcgis-assistant-data-exploration-agent":[()=>import("./GBNUMN4J.js"),"referenceElement;;getContext"],"arcgis-assistant-help-agent":[()=>import("./ERBQSEPQ.js"),"referenceElement;;getContext"],"arcgis-assistant-knowledge-agent":[()=>import("./CXWBEDXN.js"),"context:,referenceElement,serviceUrl;getContext"],"arcgis-assistant-layer-styling-agent":[()=>import("./M6F4MXDK.js"),"referenceElement;;getContext"],"arcgis-assistant-navigation-agent":[()=>import("./3BKUCFKS.js"),"referenceElement;;getContext"],"arcgis-assistant-chat":[()=>import("./NVI3I46B.js"),"loading,messages:"],"arcgis-assistant-chat-entry":[()=>import("./7PLV4QH6.js"),"_messages:,awaitingResponse,entryPlaceholder,inputValue,keyboardShortcutsDisabled,messages:,status,voiceInputEnabled;submitMessage"],"arcgis-assistant-interrupt":[()=>import("./Y333DGV6.js"),"_messages:,message,options:,type"],"arcgis-assistant-message":[()=>import("./USMDJUFS.js"),"copyEnabled,feedbackEnabled,footerDisabled,logEnabled,message:,readAloudEnabled"],"arcgis-assistant-message-block":[()=>import("./SXDLXCIM.js"),"block:"],"arcgis-assistant-message-feedback":[()=>import("./V2P4AIGG.js"),"_messages:,feedbackEnabled,message:"],"arcgis-assistant-message-footer":[()=>import("./3PKJWIC3.js"),"_messages:,copyEnabled,feedbackEnabled,logEnabled,message:,readAloudEnabled"],"arcgis-assistant-message-loading":[()=>import("./2AXF774U.js"),"loading,loadingMessage"],"arcgis-assistant-message-log":[()=>import("./P6OPJQMC.js"),"log:,logEnabled,showLog"],"arcgis-assistant-message-read-aloud":[()=>import("./DHOVCT6R.js"),"_messages:,message:,readAloudEnabled"],"arcgis-assistant-message-text":[()=>import("./AO7BQHKC.js"),"content"],"arcgis-assistant-speech-input":[()=>import("./QR54T33D.js"),"awaitingResponse,inputValue,language,mode;;clearDraftSession"],"arcgis-assistant-suggested-prompts":[()=>import("./7BCR6TUO.js"),"_messages:,label,prompts:"],"arcgis-assistant-user-message":[()=>import("./DDLZOMUY.js"),"content,message:,user"]});a({resourcesUrl:import.meta.url});var t=new CSSStyleSheet;t.replaceSync("@layer{:not([hydrated]):is(arcgis-assistant,arcgis-assistant-agent,arcgis-assistant-data-exploration-agent,arcgis-assistant-help-agent,arcgis-assistant-knowledge-agent,arcgis-assistant-layer-styling-agent,arcgis-assistant-navigation-agent,arcgis-assistant-chat,arcgis-assistant-chat-entry,arcgis-assistant-interrupt,arcgis-assistant-message-block,arcgis-assistant-message-feedback,arcgis-assistant-message-footer,arcgis-assistant-message-loading,arcgis-assistant-message-log,arcgis-assistant-message-read-aloud,arcgis-assistant-message-text,arcgis-assistant-speech-input,arcgis-assistant-suggested-prompts,arcgis-assistant-user-message){visibility:hidden}}");document.adoptedStyleSheets=[...document.adoptedStyleSheets,t];window.$arcgis||Object.defineProperty(window,"$arcgis",{configurable:!1,enumerable:!0,writable:!1,value:{}}),((a,r)=>{a.t=(c,...x)=>Promise.all(x.map(x=>x.then?x:(!a?.forceESM&&a?.import||(x=>import(x+".js").then(m=>m.default??m)))("@arcgis/core/"+x))).then(c);r.p=a.t(([m])=>{r.t=m.trackAccess;r.o=m.createObservable;r.c=m.createTrackingTarget;r.r=m.runTracked},"applications/Components/reactiveUtils")})($arcgis,e)
|
package/dist/chunks/adapter.js
CHANGED
|
@@ -2560,7 +2560,12 @@ const Ee = "addRecords", ia = i.object({
|
|
|
2560
2560
|
}), sa = async ({ prompt: e }, t) => {
|
|
2561
2561
|
const { knowledgeGraph: r } = await G(t), o = H(t), { view: a } = o, s = k.getDefault().helperServices;
|
|
2562
2562
|
let c = e;
|
|
2563
|
-
if (z(a)) {
|
|
2563
|
+
if (!z(a) && a.map) {
|
|
2564
|
+
const l = a.map, d = await Y("arcgis_knowledge_current_lc_context"), p = oa(l, r);
|
|
2565
|
+
c = `${e}
|
|
2566
|
+
|
|
2567
|
+
${d}${JSON.stringify(p)}`;
|
|
2568
|
+
} else {
|
|
2564
2569
|
const l = a.map, { allNamedTypesFullyDynamic: d, idTypePairs: p, dynamicTypes: h } = aa(l), m = await Y("arcgis_knowledge_current_map_context");
|
|
2565
2570
|
if (c = `${e}
|
|
2566
2571
|
|
|
@@ -2568,11 +2573,6 @@ ${m}${JSON.stringify(p)} and all entities or relationships with the the followin
|
|
|
2568
2573
|
throw new Error(
|
|
2569
2574
|
"No records have been added to the map because all data in the knowledge graph is contained in the map."
|
|
2570
2575
|
);
|
|
2571
|
-
} else {
|
|
2572
|
-
const l = a.map, d = await Y("arcgis_knowledge_current_lc_context"), p = oa(l, r);
|
|
2573
|
-
c = `${e}
|
|
2574
|
-
|
|
2575
|
-
${d}${JSON.stringify(p)}`;
|
|
2576
2576
|
}
|
|
2577
2577
|
const u = await na(
|
|
2578
2578
|
c,
|