1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048 |
- import {
- d as d3,
- s as s3
- } from "./chunk-FJ72FJKM.js";
- import {
- c2 as c,
- d2,
- f,
- m as m2,
- x as x3,
- z
- } from "./chunk-3RTOMVBL.js";
- import {
- e as e4
- } from "./chunk-YR7YKE3S.js";
- import {
- v
- } from "./chunk-GSORSXL5.js";
- import {
- i
- } from "./chunk-EAUVYZHD.js";
- import {
- f as f2,
- u as u2
- } from "./chunk-MNZXIBJ7.js";
- import {
- h as h2
- } from "./chunk-YJKEIUMW.js";
- import {
- S
- } from "./chunk-WFSV2B2I.js";
- import {
- o as o2
- } from "./chunk-AMQJEM7V.js";
- import {
- l as l2
- } from "./chunk-LMCIAW5S.js";
- import {
- l as l3
- } from "./chunk-6RAL4JPQ.js";
- import {
- l as l4
- } from "./chunk-4E6K4P67.js";
- import {
- w as w2,
- y as y2
- } from "./chunk-GD5TMIPM.js";
- import {
- u
- } from "./chunk-VEAEIBHK.js";
- import {
- x as x2
- } from "./chunk-2VFJVI2I.js";
- import {
- e as e3
- } from "./chunk-FIYKFRB2.js";
- import {
- g as g4
- } from "./chunk-RZFGRBD7.js";
- import {
- b as b2
- } from "./chunk-UD63WBG3.js";
- import {
- a as a2,
- h,
- j as j3,
- l,
- w
- } from "./chunk-YIS6BAC3.js";
- import {
- g as g2
- } from "./chunk-PSV473TI.js";
- import {
- A,
- F,
- I,
- N,
- V,
- _ as _2,
- de,
- g as g3,
- j as j4,
- y as y3
- } from "./chunk-WZQZRKNH.js";
- import {
- a as a3
- } from "./chunk-LRDX4TO7.js";
- import {
- _
- } from "./chunk-YBSUITLL.js";
- import {
- j as j2
- } from "./chunk-ALDCDSPV.js";
- import {
- M2 as M
- } from "./chunk-ECW2QABR.js";
- import {
- d,
- e,
- n2 as n,
- y3 as y
- } from "./chunk-Y3WMVFTW.js";
- import {
- D,
- E,
- b,
- g,
- j,
- r as r2,
- x
- } from "./chunk-ULGDPLM2.js";
- import {
- s,
- s3 as s2
- } from "./chunk-EMJ4ZSM2.js";
- import {
- m
- } from "./chunk-IKP3YN53.js";
- import {
- a,
- e as e2,
- o,
- r,
- t
- } from "./chunk-GZT4BVFP.js";
- // node_modules/@arcgis/core/AggregateGraphic.js
- var p = class extends g4 {
- constructor() {
- super(...arguments), this.isAggregate = true;
- }
- getEffectivePopupTemplate(e6 = false) {
- if (this.popupTemplate)
- return this.popupTemplate;
- const r3 = this.sourceLayer && this.sourceLayer.featureReduction;
- return r3 && "popupTemplate" in r3 && r3.popupEnabled ? r3.popupTemplate : null;
- }
- getObjectId() {
- return this.objectId;
- }
- };
- e([d({ type: Boolean })], p.prototype, "isAggregate", void 0), e([d({ type: [String, Number], json: { read: true } })], p.prototype, "objectId", void 0), p = e([n("esri.AggregateGraphic")], p);
- var s4 = p;
- // node_modules/@arcgis/core/layers/effects/FeatureEffectView.js
- var o3 = class extends y {
- constructor(e6) {
- super(e6), this._filter = null, this.duration = a("mapview-transitions-duration"), this._excludedEffectView = new h2(e6), this._includedEffectView = new h2(e6);
- }
- get excludedEffects() {
- return this._excludedEffectView.effects;
- }
- set featureEffect(e6) {
- this._get("featureEffect") !== e6 && this._transitionTo(e6);
- }
- get filter() {
- return this._filter || e2(this.featureEffect)?.filter || null;
- }
- get hasEffects() {
- return this._excludedEffectView.hasEffects || this._includedEffectView.hasEffects;
- }
- get includedEffects() {
- return this._includedEffectView.effects;
- }
- set scale(e6) {
- this._set("scale", e6), this._excludedEffectView.scale = e6, this._includedEffectView.scale = e6;
- }
- get transitioning() {
- return this._excludedEffectView.transitioning || this._includedEffectView.transitioning;
- }
- transitionStep(e6, t2) {
- this._set("scale", t2), this.transitioning ? (this._includedEffectView.transitionStep(e6, t2), this._excludedEffectView.transitionStep(e6, t2), this.transitioning || (this._filter = null)) : (this._excludedEffectView.scale = t2, this._includedEffectView.scale = t2);
- }
- end() {
- this._includedEffectView.end(), this._excludedEffectView.end(), this._filter = null;
- }
- _transitionTo(e6) {
- const t2 = this._get("featureEffect"), i3 = e2(e6), f3 = e2(i3?.includedEffect), c4 = e2(i3?.excludedEffect), r3 = this._includedEffectView.canTransitionTo(f3) && this._excludedEffectView.canTransitionTo(c4);
- this._includedEffectView.effect = f3, this._excludedEffectView.effect = c4, this._set("featureEffect", i3), this._filter = i3?.filter || t2?.filter || null, r3 || this.end();
- }
- };
- e([d()], o3.prototype, "_filter", void 0), e([d()], o3.prototype, "_excludedEffectView", void 0), e([d()], o3.prototype, "_includedEffectView", void 0), e([d()], o3.prototype, "duration", void 0), e([d()], o3.prototype, "excludedEffects", null), e([d()], o3.prototype, "featureEffect", null), e([d()], o3.prototype, "filter", null), e([d()], o3.prototype, "hasEffects", null), e([d()], o3.prototype, "includedEffects", null), e([d({ value: 0 })], o3.prototype, "scale", null), e([d()], o3.prototype, "transitioning", null), o3 = e([n("esri.layers.effects.FeatureEffectView")], o3);
- var n2 = o3;
- // node_modules/@arcgis/core/views/2d/layers/features/tileRenderers.js
- async function e5(e6, r3) {
- if (!e6)
- return null;
- switch (e6.type) {
- case "symbol":
- return new (await import("./SymbolTileRenderer-5NOPNHXV.js")).default(r3);
- case "heatmap":
- return new (await import("./HeatmapTileRenderer-3ZS5N3L7.js")).default(r3);
- }
- }
- // node_modules/@arcgis/core/views/2d/layers/support/FeatureCommandQueue.js
- function a4(e6) {
- return e6.some((e7) => e7.globalId);
- }
- function d4(e6) {
- return e6.filter((e7) => !e7.error).map((e7) => e7.objectId ?? e7.globalId);
- }
- function i2(e6, r3) {
- const s6 = new Set(e6);
- for (const t2 of r3.values())
- s6.add(t2);
- return s6;
- }
- function n3(e6, r3) {
- const s6 = new Set(e6);
- for (const t2 of r3.values())
- s6.delete(t2);
- return s6;
- }
- var c2 = class extends y {
- constructor(e6) {
- super(e6), this._hasGlobalIds = false;
- }
- normalizeCtorArgs(e6) {
- return this._queueProcessor = new l2({ concurrency: 1, process: e6.process }), {};
- }
- destroy() {
- this.clear();
- }
- get updating() {
- return this._queueProcessor.length > 0;
- }
- clear() {
- this._queueProcessor.clear();
- }
- push(e6) {
- const r3 = this._queueProcessor, s6 = r3.last();
- switch (e6.type) {
- case "update":
- case "refresh":
- if (s6?.type === e6.type)
- return;
- r3.push(e6).finally(() => this.notifyChange("updating"));
- break;
- case "edit": {
- const t2 = s6?.type === "processed-edit" ? s6 : null;
- t2 && r3.popLast();
- const o4 = this._mergeEdits(t2, e6);
- for (const e7 of o4)
- r3.push(e7).finally(() => this.notifyChange("updating"));
- break;
- }
- }
- this.notifyChange("updating");
- }
- _mergeEdits(e6, r3) {
- const { addedFeatures: s6, deletedFeatures: t2, updatedFeatures: o4 } = r3.edits;
- if (this._hasGlobalIds = this._hasGlobalIds || a4(s6) || a4(o4) || a4(t2), this._hasGlobalIds) {
- return [e6, { type: "processed-edit", edits: { addOrModified: [...s6, ...o4], removed: t2 } }];
- }
- const c4 = new Set(d4(e6?.edits.addOrModified ?? [])), u5 = new Set(d4(e6?.edits.removed ?? [])), p2 = new Set([...d4(s6), ...d4(o4)]), l7 = new Set(d4(t2));
- return [{ type: "processed-edit", edits: { addOrModified: Array.from(i2(n3(c4, l7), p2)).map((e7) => ({ objectId: e7 })), removed: Array.from(i2(n3(u5, p2), l7)).map((e7) => ({ objectId: e7 })) } }];
- }
- };
- e([d({ readOnly: true })], c2.prototype, "updating", null), c2 = e([n("esri.views.2d.layers.support.FeatureCommandQueue")], c2);
- var u3 = c2;
- // node_modules/@arcgis/core/views/2d/layers/support/FeatureLayerProxy.js
- function c3(e6) {
- return Array.isArray(e6);
- }
- var l5 = class extends _ {
- constructor(e6) {
- super(e6), this._startupResolver = D(), this.isReady = false;
- }
- initialize() {
- this._controller = new AbortController(), this.addResolvingPromise(this._startWorker(this._controller.signal));
- }
- destroy() {
- this._controller.abort(), this._connection && this._connection.close();
- }
- set tileRenderer(e6) {
- this.client.tileRenderer = e6;
- }
- get closed() {
- return this._connection.closed;
- }
- async startup(e6, t2, r3, s6) {
- await this.when();
- const o4 = this._controller.signal, i3 = c3(r3.source) ? { transferList: r3.source, signal: o4 } : void 0, n4 = { service: r3, config: t2, tileInfo: e6.tileInfo.toJSON(), tiles: s6 };
- await this._connection.invoke("startup", n4, i3), this._startupResolver.resolve(), this._set("isReady", true);
- }
- async updateTiles(e6) {
- return await this._startupResolver.promise, j(this._connection.invoke("updateTiles", e6));
- }
- async update(e6) {
- const t2 = { config: e6 };
- return await this._startupResolver.promise, this._connection.invoke("update", t2);
- }
- async applyUpdate(e6) {
- return await this._startupResolver.promise, this._connection.invoke("applyUpdate", e6);
- }
- async setHighlight(e6) {
- return await this._startupResolver.promise, j(this._connection.invoke("controller.setHighlight", e6));
- }
- async stop() {
- if (await this._startupResolver.promise, !this.closed)
- return j(this._connection.invoke("stop"));
- }
- async refresh(e6) {
- return await this._startupResolver.promise, j(this._connection.invoke("controller.refresh", e6));
- }
- async querySummaryStatistics(e6, t2, r3) {
- return await this._startupResolver.promise, this._connection.invoke("controller.querySummaryStatistics", { query: e6.toJSON(), params: t2 }, r3);
- }
- async queryUniqueValues(e6, t2, r3) {
- return await this._startupResolver.promise, this._connection.invoke("controller.queryUniqueValues", { query: e6.toJSON(), params: t2 }, r3);
- }
- async queryClassBreaks(e6, t2, r3) {
- return await this._startupResolver.promise, this._connection.invoke("controller.queryClassBreaks", { query: e6.toJSON(), params: t2 }, r3);
- }
- async queryHistogram(e6, t2, r3) {
- return await this._startupResolver.promise, this._connection.invoke("controller.queryHistogram", { query: e6.toJSON(), params: t2 }, r3);
- }
- async queryFeatures(e6, t2) {
- return await this._startupResolver.promise, this._connection.invoke("controller.queryFeatures", e6.toJSON(), t2);
- }
- async queryVisibleFeatures(e6, t2) {
- return await this._startupResolver.promise, this._connection.invoke("controller.queryVisibleFeatures", e6.toJSON(), t2);
- }
- async queryObjectIds(e6, t2) {
- return await this._startupResolver.promise, this._connection.invoke("controller.queryObjectIds", e6.toJSON(), t2);
- }
- async queryFeatureCount(e6, t2) {
- return await this._startupResolver.promise, this._connection.invoke("controller.queryFeatureCount", e6.toJSON(), t2);
- }
- async queryExtent(e6, t2) {
- return this._connection.invoke("controller.queryExtent", e6.toJSON(), t2);
- }
- async queryLatestObservations(e6, t2) {
- return await this._startupResolver.promise, this._connection.invoke("controller.queryLatestObservations", e6.toJSON(), t2);
- }
- async queryStatistics(e6) {
- return await this._startupResolver.promise, this._connection.invoke("controller.queryStatistics", e6);
- }
- async getObjectId(e6) {
- return await this._startupResolver.promise, this._connection.invoke("controller.getObjectId", e6);
- }
- async getDisplayId(e6) {
- return await this._startupResolver.promise, this._connection.invoke("controller.getDisplayId", e6);
- }
- async getFeatures(e6) {
- return await this._startupResolver.promise, this._connection.invoke("controller.getFeatures", e6);
- }
- async getAggregates() {
- return await this._startupResolver.promise, this._connection.invoke("controller.getAggregates");
- }
- async getAggregateValueRanges() {
- return await this._startupResolver.promise, this._connection.invoke("controller.getAggregateValueRanges");
- }
- async mapValidDisplayIds(e6) {
- return await this._startupResolver.promise, this._connection.invoke("controller.mapValidDisplayIds", e6);
- }
- async onEdits(e6) {
- return await this._startupResolver.promise, j(this._connection.invoke("controller.onEdits", e6));
- }
- async enableEvent(e6, t2) {
- return await this._startupResolver.promise, j(this._connection.invoke("controller.enableEvent", { name: e6, value: t2 }));
- }
- pauseStream() {
- return j(this._connection.invoke("controller.pauseStream"));
- }
- resumeStream() {
- return j(this._connection.invoke("controller.resumeStream"));
- }
- async _startWorker(e6) {
- try {
- this._connection = await u("Pipeline", { client: this.client, strategy: "dedicated", signal: e6 });
- } catch (t2) {
- b(t2);
- }
- }
- };
- e([d()], l5.prototype, "isReady", void 0), e([d()], l5.prototype, "client", void 0), e([d()], l5.prototype, "tileRenderer", null), l5 = e([n("esri.views.2d.layers.support.FeatureLayerProxy")], l5);
- var u4 = l5;
- // node_modules/@arcgis/core/views/2d/tiling/TileManager.js
- var l6 = 1e-6;
- var s5 = class {
- constructor(e6) {
- this._tiles = new Map(), this.buffer = 0, this.acquireTile = e6.acquireTile, this.releaseTile = e6.releaseTile, this.tileInfoView = e6.tileInfoView, this.buffer = e6.buffer;
- }
- destroy() {
- }
- clear() {
- this._tiles.forEach((e6) => this._releaseTile(e6));
- }
- tileKeys() {
- const e6 = [];
- return this._tiles.forEach((i3, t2) => e6.push(t2)), e6;
- }
- update(e6) {
- const l7 = this.tileInfoView.getTileCoverage(e6.state, this.buffer, "closest"), { spans: s6, lodInfo: r3 } = l7, { level: a5 } = r3, o4 = [], d5 = [], h3 = new Set(), n4 = new Set();
- for (const { row: i3, colFrom: c4, colTo: f3 } of s6)
- for (let e7 = c4; e7 <= f3; e7++) {
- const l8 = e3.getId(a5, i3, r3.normalizeCol(e7), r3.getWorldForColumn(e7)), s7 = this._getOrAcquireTile(o4, l8);
- h3.add(l8), s7.isReady ? s7.visible = true : n4.add(s7.key);
- }
- n4.forEach((e7) => this._addPlaceholders(h3, e7)), this._tiles.forEach((e7) => {
- h3.has(e7.key.id) || (d5.push(e7.key.id), this._releaseTile(e7));
- }), l3.pool.release(l7);
- return { hasMissingTiles: n4.size > 0, added: o4, removed: d5 };
- }
- _getOrAcquireTile(e6, i3) {
- if (!this._tiles.has(i3)) {
- const l7 = this.acquireTile(new e3(i3));
- e6.push(i3), this._tiles.set(i3, l7), l7.visible = false;
- }
- return this._tiles.get(i3);
- }
- _getTile(e6) {
- return this._tiles.get(e6);
- }
- _releaseTile(e6) {
- this._tiles.delete(e6.key.id), this.releaseTile(e6);
- }
- _addPlaceholders(e6, i3) {
- const t2 = this._addPlaceholderChildren(e6, i3);
- if (!(Math.abs(1 - t2) < l6)) {
- if (!this._addPlaceholderParent(e6, i3)) {
- this._getTile(i3.id).visible = true;
- }
- }
- }
- _addPlaceholderChildren(e6, i3) {
- let t2 = 0;
- return this._tiles.forEach((l7) => {
- t2 += this._addPlaceholderChild(e6, l7, i3);
- }), t2;
- }
- _addPlaceholderChild(e6, i3, t2) {
- if (i3.key.level <= t2.level || !i3.hasData || !t2.contains(i3.key))
- return 0;
- i3.visible = true, e6.add(i3.key.id);
- return 1 / (1 << 2 * (i3.key.level - t2.level));
- }
- _addPlaceholderParent(i3, t2) {
- let l7 = t2.getParentKey(), s6 = 0, r3 = null;
- for (; r(l7); ) {
- if (i3.has(l7.id))
- return true;
- const e6 = this._getTile(l7.id);
- if (e6?.isReady)
- return e6.visible = true, i3.add(e6.key.id), true;
- e6?.hasData && e6.patchCount > s6 && (s6 = e6.patchCount, r3 = e6), l7 = l7.getParentKey();
- }
- return !!r3 && (r3.visible = true, i3.add(r3.key.id), true);
- }
- };
- // node_modules/@arcgis/core/views/layers/FeatureLayerView.js
- var O = s.getLogger("esri.views.layers.FeatureLayerView");
- var A2 = (i3) => {
- let A4 = class extends i3 {
- constructor(...e6) {
- super(...e6), this._updatingRequiredFieldsPromise = null, this.filter = null, this.timeExtent = null, this.layer = null, this.requiredFields = [], this.view = null;
- }
- initialize() {
- this.handles.add([l(() => {
- const e6 = this.layer;
- return [e6?.elevationInfo?.featureExpressionInfo, e6?.displayField, e6?.timeInfo, e6 && "renderer" in e6 && e6.renderer, e6 && "labelingInfo" in e6 && e6.labelingInfo, e6 && "floorInfo" in e6 && e6.floorInfo, this.filter, this.featureEffect, this.timeExtent];
- }, () => this._handleRequiredFieldsChange(), w), a2(() => this.view?.floors, "change", () => this._handleRequiredFieldsChange()), a2(() => {
- const e6 = this.layer;
- return e6 && "sublayers" in e6 && e6.sublayers;
- }, "change", () => this._handleRequiredFieldsChange())]);
- }
- get availableFields() {
- const { layer: e6, layer: { fieldsIndex: t2 }, requiredFields: r3 } = this;
- return "outFields" in e6 && e6.outFields ? y3(t2, [...I(t2, e6.outFields), ...r3]) : y3(t2, r3);
- }
- set effect(e6) {
- r2(O, "effect", { replacement: "featureEffect", version: "4.22" }), this.featureEffect = e6;
- }
- get effect() {
- return r2(O, "effect", { replacement: "featureEffect", version: "4.22" }), this.featureEffect;
- }
- get featureEffect() {
- return this.layer && "featureEffect" in this.layer ? this.layer.featureEffect : null;
- }
- set featureEffect(e6) {
- e6 !== void 0 ? this._override("featureEffect", e6) : this._clearOverride("featureEffect");
- }
- get maximumNumberOfFeatures() {
- return 0;
- }
- set maximumNumberOfFeatures(e6) {
- O.error("#maximumNumberOfFeatures=", "Setting maximum number of features is not supported");
- }
- get maximumNumberOfFeaturesExceeded() {
- return false;
- }
- highlight(e6) {
- throw new Error("missing implementation");
- }
- createQuery() {
- const e6 = { outFields: ["*"], returnGeometry: true, outSpatialReference: this.view.spatialReference }, t2 = r(this.filter) ? this.filter.createQuery(e6) : new b2(e6);
- if (this.layer.type === "feature") {
- const e7 = o2(this);
- r(e7) && (t2.where = t2.where ? `(${t2.where}) AND (${e7})` : e7);
- }
- return r(this.timeExtent) && (t2.timeExtent = r(t2.timeExtent) ? t2.timeExtent.intersection(this.timeExtent) : this.timeExtent.clone()), t2;
- }
- queryFeatures(e6, t2) {
- throw new Error("missing implementation");
- }
- queryObjectIds(e6, t2) {
- throw new Error("missing implementation");
- }
- queryFeatureCount(e6, t2) {
- throw new Error("missing implementation");
- }
- queryExtent(e6, t2) {
- throw new Error("missing implementation");
- }
- async fetchPopupFeatures(e6, t2) {
- const r3 = this.validateFetchPopupFeatures(t2);
- if (r3)
- throw r3;
- return this.fetchClientPopupFeatures(t2);
- }
- _loadArcadeModules(e6) {
- if (e6.get("expressionInfos.length") || Array.isArray(e6.content) && e6.content.some((e7) => e7.type === "expression"))
- return a3();
- }
- _handleRequiredFieldsChange() {
- const e6 = this._updateRequiredFields();
- this._set("_updatingRequiredFieldsPromise", e6), e6.then(() => {
- this._updatingRequiredFieldsPromise === e6 && this._set("_updatingRequiredFieldsPromise", null);
- });
- }
- async _updateRequiredFields() {
- if (!this.layer || !this.view)
- return;
- const e6 = this.view.type === "3d", { layer: t2, layer: { fieldsIndex: r3, objectIdField: i4 } } = this, o4 = "renderer" in t2 && t2.renderer, a5 = "orderBy" in t2 && t2.orderBy, l7 = t2.featureReduction, u5 = new Set(), p2 = await E([o4 ? o4.collectRequiredFields(u5, r3) : null, j4(u5, t2), e6 ? A(u5, t2) : null, r(this.filter) ? V(u5, t2, this.filter) : null, r(this.featureEffect) ? V(u5, t2, this.featureEffect.filter) : null, l7 ? N(u5, t2, l7) : null, a5 ? _2(u5, t2, a5) : null]);
- if (t2.timeInfo && this.timeExtent && g3(u5, t2.fieldsIndex, [t2.timeInfo.startField, t2.timeInfo.endField]), t2.type === "feature" && t2.floorInfo && g3(u5, t2.fieldsIndex, [t2.floorInfo.floorField]), t2.type === "subtype-group") {
- F(u5, r3, t2.subtypeField);
- const e7 = t2.sublayers.map((e8) => Promise.all([e8.renderer?.collectRequiredFields(u5, r3), j4(u5, e8)]));
- await E(e7);
- }
- for (const s6 of p2)
- s6.error && O.error(s6.error);
- F(u5, r3, i4), e6 && "displayField" in t2 && t2.displayField && F(u5, r3, t2.displayField);
- const f3 = Array.from(u5).sort();
- this._set("requiredFields", f3);
- }
- validateFetchPopupFeatures(e6) {
- if (t(e6))
- return null;
- for (const t2 of e6.clientGraphics) {
- const i4 = t2.layer;
- if ("popupEnabled" in i4 && !i4.popupEnabled)
- return new s2("featurelayerview:fetchPopupFeatures", "Popups are disabled", { layer: i4 });
- if (t2.isAggregate) {
- if (!(i4.featureReduction && "popupTemplate" in i4.featureReduction && i4.featureReduction.popupEnabled && i4.featureReduction.popupTemplate))
- return new s2("featurelayerview:fetchPopupFeatures", "Popups are disabled", { layer: i4 });
- } else if ("popupTemplate" in i4) {
- if (!s3(i4, e6))
- return new s2("featurelayerview:fetchPopupFeatures", "Layer does not define a popup template", { layer: i4 });
- }
- }
- }
- async fetchClientPopupFeatures(e6) {
- const t2 = r(e6) ? e6.clientGraphics : null;
- if (!t2 || t2.length === 0)
- return [];
- const r3 = new Array(t2.length), i4 = new Map(), n4 = await this.createPopupQuery(e6);
- for (let s6 = 0; s6 < t2.length; s6++) {
- const a5 = t2[s6];
- if (a5.isAggregate) {
- r3[s6] = a5;
- continue;
- }
- const { layer: l7 } = a5;
- if (!("popupEnabled" in l7))
- continue;
- const u5 = I(this.layer.fieldsIndex, n4.outFields), p2 = s3(l7, e6);
- if (t(p2))
- continue;
- const f3 = await this._loadArcadeModules(p2);
- f3 && f3.arcadeUtils.hasGeometryOperations(p2) || !de(u5, a5) ? i4.set(a5.getObjectId(), s6) : r3[s6] = a5;
- }
- if (this.layer.type === "stream" || i4.size === 0)
- return r3.filter(Boolean);
- n4.objectIds = Array.from(i4.keys());
- try {
- const e7 = await this.layer.queryFeatures(n4);
- for (const t3 of e7.features) {
- r3[i4.get(t3.getObjectId())] = t3;
- }
- } catch {
- }
- return r3.filter(Boolean);
- }
- async createPopupQuery(e6) {
- const t2 = this.layer.createQuery(), r3 = new Set();
- let i4 = false;
- const n4 = r(e6) && e6.clientGraphics ? e6.clientGraphics.map((e7) => e7.layer) : [this.layer];
- for (const s6 of n4) {
- if (!("popupEnabled" in s6))
- continue;
- const t3 = s3(s6, e6);
- if (t(t3))
- continue;
- const n5 = await this._loadArcadeModules(t3), a5 = n5 && n5.arcadeUtils.hasGeometryOperations(t3);
- i4 = !(this.layer.geometryType !== "point" && !a5);
- const l7 = await d3(this.layer, t3);
- for (const e7 of l7)
- r3.add(e7);
- }
- if (t2.returnGeometry = i4, t2.returnZ = i4, t2.returnM = i4, t2.outFields = Array.from(r3), t2.outSpatialReference = this.view.spatialReference, this.layer.type === "feature") {
- const e7 = o2(this);
- r(e7) && (t2.where = t2.where ? `(${t2.where}) AND (${e7})` : e7);
- }
- return t2;
- }
- canResume() {
- return !!super.canResume() && (!r(this.timeExtent) || !this.timeExtent.isEmpty);
- }
- };
- return e([d()], A4.prototype, "_updatingRequiredFieldsPromise", void 0), e([d({ readOnly: true })], A4.prototype, "availableFields", null), e([d()], A4.prototype, "effect", null), e([d({ type: w2 })], A4.prototype, "featureEffect", null), e([d({ type: y2 })], A4.prototype, "filter", void 0), e([d(g2)], A4.prototype, "timeExtent", void 0), e([d()], A4.prototype, "layer", void 0), e([d({ type: Number })], A4.prototype, "maximumNumberOfFeatures", null), e([d({ readOnly: true, type: Boolean })], A4.prototype, "maximumNumberOfFeaturesExceeded", null), e([d({ readOnly: true })], A4.prototype, "requiredFields", void 0), e([d()], A4.prototype, "suspended", void 0), e([d()], A4.prototype, "view", void 0), A4 = e([n("esri.views.layers.FeatureLayerView")], A4), A4;
- };
- // node_modules/@arcgis/core/views/2d/layers/FeatureLayerView2D.js
- function Q(e6) {
- return e6 && "openPorts" in e6;
- }
- var A3 = s.getLogger("esri.views.2d.layers.FeatureLayerView2D");
- var M2 = class extends A2(i(f2(u2))) {
- constructor() {
- super(...arguments), this._pipelineIsUpdating = true, this._commandsQueue = new u3({ process: (e6) => {
- switch (e6.type) {
- case "processed-edit":
- return this._doEdit(e6);
- case "refresh":
- return this._doRefresh(e6.dataChanged);
- case "update":
- return this._doUpdate();
- }
- } }), this._visibilityOverrides = new Set(), this._highlightIds = new Map(), this._updateHighlight = x(async () => this._proxy.setHighlight(Array.from(this._highlightIds.keys()))), this._uploadsLocked = false, this._needsClusterSizeUpdate = false, this.featureEffectView = new n2(), this._lastDefinitionExpression = null;
- }
- destroy() {
- o(this._updateClusterSizeTask, (e6) => e6.remove()), this._proxy?.destroy(), this._commandsQueue.destroy();
- }
- initialize() {
- this.addResolvingPromise(Promise.all([this._initProxy(), this._initServiceOptions()])), this.handles.add([this.on("valueRangesChanged", (e6) => {
- this._set("_aggregateValueRanges", e6.valueRanges);
- }), l(() => this.featureEffect, (e6) => {
- this.featureEffectView.featureEffect = e6;
- }, { initial: true, sync: true })]);
- }
- async _initProxy() {
- const e6 = this.layer;
- if ("isTable" in e6 && e6.isTable)
- throw new s2("featurelayerview:table-not-supported", "table feature layer can't be displayed", { layer: this.layer });
- const t2 = e6.type === "feature" || e6.type === "subtype-group", i3 = "capabilities" in e6 && e6.capabilities.operations.supportsQuery;
- if (t2 && !i3)
- throw new s2("featurelayerview:query-not-supported", "layer view requires a layer with query capability", { layer: e6 });
- this._proxy && this._proxy.destroy();
- const r3 = this._createClientOptions();
- return this._set("_proxy", new u4({ client: r3 })), this._proxy.when();
- }
- async _initServiceOptions() {
- return this._set("_serviceOptions", await this._createServiceOptions()), this._serviceOptions;
- }
- get orderByFields() {
- return this._serviceOptions.type !== "stream" && this._serviceOptions.orderByFields;
- }
- get labelsVisible() {
- const e6 = this.layer.type === "subtype-group" ? this.layer.sublayers.items : [this.layer];
- return !this.suspended && e6.some((e7) => e7.labelingInfo && e7.labelsVisible);
- }
- get queryMode() {
- return this._serviceOptions.type;
- }
- get renderingConfigHash() {
- if (!this.layer)
- return null;
- const e6 = this.availableFields, t2 = this.layer, i3 = this.view.floors, { definitionExpression: r3 } = t2, s6 = this.layer.type !== "subtype-group" && this.layer.labelsVisible && this.layer.labelingInfo, a5 = "renderer" in t2 && t2.renderer, n4 = t2.type === "feature" ? t2.gdbVersion : void 0, o4 = t2.type === "feature" && t2.historicMoment ? t2.historicMoment.getTime() : void 0, { timeExtent: l7 } = this, u5 = "customParameters" in t2 ? JSON.stringify(t2.customParameters) : void 0, d5 = "apiKey" in t2 ? t2.apiKey : void 0, p2 = t2.type === "stream" ? `${JSON.stringify(t2.geometryDefinition)}${t2.definitionExpression}` : null, y4 = JSON.stringify(this.clips), c4 = t2.featureReduction && t2.featureReduction.toJSON(), f3 = "orderBy" in this.layer && JSON.stringify(this.layer.orderBy), g5 = "sublayers" in this.layer && this.layer.sublayers.items.reduce((e7, t3) => e7 + `${t3.visible ? 1 : 0}.${JSON.stringify(t3.renderer)}.${t3.labelsVisible}
- .${JSON.stringify(t3.labelingInfo)}`, ""), m3 = "subtypeCode" in this.layer && this.layer.subtypeCode;
- return JSON.stringify({ orderBy: f3, sublayerHash: g5, subtypeCode: m3, filterHash: r(this.filter) && this.filter.toJSON(), effectHash: r(this.featureEffect) && this.featureEffect.toJSON(), streamFilter: p2, gdbVersion: n4, definitionExpression: r3, historicMoment: o4, availableFields: e6, renderer: a5, labelingInfo: s6, timeExtent: l7, floors: i3, clipsHash: y4, featureReduction: c4, customParameters: u5, apiKey: d5 });
- }
- highlight(e6) {
- let t2;
- return e6 instanceof g4 ? t2 = [e6.getObjectId()] : typeof e6 == "number" || typeof e6 == "string" ? t2 = [e6] : Array.isArray(e6) && e6.length > 0 ? t2 = typeof e6[0] == "number" || typeof e6[0] == "string" ? e6 : e6.map((e7) => e7?.getObjectId()) : j2.isCollection(e6) && e6.length > 0 && (t2 = e6.map((e7) => e7?.getObjectId()).toArray()), t2 = t2?.filter((e7) => e7 != null), t2 && t2.length ? (this._addHighlight(t2), { remove: () => this._removeHighlight(t2) }) : { remove: () => {
- } };
- }
- hasHighlight() {
- return !!this._highlightIds.size;
- }
- async hitTest(e6, r3) {
- if (!this.tileRenderer)
- return null;
- const s6 = await this.tileRenderer.hitTest(r3);
- if (s6.length === 0)
- return null;
- const { features: a5, aggregates: n4 } = await this._proxy.getFeatures(s6);
- return [...n4.map((i3) => this._createGraphicHit(e6, s4.fromJSON(i3))), ...a5.map((t2) => this._createGraphicHit(e6, g4.fromJSON(t2)))];
- }
- async queryAggregates() {
- return (await this._proxy.getAggregates()).map((e6) => s4.fromJSON(e6));
- }
- queryStatistics() {
- return this._proxy.queryStatistics();
- }
- async querySummaryStatistics(e6, t2, i3) {
- const r3 = { ...t2, scale: this.view.scale };
- return this._proxy.querySummaryStatistics(this._cleanUpQuery(e6), r3, i3);
- }
- async queryUniqueValues(e6, t2, i3) {
- const r3 = { ...t2, scale: this.view.scale };
- return this._proxy.queryUniqueValues(this._cleanUpQuery(e6), r3, i3);
- }
- async queryClassBreaks(e6, t2, i3) {
- const r3 = { ...t2, scale: this.view.scale };
- return this._proxy.queryClassBreaks(this._cleanUpQuery(e6), r3, i3);
- }
- async queryHistogram(e6, t2, i3) {
- const r3 = { ...t2, scale: this.view.scale };
- return this._proxy.queryHistogram(this._cleanUpQuery(e6), r3, i3);
- }
- queryFeatures(e6, t2) {
- return this.queryFeaturesJSON(e6, t2).then((e7) => {
- const t3 = x2.fromJSON(e7);
- return t3.features.forEach((e8) => this._setLayersForFeature(e8)), t3;
- });
- }
- queryVisibleFeatures(e6, t2) {
- return this._proxy.queryVisibleFeatures(this._cleanUpQuery(e6), t2).then((e7) => {
- const t3 = x2.fromJSON(e7);
- return t3.features.forEach((e8) => this._setLayersForFeature(e8)), t3;
- });
- }
- queryFeaturesJSON(e6, t2) {
- return this._proxy.queryFeatures(this._cleanUpQuery(e6), t2);
- }
- queryObjectIds(e6, t2) {
- return this._proxy.queryObjectIds(this._cleanUpQuery(e6), t2);
- }
- queryFeatureCount(e6, t2) {
- return this._proxy.queryFeatureCount(this._cleanUpQuery(e6), t2);
- }
- queryExtent(e6, t2) {
- return this._proxy.queryExtent(this._cleanUpQuery(e6), t2).then((e7) => ({ count: e7.count, extent: M.fromJSON(e7.extent) }));
- }
- setVisibility(e6, t2) {
- t2 ? this._visibilityOverrides.delete(e6) : this._visibilityOverrides.add(e6), this._update();
- }
- update(e6) {
- if (!this._tileStrategy || !this.tileRenderer)
- return;
- const { hasMissingTiles: t2, added: i3, removed: r3 } = this._tileStrategy.update(e6);
- (i3.length || r3.length) && this._proxy.updateTiles({ added: i3, removed: r3 }), t2 && this.requestUpdate(), this.notifyChange("updating");
- }
- attach() {
- this.view.timeline.record(`${this.layer.title} (FeatureLayer) Attach`), this._tileStrategy = new s5({ acquireTile: (e6) => this._acquireTile(e6), releaseTile: (e6) => this._releaseTile(e6), tileInfoView: this.view.featuresTilingScheme, buffer: 0 }), this.handles.add(l(() => this.renderingConfigHash, () => this._update(), h), "attach"), this.layer.type !== "stream" && this.handles.add(this.layer.on("edits", (e6) => this._edit(e6)), "attach");
- }
- detach() {
- this._commandsQueue.clear(), this._proxy?.stop(), this.container.removeAllChildren(), this.handles.remove("attach"), this.tileRenderer && (this.tileRenderer.uninstall(this.container), this.tileRenderer = null), this._tileStrategy && (this._tileStrategy.destroy(), this._tileStrategy = null), this._tileRendererHash = null;
- }
- moveStart() {
- this.requestUpdate();
- }
- viewChange() {
- this.requestUpdate();
- }
- moveEnd() {
- this.requestUpdate();
- }
- isUpdating() {
- const e6 = "renderer" in this.layer && this.layer.renderer != null, t2 = this._commandsQueue.updating, i3 = this._updatingRequiredFieldsPromise != null, r3 = !this._proxy || !this._proxy.isReady, s6 = this._pipelineIsUpdating, n4 = this.tileRenderer == null || this.tileRenderer?.updating, o4 = e6 && (t2 || i3 || r3 || s6 || n4);
- return a("esri-2d-log-updating") && console.log(`Updating FLV2D: ${o4}
- -> hasRenderer ${e6}
- -> hasPendingCommand ${t2}
- -> updatingRequiredFields ${i3}
- -> updatingProxy ${r3}
- -> updatingPipeline ${s6}
- -> updatingTileRenderer ${n4}
- `), o4;
- }
- _createClientOptions() {
- return { setUpdating: (e6) => {
- this._set("_pipelineIsUpdating", e6);
- }, emitEvent: (e6) => {
- this.emit(e6.name, e6.event);
- } };
- }
- async _detectQueryMode(e6) {
- const t2 = "path" in e6, i3 = "editingInfo" in this.layer && this.layer.editingInfo?.lastEditDate, r3 = !!this.layer.refreshInterval, s6 = !i3 && r3;
- if (t2 && (this.layer.type === "feature" || this.layer.type === "subtype-group") && this.layer.geometryType === "point" && this.layer.capabilities.query.supportsPagination && !this.layer.capabilities.operations.supportsEditing && !s6 && a("featurelayer-snapshot-enabled"))
- try {
- const e7 = await this.layer.queryFeatureCount();
- if (e7 <= a("featurelayer-snapshot-point-min-threshold"))
- return { mode: "snapshot", featureCount: e7 };
- const t3 = a("featurelayer-snapshot-point-max-threshold"), i4 = a("featurelayer-snapshot-point-coverage"), r4 = this.view.extent, s7 = e2(this.layer.fullExtent), n4 = s7?.clone().intersection(r4), o4 = r(n4) ? n4.width * n4.height : 0, l7 = s7?.width * s7?.height, d5 = l7 === 0 ? 0 : o4 / l7;
- if (e7 <= t3 && d5 >= i4)
- return { mode: "snapshot", featureCount: e7 };
- } catch (n4) {
- A3.warn("mapview-feature-layer", "Encountered an error when querying for featureCount", { error: n4 });
- }
- return { mode: "on-demand" };
- }
- async _createServiceOptions() {
- const e6 = this.layer;
- if (e6.type === "stream")
- return null;
- const { capabilities: t2, objectIdField: i3 } = e6, r3 = e6.fields.map((e7) => e7.toJSON()), s6 = r(e6.fullExtent) && e6.fullExtent.toJSON(), a5 = e4(e6.geometryType), o4 = e6.timeInfo && e6.timeInfo.toJSON() || null, l7 = e6.spatialReference ? e6.spatialReference.toJSON() : null, u5 = e6.type === "feature" ? e6.globalIdField : null;
- let d5;
- e6.type === "ogc-feature" ? d5 = e6.source.getFeatureDefinition() : Q(e6.source) ? d5 = await e6.source.openPorts() : e6.parsedUrl && (d5 = m(e6.parsedUrl), "dynamicDataSource" in e6 && e6.dynamicDataSource && (d5.query = { layer: JSON.stringify({ source: e6.dynamicDataSource }) }));
- const p2 = "datesInUnknownTimezone" in this.layer && this.layer.datesInUnknownTimezone, y4 = ("subtypeField" in this.layer && this.layer.subtypeField) ?? null, { mode: c4, featureCount: f3 } = await this._detectQueryMode(d5);
- let g5 = this.layer.objectIdField;
- if (this.layer.type === "feature" && r(this.layer.orderBy) && this.layer.orderBy.length) {
- const e7 = !this.layer.orderBy[0].valueExpression && this.layer.orderBy[0].field;
- e7 && (g5 = e7);
- }
- return { type: c4, timeReferenceUnknownClient: p2, subtypeField: y4, featureCount: f3, globalIdField: u5, maxRecordCount: t2.query.maxRecordCount, tileMaxRecordCount: t2.query.tileMaxRecordCount, capabilities: t2, fields: r3, fullExtent: s6, geometryType: a5, objectIdField: i3, source: d5, timeInfo: o4, spatialReference: l7, orderByFields: g5 };
- }
- async _createMemoryServiceOptions(e6) {
- const t2 = await e6.openPorts();
- return { ...this._createServiceOptions(), type: "memory", source: t2 };
- }
- _cleanUpQuery(e6) {
- const t2 = b2.from(e6) || this.createQuery();
- return t2.outSpatialReference || (t2.outSpatialReference = this.view.spatialReference), t2;
- }
- async _update() {
- return this._commandsQueue.push({ type: "update" });
- }
- async _edit(e6) {
- if (this.suspended)
- return void this._clearTiles();
- return this._validateEdit(e6) ? this._commandsQueue.push({ type: "edit", edits: e6 }) : void 0;
- }
- async doRefresh(e6) {
- if (this._tileStrategy.tileKeys().length)
- return this.suspended && e6 ? void this._clearTiles() : this._commandsQueue.push({ type: "refresh", dataChanged: e6 });
- }
- _clearTiles() {
- this._tileStrategy.tileKeys().length && (this._proxy.updateTiles({ added: [], removed: this._tileStrategy.tileKeys() }), this._tileStrategy.clear(), this.requestUpdate(), this._commandsQueue.clear(), this._update());
- }
- _validateEdit(e6) {
- const t2 = "globalIdField" in this.layer && this.layer.globalIdField, i3 = e6.deletedFeatures.some((e7) => e7.objectId === -1 || !e7.objectId), r3 = t2 && this.availableFields.includes(t2);
- return i3 && !r3 ? (A3.error(new s2("mapview-apply-edits", `Editing the specified service requires the layer's globalIdField, ${t2} to be included the layer's outFields for updates to be reflected on the map`)), null) : e6;
- }
- async _doUpdate() {
- try {
- if (this.destroyed || !this._hasRequiredSupport(this.layer) || !this._tileStrategy)
- return;
- const { featureEffectView: t2, filter: i3 } = this;
- await this._updateRequiredFields();
- const { renderer: r3 } = this._getEffectiveRenderer();
- this._set("_effectiveRenderer", r3);
- const s6 = this._createSchemaConfig(), a5 = this._createConfiguration(s6, i3, t2.filter), n4 = this._lastDefinitionExpression !== a5.schema.source.definitionExpression;
- this._lastDefinitionExpression = a5.schema.source.definitionExpression;
- const o4 = a5.schema.tileRenderer, l7 = this._createTileRendererHash(o4);
- if (this._serviceOptions.type === "snapshot" && (a5.schema.source.featureCount = this._serviceOptions.featureCount), l7 !== this._tileRendererHash) {
- await this._initTileRenderer(o4, r3);
- const e6 = this.layer, t3 = e6.type === "stream" ? await this._initServiceOptions() : this._serviceOptions;
- this.tileRenderer.onConfigUpdate(r3), e6.type !== "stream" && Q(e6.source) && (t3.source = await e6.source.openPorts());
- const i4 = { added: this._tileStrategy.tileKeys(), removed: [] };
- await this._proxy.startup(this.view.featuresTilingScheme, a5, t3, i4), this.hasHighlight() && await this._proxy.setHighlight(Array.from(this._highlightIds.keys())), await this._onceTilesUpdated(), this.tileRenderer.onConfigUpdate(r3);
- } else {
- this._serviceOptions.type === "snapshot" && n4 && (a5.schema.source.featureCount = await this.layer.queryFeatureCount());
- const t3 = await this._proxy.update(a5);
- (t3.mesh || t3.targets.aggregate) && this._lockGPUUploads();
- try {
- await this._proxy.applyUpdate(t3);
- } catch (e6) {
- g(e6) || A3.error(e6);
- }
- (t3.mesh || t3.targets.aggregate) && this._unlockGPUUploads(), this.tileRenderer.onConfigUpdate(r3), this._updateClusterSizeVariable(), this._forceAttributeTextureUpload();
- }
- this._tileRendererHash = l7, this.tileRenderer.invalidateLabels(), this.requestUpdate();
- } catch (e6) {
- }
- }
- async _doEdit(e6) {
- try {
- await this._proxy.onEdits(e6);
- } catch (t2) {
- g(t2), 0;
- }
- }
- async _doRefresh(e6) {
- this._lockGPUUploads();
- try {
- await this._proxy.refresh(e6);
- } catch (t2) {
- g(t2), 0;
- }
- this._unlockGPUUploads(), this.layer?.featureReduction && this._updateClusterSizeVariable();
- }
- _updateClusterSizeVariable() {
- this._needsClusterSizeUpdate && (this.tileRenderer.onConfigUpdate(this._effectiveRenderer), this._needsClusterSizeUpdate = false);
- }
- _createUpdateClusterSizeTask(e6, t2) {
- return l(() => this._aggregateValueRanges, (i3) => {
- this._updateClusterEffectiveRendererSizeVariable(e6, t2, i3), this._needsClusterSizeUpdate = true, this._uploadsLocked || this._updateClusterSizeVariable();
- });
- }
- async _updateClusterEffectiveRendererSizeVariable(e6, t2, i3) {
- if (e6.dynamicClusterSize && "visualVariables" in e6 && e6.visualVariables) {
- const r3 = d2(e6.visualVariables);
- if (r(r3) && r3.field === "cluster_count") {
- const s6 = e6.visualVariables.indexOf(r3);
- e6.visualVariables[s6] = f(t2, i3);
- const a5 = e6.clone();
- a5.dynamicClusterSize = true, this._set("_effectiveRenderer", a5);
- }
- }
- }
- _getEffectiveRenderer() {
- const e6 = "renderer" in this.layer && this.layer.renderer, t2 = this.layer.featureReduction;
- if (r(this._updateClusterSizeTask) && (this._updateClusterSizeTask.remove(), this._updateClusterSizeTask = null), t2 && "renderer" in t2 && t2.renderer) {
- const e7 = [];
- for (const i3 of t2.fields ?? [])
- x3(e7, i3);
- return { renderer: t2.renderer, aggregateFields: e7, featureReduction: t2 };
- }
- if (t2 && t2.type === "cluster" && m2(e6)) {
- const i3 = t2, r3 = [], s6 = c(r3, e6, i3, this._aggregateValueRanges);
- return o(this._updateClusterSizeTask, (e7) => e7.remove()), this._updateClusterSizeTask = this._createUpdateClusterSizeTask(s6, i3), { renderer: s6, aggregateFields: r3, featureReduction: t2 };
- }
- return { renderer: e6, aggregateFields: [], featureReduction: null };
- }
- _acquireTile(e6) {
- const t2 = this.tileRenderer.acquireTile(e6);
- return t2.once("attach", () => {
- this.requestUpdate();
- }), t2;
- }
- _releaseTile(e6) {
- this.tileRenderer.releaseTile(e6);
- }
- async _initTileRenderer(e6, t2) {
- const i3 = await e5(e6, { layerView: this, tileInfoView: this.view.featuresTilingScheme, layer: this.layer });
- return this.tileRenderer && (this._tileStrategy.clear(), this.tileRenderer.uninstall(this.container), this.tileRenderer.destroy(), this.tileRenderer = null), this.destroyed ? null : (this._proxy.tileRenderer = i3, this._set("tileRenderer", i3), this.tileRenderer.install(this.container), this.tileRenderer.onConfigUpdate(t2), this.requestUpdate(), this.tileRenderer);
- }
- _createTileRendererHash(e6) {
- return `${e6.type}`;
- }
- get hasFilter() {
- const e6 = !!("floorInfo" in this.layer && this.layer.floorInfo && this.view.floors && this.view.floors.length);
- return !!this.filter || e6 || !!this._visibilityOverrides.size || !!this.timeExtent;
- }
- _injectOverrides(e6) {
- const t2 = r(e6) ? e6.timeExtent : null, i3 = r(this.timeExtent) && r(t2) ? this.timeExtent.intersection(t2) : this.timeExtent || t2;
- let r3 = null;
- const s6 = "floorInfo" in this.layer && this.layer.floorInfo;
- if (s6) {
- const t3 = r(e6) && e6.where;
- r3 = this._addFloorFilterClause(t3);
- }
- if (!this._visibilityOverrides.size && !i3 && !s6)
- return r(e6) ? e6.toJSON() : null;
- (e6 = r(e6) && e6.clone() || new y2()).timeExtent = i3, r3 && (e6.where = r3);
- const a5 = e6.toJSON();
- return a5.hiddenIds = Array.from(this._visibilityOverrides), a5;
- }
- _addFloorFilterClause(e6) {
- const t2 = this.layer;
- let i3 = e6 || "";
- if ("floorInfo" in t2 && t2.floorInfo) {
- let e7 = this.view.floors;
- if (!e7 || !e7.length)
- return i3;
- t2.floorInfo.viewAllLevelIds?.length && (e7 = t2.floorInfo.viewAllLevelIds);
- const r3 = e7.filter((e8) => e8 !== "").map((e8) => "'" + e8 + "'");
- r3.push("''");
- const s6 = t2.floorInfo.floorField;
- let a5 = "(" + s6 + " IN ({ids}) OR " + s6 + " IS NULL)";
- if (a5 = a5.replace("{ids}", r3.join(", ")), r(i3) && i3.includes(s6)) {
- let e8 = new RegExp("AND \\(" + s6 + ".*NULL\\)", "g");
- i3 = i3.replace(e8, ""), e8 = new RegExp("\\(" + s6 + ".*NULL\\)", "g"), i3 = i3.replace(e8, ""), i3 = i3.replace(/\s+/g, " ").trim();
- }
- i3 = i3 !== "" ? "(" + i3 + ") AND " + a5 : a5;
- }
- return i3 !== "" ? i3 : null;
- }
- _createConfiguration(e6, t2, i3) {
- const r3 = this.layer.type === "feature" && this.layer.historicMoment ? this.layer.historicMoment.getTime() : void 0, s6 = this.layer.type === "feature" ? this.layer.gdbVersion : void 0, a5 = new Array(S), n4 = this._injectOverrides(t2);
- a5[0] = n4, a5[1] = r(i3) ? i3.toJSON() : null;
- const o4 = z(e6);
- if (t(o4))
- return null;
- const l7 = l4("2d");
- return { availableFields: this.availableFields, gdbVersion: s6, historicMoment: r3, devicePixelRatio: window.devicePixelRatio || 1, filters: a5, schema: o4, supportsTextureFloat: l7.supportsTextureFloat, maxTextureSize: l7.maxTextureSize };
- }
- _hasRequiredSupport(e6) {
- return !("renderer" in e6) || v(e6.renderer);
- }
- _onceTilesUpdated() {
- return this.requestUpdate(), j3(() => !this._pipelineIsUpdating);
- }
- _lockGPUUploads() {
- this.tileRenderer && (this._uploadsLocked = true, this.tileRenderer.lockGPUUploads());
- }
- _unlockGPUUploads() {
- this.tileRenderer && (this._uploadsLocked = false, this.tileRenderer.unlockGPUUploads());
- }
- _forceAttributeTextureUpload() {
- this.tileRenderer && this.tileRenderer.forceAttributeTextureUpload();
- }
- _createSchemaConfig() {
- const e6 = this.layer.type === "feature" ? this.layer.historicMoment : null, t2 = this.layer.type === "feature" ? this.layer.gdbVersion : null;
- return { renderer: "renderer" in this.layer && this.layer.renderer, spatialReference: this.layer.spatialReference, timeExtent: this.layer.timeExtent, definitionExpression: this.layer.definitionExpression, featureReduction: this.layer.featureReduction, fields: this.layer.fields, geometryType: this.layer.geometryType, historicMoment: e6, labelsVisible: "labelsVisible" in this.layer && this.layer.labelsVisible, labelingInfo: "labelingInfo" in this.layer && this.layer.labelingInfo, availableFields: this.availableFields, featureEffect: this.featureEffect, filter: this.filter, gdbVersion: t2, pixelBuffer: 0, orderBy: "orderBy" in this.layer && this.layer.orderBy ? this.layer.orderBy : null, customParameters: { ..."customParameters" in this.layer ? this.layer.customParameters : void 0, token: "apiKey" in this.layer ? this.layer.apiKey : void 0 }, subtypeCode: "subtypeCode" in this.layer ? this.layer.subtypeCode : void 0, subtypeField: "subtypeField" in this.layer ? this.layer.subtypeField : void 0 };
- }
- _addHighlight(e6) {
- for (const t2 of e6)
- if (this._highlightIds.has(t2)) {
- const e7 = this._highlightIds.get(t2);
- this._highlightIds.set(t2, e7 + 1);
- } else
- this._highlightIds.set(t2, 1);
- this._updateHighlight().catch((e7) => {
- g(e7) || A3.error(e7);
- });
- }
- _removeHighlight(e6) {
- for (const t2 of e6)
- if (this._highlightIds.has(t2)) {
- const e7 = this._highlightIds.get(t2) - 1;
- e7 === 0 ? this._highlightIds.delete(t2) : this._highlightIds.set(t2, e7);
- }
- this._updateHighlight().catch((e7) => {
- g(e7) || A3.error(e7);
- });
- }
- _setLayersForFeature(e6) {
- const t2 = this.layer;
- e6.layer = t2, e6.sourceLayer = t2;
- }
- _createGraphicHit(e6, t2) {
- return this._setLayersForFeature(t2), r(t2.geometry) && (t2.geometry.spatialReference = this.view.spatialReference), { type: "graphic", graphic: t2, layer: this.layer, mapPoint: e6 };
- }
- };
- e([d()], M2.prototype, "_serviceOptions", void 0), e([d()], M2.prototype, "_proxy", void 0), e([d()], M2.prototype, "_pipelineIsUpdating", void 0), e([d()], M2.prototype, "_effectiveRenderer", void 0), e([d()], M2.prototype, "_aggregateValueRanges", void 0), e([d()], M2.prototype, "_commandsQueue", void 0), e([d()], M2.prototype, "featureEffectView", void 0), e([d()], M2.prototype, "labelsVisible", null), e([d({ readOnly: true })], M2.prototype, "queryMode", null), e([d()], M2.prototype, "renderingConfigHash", null), e([d()], M2.prototype, "tileRenderer", void 0), e([d()], M2.prototype, "updating", void 0), M2 = e([n("esri.views.2d.layers.FeatureLayerView2D")], M2);
- var B = M2;
- export {
- B
- };
- //# sourceMappingURL=chunk-3IU4W5A7.js.map
|