@arcgis/core 5.1.0-next.71 → 5.1.0-next.73
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/PopupTemplate.js +1 -1
- package/assets/esri/core/workers/RemoteClient.js +1 -1
- package/assets/esri/core/workers/chunks/003fd7745966fe03510c.js +1 -0
- package/assets/esri/core/workers/chunks/00bae4b7e179336e0362.js +1 -0
- package/assets/esri/core/workers/chunks/{36031cb53c486630f3c9.js → 026d3fa331caec1ea3d2.js} +1 -1
- package/assets/esri/core/workers/chunks/027c3ea756db68e51f0a.js +1 -0
- package/assets/esri/core/workers/chunks/041c372e98a6fba90b36.js +1 -0
- package/assets/esri/core/workers/chunks/{a5a46d0a0831497cf1b4.js → 0783890816bac45277b9.js} +1 -1
- package/assets/esri/core/workers/chunks/07aac6245a0d1adbb2d4.js +1 -0
- package/assets/esri/core/workers/chunks/0839da55707f7c4cf780.js +1 -0
- package/assets/esri/core/workers/chunks/0ae360bf253adee46737.js +1 -0
- package/assets/esri/core/workers/chunks/0c00e5e4bd18467bcecd.js +1 -0
- package/assets/esri/core/workers/chunks/0dad0bca8d58b2c63d22.js +1 -0
- package/assets/esri/core/workers/chunks/0ef93722524620023f69.js +1 -0
- package/assets/esri/core/workers/chunks/127cd8fee3717a473fc5.js +1 -0
- package/assets/esri/core/workers/chunks/1286f41f245ef22b3a26.js +1 -0
- package/assets/esri/core/workers/chunks/12e575a6d2b008b8fc2b.js +1 -0
- package/assets/esri/core/workers/chunks/{c92352b0e39576ca317a.js → 13e60f19f436b8d683ae.js} +1 -1
- package/assets/esri/core/workers/chunks/161d60fdac2013c15543.js +1 -0
- package/assets/esri/core/workers/chunks/1661684357912726a72a.js +1 -0
- package/assets/esri/core/workers/chunks/168de44a789d1cecc1f8.js +1 -0
- package/assets/esri/core/workers/chunks/1961b59756933e0a82f2.js +1 -0
- package/assets/esri/core/workers/chunks/1d9d7915cf7449e5d468.js +1 -0
- package/assets/esri/core/workers/chunks/1f85646936200a399c15.js +1 -0
- package/assets/esri/core/workers/chunks/{deb8a0b306d7b9c86b97.js → 2171aaa147aa4d9fc5b5.js} +1 -1
- package/assets/esri/core/workers/chunks/235cb82952a18ff8d206.js +1 -0
- package/assets/esri/core/workers/chunks/260d4571722cb1ff1366.js +1 -0
- package/assets/esri/core/workers/chunks/{3e972ae291df1844017d.js → 266ba61b72a278d93a26.js} +1 -1
- package/assets/esri/core/workers/chunks/27b80c386cebadcaca3c.js +1 -0
- package/assets/esri/core/workers/chunks/29d3890a5a43d934067a.js +1 -0
- package/assets/esri/core/workers/chunks/{7e6ccf9f3e756186e93e.js → 29e76256e3e867e80520.js} +1 -1
- package/assets/esri/core/workers/chunks/{333a0038d782d8a34d58.js → 2abf124e2956e4f76688.js} +1 -1
- package/assets/esri/core/workers/chunks/2f17438d215bea3ce70f.js +1 -0
- package/assets/esri/core/workers/chunks/{f6d5dd2eef0d9918096e.js → 30e710ec4d22c43d4e7e.js} +1 -1
- package/assets/esri/core/workers/chunks/30f04dc001eaf838d64c.js +1 -0
- package/assets/esri/core/workers/chunks/356cb86606b8c674f947.js +1 -0
- package/assets/esri/core/workers/chunks/398e0dd2bc7e1ab84831.js +1 -0
- package/assets/esri/core/workers/chunks/3b1052aa30af3f6186cc.js +1 -0
- package/assets/esri/core/workers/chunks/3bbf684ee2484eb44c9f.js +1 -0
- package/assets/esri/core/workers/chunks/3e87e3ad857d72f6ecbb.js +1 -0
- package/assets/esri/core/workers/chunks/{7cb6d8f7eaf762279632.js → 3ea5a18b264628dc37f0.js} +1 -1
- package/assets/esri/core/workers/chunks/41809c16544ec25120fa.js +1 -0
- package/assets/esri/core/workers/chunks/41913575dd45c65d645e.js +1 -0
- package/assets/esri/core/workers/chunks/{628f56c09838eb9c573b.js → 422824e407b550170c8c.js} +1 -1
- package/assets/esri/core/workers/chunks/42e483fde18f12da32a6.js +1 -0
- package/assets/esri/core/workers/chunks/43ab44d37bc0ea97ef98.js +1 -0
- package/assets/esri/core/workers/chunks/46e622857ba92a72a317.js +1 -0
- package/assets/esri/core/workers/chunks/47f2113357b2aa4f4f37.js +1 -0
- package/assets/esri/core/workers/chunks/488ed9584b527ec47be3.js +1 -0
- package/assets/esri/core/workers/chunks/4ad32580e0c0699fde1f.js +1 -0
- package/assets/esri/core/workers/chunks/4d0f793dee4ad919221b.js +1 -0
- package/assets/esri/core/workers/chunks/4eed175277eb0df3c821.js +1 -0
- package/assets/esri/core/workers/chunks/{916a8f3eed1fafdc7242.js → 54d07eadf113f0e4e506.js} +1 -1
- package/assets/esri/core/workers/chunks/54ed37ec9682ea739deb.js +1 -0
- package/assets/esri/core/workers/chunks/{9187d1caca1fd2d713e0.js → 55369c5bd65bcaf78da1.js} +1 -1
- package/assets/esri/core/workers/chunks/56fd3da911c2c4511e5d.js +1 -0
- package/assets/esri/core/workers/chunks/59592bb25f226865e88a.js +1 -0
- package/assets/esri/core/workers/chunks/{e77d958cb62536b8eebc.js → 5a4d7ba6dc1d4b41d80d.js} +1 -1
- package/assets/esri/core/workers/chunks/5c663d5f98bdfa29151b.js +1 -0
- package/assets/esri/core/workers/chunks/5d55b4449bcb24cd72b6.js +1 -0
- package/assets/esri/core/workers/chunks/5d8fe41a3c06ddb4094b.js +1 -0
- package/assets/esri/core/workers/chunks/{fe68c28d3c61f116ff23.js → 5ef37f37e405b3bb5450.js} +1 -1
- package/assets/esri/core/workers/chunks/608d707fd9d9f9088473.js +1 -0
- package/assets/esri/core/workers/chunks/{ae0a572cbbdd9815ee2e.js → 62b3e933f548ce354b99.js} +1 -1
- package/assets/esri/core/workers/chunks/656d6963e8f837fbf28f.js +1 -0
- package/assets/esri/core/workers/chunks/{a5afcd633b32e6ee31a7.js → 6a0352d20596ca3f4b64.js} +1 -1
- package/assets/esri/core/workers/chunks/6c7ff968bd4fc816442d.js +1 -0
- package/assets/esri/core/workers/chunks/6e526c06825ecc6c99c0.js +1 -0
- package/assets/esri/core/workers/chunks/6ea8b0d68881d16a2432.js +1 -0
- package/assets/esri/core/workers/chunks/7027d93dc5a4595d70c6.js +1 -0
- package/assets/esri/core/workers/chunks/70b35b2446558d5280e3.js +1 -0
- package/assets/esri/core/workers/chunks/7349cb45a93e6916f115.js +1 -0
- package/assets/esri/core/workers/chunks/751609831b283903ba48.js +1 -0
- package/assets/esri/core/workers/chunks/76edaeaf8fe344bb77a8.js +1 -0
- package/assets/esri/core/workers/chunks/76fe5b821d6b54db5721.js +1 -0
- package/assets/esri/core/workers/chunks/7951d93f5f15aa76f49c.js +1 -0
- package/assets/esri/core/workers/chunks/80ace1c7203c5059525d.js +1 -0
- package/assets/esri/core/workers/chunks/81d30c9062ad0120a863.js +1 -0
- package/assets/esri/core/workers/chunks/84772b023d04e415f17f.js +1 -0
- package/assets/esri/core/workers/chunks/{123e920e4460124ec3bb.js → 88b480a1d1fb01778798.js} +9 -30
- package/assets/esri/core/workers/chunks/88c5f7c712c6b89b5109.js +1 -0
- package/assets/esri/core/workers/chunks/88e469b82d2594f23649.js +1 -0
- package/assets/esri/core/workers/chunks/8a14e3db28c403b046cf.js +1 -0
- package/assets/esri/core/workers/chunks/8a664451845a47048859.js +1 -0
- package/assets/esri/core/workers/chunks/8a8242e7cc7e6a9e7876.js +1 -0
- package/assets/esri/core/workers/chunks/{4d51261d6131c07402cd.js → 8acee3fba488f202f82f.js} +1 -1
- package/assets/esri/core/workers/chunks/{31071a43e2c03984d619.js → 8d75f6f27c1c17c33992.js} +1 -1
- package/assets/esri/core/workers/chunks/9444ed8ea117861ae89b.js +1 -0
- package/assets/esri/core/workers/chunks/95d82c619dcbec2e1050.js +1 -0
- package/assets/esri/core/workers/chunks/96bba4d93a32ad34a1c8.js +1 -0
- package/assets/esri/core/workers/chunks/9a38fd68b02b617c45d3.js +1 -0
- package/assets/esri/core/workers/chunks/9d434360dfce1e49b7b9.js +1 -0
- package/assets/esri/core/workers/chunks/9eb4ae556950e1d0124d.js +2 -0
- package/assets/esri/core/workers/chunks/9f4b97204def91567e3c.js +1 -0
- package/assets/esri/core/workers/chunks/a37c28e3c4a2be9fd1d5.js +1 -0
- package/assets/esri/core/workers/chunks/{c06d021180418f2014de.js → a78bc340a794fd332667.js} +1 -1
- package/assets/esri/core/workers/chunks/{1edd39c7c4acdc591d10.js → a809b811121099a87a98.js} +1 -1
- package/assets/esri/core/workers/chunks/a8d7f59927bdad564141.js +1 -0
- package/assets/esri/core/workers/chunks/{f89976ec97938bf86996.js → abc06d10c7ac8ba5b0e4.js} +1 -1
- package/assets/esri/core/workers/chunks/abdf146b35e179b5b245.js +1 -0
- package/assets/esri/core/workers/chunks/abe22ae8ee0dcc9efbb7.js +1 -0
- package/assets/esri/core/workers/chunks/{fef5dc19736f12dfa99a.js → af5db0372d526e592fcc.js} +1 -1
- package/assets/esri/core/workers/chunks/{3b7cda16e656db450f11.js → afc0baf86ece710ef867.js} +1 -1
- package/assets/esri/core/workers/chunks/{6ac5ec3ecbca8860338b.js → b54b7cc6b23a70fed700.js} +1 -1
- package/assets/esri/core/workers/chunks/b6cadb8a579241adcb86.js +1 -0
- package/assets/esri/core/workers/chunks/b702279c48f3009f6dd8.js +1 -0
- package/assets/esri/core/workers/chunks/b9848bdbaf3d9ac93d54.js +1 -0
- package/assets/esri/core/workers/chunks/be1d6a571f76933dfbb0.js +1 -0
- package/assets/esri/core/workers/chunks/{eb3cdc4ff45243fc3cc5.js → bef27a25fbc4a6e19ec0.js} +1 -1
- package/assets/esri/core/workers/chunks/bfcdc5c315131aae34d8.js +1 -0
- package/assets/esri/core/workers/chunks/c0f624a2ca0d07ef8f8c.js +1 -0
- package/assets/esri/core/workers/chunks/c3381b9a36299210ee47.js +1 -0
- package/assets/esri/core/workers/chunks/{c2882a9e67124b7c18be.js → c503c79ba5761f7abbeb.js} +1 -1
- package/assets/esri/core/workers/chunks/{a65d576e90179a2b5400.js → c5507480344176fad241.js} +1 -1
- package/assets/esri/core/workers/chunks/c70df6ed190f9ebcf6aa.js +1 -0
- package/assets/esri/core/workers/chunks/cb5e4b9b4a59c2622eb5.js +1 -0
- package/assets/esri/core/workers/chunks/cd7159600ce132e32d04.js +1 -0
- package/assets/esri/core/workers/chunks/cfe246adb5e6cb6f0cfc.js +1 -0
- package/assets/esri/core/workers/chunks/d17fcfc502f0e0fa6523.js +596 -0
- package/assets/esri/core/workers/chunks/d201a5dff18a5bb467ab.js +1 -0
- package/assets/esri/core/workers/chunks/d65b1234867f7d773d50.js +2 -0
- package/assets/esri/core/workers/chunks/{4d8670f6fa8952b7bab6.js → d950d5c2844206502ff0.js} +1 -1
- package/assets/esri/core/workers/chunks/db3c484bfa607dec6050.js +1 -0
- package/assets/esri/core/workers/chunks/db588bf3256e95c977b7.js +1 -0
- package/assets/esri/core/workers/chunks/{967758a05170545cd371.js → dcc719e15b2e0cce1f3b.js} +1 -1
- package/assets/esri/core/workers/chunks/{6bb090f3e5c18604cb39.js → dd5b362bded458afa2d6.js} +1 -1
- package/assets/esri/core/workers/chunks/dfdd474fddcd1d6091ce.js +1 -0
- package/assets/esri/core/workers/chunks/{aa1a3a849aba84cf585b.js → e1bc9ad767e08dc18bbc.js} +1 -1
- package/assets/esri/core/workers/chunks/e235ea4293d5d463acfb.js +1 -0
- package/assets/esri/core/workers/chunks/e25a684eb9f025bdcc01.js +1 -0
- package/assets/esri/core/workers/chunks/e272411e2c9378aa8496.js +1312 -0
- package/assets/esri/core/workers/chunks/e43486113aaf72ac4dc1.js +1 -0
- package/assets/esri/core/workers/chunks/ea4c3393c5757e309a71.js +1 -0
- package/assets/esri/core/workers/chunks/ed216ddeb7f59f510bd0.js +1 -0
- package/assets/esri/core/workers/chunks/ef8886dff54063928bcb.js +1 -0
- package/assets/esri/core/workers/chunks/{231f502cd15f30d12be2.js → f1673e723b336204ad77.js} +1 -1
- package/assets/esri/core/workers/chunks/{d69110ec4078c583a05e.js → f207b3be0714cc50030a.js} +1 -1
- package/assets/esri/core/workers/chunks/f5223ffb3be548c9b0a1.js +1 -0
- package/assets/esri/core/workers/chunks/f53805c7a84203305b2c.js +1 -0
- package/assets/esri/core/workers/chunks/f5c57ff48ca505ed701d.js +1 -0
- package/assets/esri/core/workers/chunks/fae147d03ed723ab234d.js +1 -0
- package/chunks/CheckerBoard.glsl.js +3 -5
- package/chunks/ColorMaterial.glsl.js +4 -6
- package/chunks/ComponentShader.glsl.js +42 -44
- package/chunks/DefaultMaterial.glsl.js +21 -23
- package/chunks/EdgeShader.glsl.js +9 -11
- package/chunks/GaussianSplat.glsl.js +8 -8
- package/chunks/GlobalIllumination.glsl.js +186 -116
- package/chunks/GlobalIlluminationBlur.glsl.js +81 -61
- package/chunks/GlobalIlluminationUpscale.glsl.js +66 -0
- package/chunks/ImageMaterial.glsl.js +5 -7
- package/chunks/LineCallout.glsl.js +9 -12
- package/chunks/LineMarker.glsl.js +24 -26
- package/chunks/Path.glsl.js +15 -17
- package/chunks/Pattern.glsl.js +25 -27
- package/chunks/RealisticTree.glsl.js +11 -13
- package/chunks/RibbonLine.glsl.js +42 -45
- package/chunks/ShadedColorMaterial.glsl.js +8 -9
- package/chunks/Water.glsl.js +18 -20
- package/config.js +1 -1
- package/form/elements/FieldElement.d.ts +3 -2
- package/form/elements/inputs/Input.d.ts +1 -1
- package/form/elements/inputs/MultipleChoiceInput.d.ts +65 -0
- package/form/elements/inputs/MultipleChoiceInput.js +2 -0
- package/form/elements/inputs/inputUtils.js +1 -1
- package/form/elements/inputs/multipleChoice/Choice.d.ts +30 -0
- package/form/elements/inputs/multipleChoice/Choice.js +2 -0
- package/form/elements/inputs/multipleChoice/OtherChoice.d.ts +28 -0
- package/form/elements/inputs/multipleChoice/OtherChoice.js +2 -0
- package/form/elements/inputs.d.ts +11 -2
- package/form/elements/inputs.js +1 -1
- package/form/support/formUtils.js +1 -1
- package/interfaces.d.ts +28 -0
- package/kernel.js +1 -1
- package/layers/Lyr3DWasmPerSceneView.js +1 -1
- package/layers/VoxelWasmPerSceneView.js +1 -1
- package/layers/graphics/FlatFeature.js +1 -1
- package/layers/graphics/FlatFeatureSet.js +1 -1
- package/layers/graphics/OptimizedFeature.js +1 -1
- package/layers/graphics/data/AttributesBuilder.js +1 -1
- package/layers/graphics/data/QueryEngineResult.js +1 -1
- package/layers/graphics/data/flatFeatureQueryEngineAdapter.js +1 -1
- package/layers/graphics/data/optimizedFeatureQueryEngineAdapter.js +1 -1
- package/layers/graphics/featureConversionUtils.js +1 -1
- package/layers/support/LabelClass.js +1 -1
- package/layers/support/featureLayerUtils.js +1 -1
- package/layers/support/labelUtils.js +1 -1
- package/layers/video/videoUtils.js +1 -1
- package/package.json +2 -2
- package/popupTemplateUtils.js +2 -0
- package/renderers/visualVariables/SizeVariable.js +1 -1
- package/renderers/visualVariables/support/sizeVariableUtils.js +1 -1
- package/rest/query/operations/pbfFeatureServiceParser.js +1 -1
- package/rest/support/OutDistance.js +2 -0
- package/rest/support/Query.js +1 -1
- package/smartMapping/statistics/support/utils.js +1 -1
- package/smartMapping/support/adapters/InMemoryLayerAdapter.js +1 -1
- package/support/arcadeUtils.js +1 -1
- package/support/revision.js +1 -1
- package/third-party-notices.txt +7 -29
- package/views/2d/engine/webgl/shaderGraph/techniques/mesh/MeshWriter.js +1 -1
- package/views/2d/engine/webgl/shaders/sources/shaderRepository.js +1 -1
- package/views/2d/layers/FeatureLikeLayerView2D.js +1 -1
- package/views/2d/layers/features/layerAdapters/CatalogFootprintLayerAdapter.js +1 -1
- package/views/2d/layers/features/layerAdapters/FeatureLayerAdapter.js +1 -1
- package/views/2d/layers/features/layerAdapters/InMemoryLayerAdapter.js +1 -1
- package/views/2d/layers/features/layerAdapters/KnowledgeGraphSublayerAdapter.js +1 -1
- package/views/2d/layers/features/layerAdapters/OGCFeatureLayerAdapter.js +1 -1
- package/views/2d/layers/features/layerAdapters/OrientedImageryLayerAdapter.js +1 -1
- package/views/2d/layers/features/layerAdapters/SubtypeGroupLayerAdapter.js +1 -1
- package/views/2d/layers/features/support/FeatureSetReader.js +1 -1
- package/views/2d/layers/features/support/FeatureSetReaderPBF.js +1 -1
- package/views/3d/environment/EnvironmentManager.js +1 -1
- package/views/3d/layers/FeatureLikeLayerView3D.js +1 -1
- package/views/3d/layers/I3SMeshView3D.js +1 -1
- package/views/3d/layers/IntegratedMesh3DTilesLayerView3D.js +1 -1
- package/views/3d/layers/IntegratedMeshNormals.js +1 -1
- package/views/3d/layers/StreamLayerView3D.js +1 -1
- package/views/3d/layers/graphics/featureExpressionInfoUtils.js +1 -1
- package/views/3d/state/ViewStateManager.js +1 -1
- package/views/3d/support/orientedBoundingBox.js +1 -1
- package/views/3d/terrain/OverlayRenderer.js +1 -1
- package/views/3d/terrain/TerrainRenderer.js +1 -1
- package/views/3d/webgl-engine/collections/Component/Material/ComponentMaterial.js +1 -1
- package/views/3d/webgl-engine/collections/Component/Material/ComponentMaterialGlobalParameters.js +1 -1
- package/views/3d/webgl-engine/collections/Component/Material/ComponentMaterialRepository.js +1 -1
- package/views/3d/webgl-engine/collections/Component/Material/ComponentShader.glsl.js +1 -1
- package/views/3d/webgl-engine/core/renderPasses/RenderPassManager.js +1 -1
- package/views/3d/webgl-engine/core/shaderLibrary/hud/HUD.glsl.js +20 -32
- package/views/3d/webgl-engine/core/shaderLibrary/shading/GlobalIlluminationWeights.glsl.js +21 -0
- package/views/3d/webgl-engine/core/shaderLibrary/shading/ReadGlobalIllumination.glsl.js +11 -7
- package/views/3d/webgl-engine/core/shaderLibrary/shading/VisualVariables.glsl.js +5 -3
- package/views/3d/webgl-engine/core/shaderLibrary/terrain/Overlay.glsl.js +1 -1
- package/views/3d/webgl-engine/effects/RenderPluginManager.js +1 -1
- package/views/3d/webgl-engine/effects/geometry/RenderOccludedRenderNode.js +1 -1
- package/views/3d/webgl-engine/effects/globalIllumination/GlobalIllumination.glsl.js +2 -0
- package/views/3d/webgl-engine/effects/globalIllumination/GlobalIllumination.js +1 -1
- package/views/3d/webgl-engine/effects/globalIllumination/GlobalIlluminationBlur.glsl.js +2 -0
- package/views/3d/webgl-engine/effects/globalIllumination/GlobalIlluminationBlurTechnique.js +1 -1
- package/views/3d/webgl-engine/effects/globalIllumination/GlobalIlluminationTechnique.js +1 -1
- package/views/3d/webgl-engine/effects/globalIllumination/GlobalIlluminationUpscale.glsl.js +2 -0
- package/views/3d/webgl-engine/effects/globalIllumination/GlobalIlluminationUpscaleTechnique.js +2 -0
- package/views/3d/webgl-engine/effects/glow/GlowRenderNode.js +1 -1
- package/views/3d/webgl-engine/lib/BindParameters.js +1 -1
- package/views/3d/webgl-engine/lib/Compositor.js +1 -1
- package/views/3d/webgl-engine/lib/GaussianSplatRenderNode.js +1 -1
- package/views/3d/webgl-engine/lib/RenderFeature.js +1 -1
- package/views/3d/webgl-engine/lib/Renderer.js +1 -1
- package/views/3d/webgl-engine/lib/SortedRenderGeometryRenderer.js +1 -1
- package/views/3d/webgl-engine/lib/Viewshed.js +1 -1
- package/views/3d/webgl-engine/lib/edgeRendering/EdgeRenderer.js +1 -1
- package/views/3d/webgl-engine/lib/edgeRendering/EdgeShader.glsl.js +1 -1
- package/views/3d/webgl-engine/lib/edgeRendering/EdgeShaderTechniqueConfiguration.js +1 -1
- package/views/3d/webgl-engine/materials/CheckerBoardMaterial.js +1 -1
- package/views/3d/webgl-engine/materials/ColorMaterial.js +1 -1
- package/views/3d/webgl-engine/materials/DefaultMaterial.js +1 -1
- package/views/3d/webgl-engine/materials/HUDMaterial.js +1 -1
- package/views/3d/webgl-engine/materials/HeatmapDensityMaterial.js +1 -1
- package/views/3d/webgl-engine/materials/ImageMaterial.js +1 -1
- package/views/3d/webgl-engine/materials/LineCalloutMaterial.js +1 -1
- package/views/3d/webgl-engine/materials/LineMarkerMaterial.js +1 -1
- package/views/3d/webgl-engine/materials/MeasurementArrowMaterial.js +1 -1
- package/views/3d/webgl-engine/materials/Path.glsl.js +1 -1
- package/views/3d/webgl-engine/materials/PathMaterial.js +1 -1
- package/views/3d/webgl-engine/materials/PathTechniqueConfiguration.js +1 -1
- package/views/3d/webgl-engine/materials/PatternMaterial.js +1 -1
- package/views/3d/webgl-engine/materials/RibbonLineMaterial.js +1 -1
- package/views/3d/webgl-engine/materials/ShadedColorMaterial.js +1 -1
- package/views/3d/webgl-engine/materials/SlicePlaneMaterial.js +1 -1
- package/views/3d/webgl-engine/materials/Water.glsl.js +1 -1
- package/views/3d/webgl-engine/materials/WaterMaterial.js +1 -1
- package/views/3d/webgl-engine/materials/WaterTechniqueConfiguration.js +1 -1
- package/views/3d/webgl-engine/shaders/CheckerBoard.glsl.js +1 -1
- package/views/3d/webgl-engine/shaders/CheckerBoardTechniqueConfiguration.js +1 -1
- package/views/3d/webgl-engine/shaders/ColorMaterial.glsl.js +1 -1
- package/views/3d/webgl-engine/shaders/ColorMaterialTechniqueConfiguration.js +1 -1
- package/views/3d/webgl-engine/shaders/DefaultMaterial.glsl.js +1 -1
- package/views/3d/webgl-engine/shaders/DefaultMaterialTechniqueConfiguration.js +1 -1
- package/views/3d/webgl-engine/shaders/GaussianSplat.glsl.js +1 -1
- package/views/3d/webgl-engine/shaders/GaussianSplatTechniqueConfiguration.js +1 -1
- package/views/3d/webgl-engine/shaders/HUDMaterialTechniqueConfiguration.js +1 -1
- package/views/3d/webgl-engine/shaders/ImageMaterial.glsl.js +1 -1
- package/views/3d/webgl-engine/shaders/ImageMaterialTechniqueConfiguration.js +1 -1
- package/views/3d/webgl-engine/shaders/LineCallout.glsl.js +1 -1
- package/views/3d/webgl-engine/shaders/LineCalloutTechnique.js +1 -1
- package/views/3d/webgl-engine/shaders/LineCalloutTechniqueConfiguration.js +1 -1
- package/views/3d/webgl-engine/shaders/LineMarker.glsl.js +1 -1
- package/views/3d/webgl-engine/shaders/LineMarkerTechnique.js +1 -1
- package/views/3d/webgl-engine/shaders/LineMarkerTechniqueConfiguration.js +1 -1
- package/views/3d/webgl-engine/shaders/Pattern.glsl.js +1 -1
- package/views/3d/webgl-engine/shaders/PatternTechniqueConfiguration.js +1 -1
- package/views/3d/webgl-engine/shaders/RealisticTree.glsl.js +1 -1
- package/views/3d/webgl-engine/shaders/RibbonLine.glsl.js +1 -1
- package/views/3d/webgl-engine/shaders/RibbonLineTechnique.js +1 -1
- package/views/3d/webgl-engine/shaders/RibbonLineTechniqueConfiguration.js +1 -1
- package/views/3d/webgl-engine/shaders/ShadedColorMaterial.glsl.js +1 -1
- package/views/3d/webgl-engine/shaders/ShadedColorMaterialTechniqueConfiguration.js +1 -1
- package/views/3d/webgl-engine/statistics/RendererPerformanceInfo.js +1 -1
- package/views/VideoView.js +1 -1
- package/views/interactive/sketch/SketchOptions.d.ts +3 -1
- package/views/interactive/sketch/SketchTooltipOptions.d.ts +6 -0
- package/views/layers/FeatureLikeLayerView.js +1 -1
- package/views/support/Scheduler.js +1 -1
- package/views/video/VideoOperationalDataView.js +1 -1
- package/views/webgl/ShaderBuilder.js +1 -1
- package/widgets/BatchAttributeForm/BatchAttributeFormViewModel.js +1 -1
- package/widgets/BatchAttributeForm/batchAttributeFormUtils.js +1 -1
- package/widgets/BatchAttributeForm/inputs/SingleFeatureInputAdapter.js +2 -0
- package/widgets/BatchAttributeForm/inputs/TextElementInput.d.ts +28 -4
- package/widgets/BatchAttributeForm/inputs/TextElementInput.js +1 -1
- package/widgets/BatchAttributeForm/templates/AttachmentElementTemplate.js +2 -0
- package/widgets/BatchAttributeForm/templates/support/createBatchFormTemplate.js +1 -1
- package/widgets/BatchAttributeForm/templates/support/hashElementTemplate.js +1 -1
- package/widgets/BatchAttributeForm/templates/support/templateUtils.js +1 -1
- package/widgets/FeatureTable/FeatureTableViewModel.d.ts +19 -3
- package/widgets/FeatureTable/FeatureTableViewModel.js +1 -1
- package/widgets/FeatureTable/Grid/GridViewModel.js +1 -1
- package/widgets/FeatureTable/VisibleElements.d.ts +15 -1
- package/widgets/FeatureTable/VisibleElements.js +1 -1
- package/widgets/FeatureTable/support/FeatureStore.js +1 -1
- package/widgets/FeatureTable.d.ts +15 -1
- package/widgets/FeatureTable.js +1 -1
- package/widgets/Search/SearchViewModel.js +1 -1
- package/widgets/Search/support/layerSearchUtils.js +1 -1
- package/widgets/support/widgetUtils.js +1 -1
- package/assets/esri/core/workers/chunks/09ecb36e44096e577af8.js +0 -1
- package/assets/esri/core/workers/chunks/0ca06ea649bbdb93ff49.js +0 -1
- package/assets/esri/core/workers/chunks/10308c9f3f0d709d96bc.js +0 -1
- package/assets/esri/core/workers/chunks/141edf5ed890105a079b.js +0 -1
- package/assets/esri/core/workers/chunks/160b9a76b75875507c86.js +0 -1
- package/assets/esri/core/workers/chunks/16dfdee05704df249e95.js +0 -1
- package/assets/esri/core/workers/chunks/17ef955dc48e329aa184.js +0 -1
- package/assets/esri/core/workers/chunks/18001536ed345955121a.js +0 -1
- package/assets/esri/core/workers/chunks/20e715e3aeb1c3265901.js +0 -1
- package/assets/esri/core/workers/chunks/238f51d0b36f998017b8.js +0 -1
- package/assets/esri/core/workers/chunks/2cee6d751c5e73fe09d4.js +0 -1
- package/assets/esri/core/workers/chunks/314140e2e9b813191907.js +0 -1
- package/assets/esri/core/workers/chunks/3158a3487d3e8a61b680.js +0 -1
- package/assets/esri/core/workers/chunks/3b1446286a9b87f34761.js +0 -1
- package/assets/esri/core/workers/chunks/3f7fd58ee7d71989fc83.js +0 -1
- package/assets/esri/core/workers/chunks/41396724040180d2537f.js +0 -1
- package/assets/esri/core/workers/chunks/416e031bafc0189544fa.js +0 -1
- package/assets/esri/core/workers/chunks/55ee78923987ed17ea8c.js +0 -1
- package/assets/esri/core/workers/chunks/56c7d7c7217557375fb6.js +0 -1
- package/assets/esri/core/workers/chunks/58b3c888c8bfedbe6443.js +0 -1
- package/assets/esri/core/workers/chunks/5a1d975b3e9e6b7eff67.js +0 -1
- package/assets/esri/core/workers/chunks/5f6942ac94acd7842926.js +0 -1
- package/assets/esri/core/workers/chunks/6118706b9a038e9a06b8.js +0 -1
- package/assets/esri/core/workers/chunks/6d15229b3fa84a7acf4d.js +0 -599
- package/assets/esri/core/workers/chunks/7314c0131403cac84ad7.js +0 -1
- package/assets/esri/core/workers/chunks/73545bb13c70f6a347a4.js +0 -1
- package/assets/esri/core/workers/chunks/73a045061e69a22b6869.js +0 -1
- package/assets/esri/core/workers/chunks/75669912cddcb5db52c8.js +0 -1
- package/assets/esri/core/workers/chunks/7ca32806e47be15109a4.js +0 -1
- package/assets/esri/core/workers/chunks/7d6ed65bbcd279448191.js +0 -1
- package/assets/esri/core/workers/chunks/81f149e45c79b9b086fb.js +0 -1
- package/assets/esri/core/workers/chunks/84fa25f66a6949290221.js +0 -1
- package/assets/esri/core/workers/chunks/852aabbf671d2ca9cd33.js +0 -1
- package/assets/esri/core/workers/chunks/854fe80272b59fafc2e9.js +0 -1
- package/assets/esri/core/workers/chunks/85edbb072a2ce6c1bb30.js +0 -2
- package/assets/esri/core/workers/chunks/861817be5e050e9522ab.js +0 -1
- package/assets/esri/core/workers/chunks/89345a682dea60ef1643.js +0 -1
- package/assets/esri/core/workers/chunks/8985402c328b90af5724.js +0 -1
- package/assets/esri/core/workers/chunks/89fdf9ad10ca8fbb08a5.js +0 -1
- package/assets/esri/core/workers/chunks/8b094330323d9b16fb5d.js +0 -1
- package/assets/esri/core/workers/chunks/90aed8c4b266832f84ca.js +0 -1
- package/assets/esri/core/workers/chunks/943cf0653a2b7de16a4f.js +0 -1
- package/assets/esri/core/workers/chunks/9776c2db337222ceceef.js +0 -1
- package/assets/esri/core/workers/chunks/990853e9df38fdfc58b5.js +0 -1
- package/assets/esri/core/workers/chunks/9a21ba0c45a96b94c05e.js +0 -1
- package/assets/esri/core/workers/chunks/9a235c92f21df2c17aa8.js +0 -1
- package/assets/esri/core/workers/chunks/9b56162ac67c992193ce.js +0 -1
- package/assets/esri/core/workers/chunks/9f1f5fb648302c43ad12.js +0 -1
- package/assets/esri/core/workers/chunks/a1e6187c239fdc7553ed.js +0 -1
- package/assets/esri/core/workers/chunks/a4b6fdbc995be03d2afb.js +0 -1
- package/assets/esri/core/workers/chunks/a760be8fa6c6ea6b745c.js +0 -1
- package/assets/esri/core/workers/chunks/a8782286ce3c0d6c20e6.js +0 -1
- package/assets/esri/core/workers/chunks/a96692514dcaa50340dd.js +0 -1
- package/assets/esri/core/workers/chunks/a994a3c912a33b2f4100.js +0 -1
- package/assets/esri/core/workers/chunks/aa7aaeae31ddb259e55e.js +0 -1
- package/assets/esri/core/workers/chunks/abcc5fb71be2bd94878c.js +0 -1
- package/assets/esri/core/workers/chunks/aecb05df4ad1454f5435.js +0 -1
- package/assets/esri/core/workers/chunks/aecb105db7cec2c9c4c5.js +0 -1
- package/assets/esri/core/workers/chunks/b19f33e026a2a43b17c4.js +0 -1
- package/assets/esri/core/workers/chunks/b3950d5f1f3352521504.js +0 -1
- package/assets/esri/core/workers/chunks/b3f0600729227b458a75.js +0 -1
- package/assets/esri/core/workers/chunks/b5922991d2f450e6a9d9.js +0 -1
- package/assets/esri/core/workers/chunks/b8643976a7f984552d94.js +0 -1
- package/assets/esri/core/workers/chunks/b8a11d32a4847513619b.js +0 -1
- package/assets/esri/core/workers/chunks/b8acb6c2538053c01cc6.js +0 -1
- package/assets/esri/core/workers/chunks/ba4259aa050169c1d523.js +0 -1
- package/assets/esri/core/workers/chunks/bbaf1d9835671c0165ca.js +0 -1
- package/assets/esri/core/workers/chunks/bcefdf9753d9d2f6f1be.js +0 -1
- package/assets/esri/core/workers/chunks/c178e2cfc34603661b1d.js +0 -1
- package/assets/esri/core/workers/chunks/c3e80c0e29ac6a7a6f80.js +0 -1
- package/assets/esri/core/workers/chunks/c79827f879d1d58d3f1b.js +0 -1
- package/assets/esri/core/workers/chunks/c92b40a532e708e506cc.js +0 -1
- package/assets/esri/core/workers/chunks/cb903ccbce87172a0757.js +0 -1
- package/assets/esri/core/workers/chunks/cda2e445eb2ac269abdf.js +0 -1
- package/assets/esri/core/workers/chunks/ce44e172e2847fd8df14.js +0 -1
- package/assets/esri/core/workers/chunks/cff7e921649aef715c78.js +0 -1
- package/assets/esri/core/workers/chunks/d0c3ab70f390cd579fed.js +0 -1
- package/assets/esri/core/workers/chunks/d315098b038a96084ff5.js +0 -1
- package/assets/esri/core/workers/chunks/d4a9eb4470cc6a1f67fc.js +0 -2
- package/assets/esri/core/workers/chunks/d8c0d18f0132872decd3.js +0 -1
- package/assets/esri/core/workers/chunks/db0061a6d5bf454cc509.js +0 -1
- package/assets/esri/core/workers/chunks/dca595fdd5e1a571e441.js +0 -1
- package/assets/esri/core/workers/chunks/dcfafcf4386f2940d000.js +0 -1
- package/assets/esri/core/workers/chunks/df8143b72ef94806c992.js +0 -1
- package/assets/esri/core/workers/chunks/e2b034c391c603f7f825.js +0 -1
- package/assets/esri/core/workers/chunks/e3a73d9acebccd3ba49b.js +0 -1
- package/assets/esri/core/workers/chunks/e67bdd8bf38ebe89a344.js +0 -1
- package/assets/esri/core/workers/chunks/e797d45eba0884dc7e6f.js +0 -1
- package/assets/esri/core/workers/chunks/e81a3da05fcff97b4752.js +0 -1
- package/assets/esri/core/workers/chunks/e957d52cb9643961a843.js +0 -1127
- package/assets/esri/core/workers/chunks/e9dd60d0220036545ebb.js +0 -1
- package/assets/esri/core/workers/chunks/ea6d3b7c7d720aa7bc94.js +0 -1
- package/assets/esri/core/workers/chunks/eb9982bc866976fef960.js +0 -1
- package/assets/esri/core/workers/chunks/ec4669a0edeca94710e0.js +0 -1
- package/assets/esri/core/workers/chunks/ef013a77950c1902de11.js +0 -1
- package/assets/esri/core/workers/chunks/ef9d74f8d5a502fda809.js +0 -1
- package/assets/esri/core/workers/chunks/f09446b9ff937a84d6d3.js +0 -1
- package/assets/esri/core/workers/chunks/f0bc5e8e44d53b73d431.js +0 -1
- package/assets/esri/core/workers/chunks/f653970d983f17fb764b.js +0 -1
- package/assets/esri/core/workers/chunks/f9edc685099f51363f41.js +0 -1
- package/assets/esri/core/workers/chunks/fa687ba2d66fcc2501da.js +0 -1
- package/assets/esri/core/workers/chunks/fb9a889ec9fd23739a14.js +0 -1
- package/assets/esri/core/workers/chunks/fe1b67ab7748a3aef231.js +0 -1
- package/chunks/HUDCompositing.glsl.js +0 -2
- package/views/3d/webgl-engine/core/shaderLibrary/shading/EncodingColor.glsl.js +0 -7
- package/views/3d/webgl-engine/core/shaderLibrary/shading/MultipassGeometryTest.glsl.js +0 -5
- package/views/3d/webgl-engine/core/shaderLibrary/shading/TerrainDepthTest.glsl.js +0 -8
- package/views/3d/webgl-engine/effects/fboFormatUtils.js +0 -2
- package/views/3d/webgl-engine/shaders/GlobalIllumination.glsl.js +0 -2
- package/views/3d/webgl-engine/shaders/GlobalIlluminationBlur.glsl.js +0 -2
- package/views/3d/webgl-engine/shaders/HUDCompositing.glsl.js +0 -2
- package/views/3d/webgl-engine/shaders/HUDCompositingTechnique.js +0 -2
- /package/assets/esri/core/workers/chunks/{85edbb072a2ce6c1bb30.js.LICENSE.txt → 9eb4ae556950e1d0124d.js.LICENSE.txt} +0 -0
- /package/assets/esri/core/workers/chunks/{d4a9eb4470cc6a1f67fc.js.LICENSE.txt → d65b1234867f7d773d50.js.LICENSE.txt} +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";(self.webpackChunkRemoteClient=self.webpackChunkRemoteClient||[]).push([[6061,7389],{61691(e,t,s){s.d(t,{G:()=>i});class i{*[Symbol.iterator](){let e=this.next();for(;e;)yield e,e=this.next()}}},76061(e,t,s){s.d(t,{S:()=>r});var i=s(61691);class r extends i.G{constructor(e){super(),this.m_iGeom=-1,this.m_aGeoms=e?e.slice():[]}next(){if(this.m_iGeom<this.m_aGeoms.length-1){const e=this.m_aGeoms[++this.m_iGeom];return this.m_aGeoms[this.m_iGeom]=null,e}return null}tock(){return!1}getGeometryID(){return this.m_iGeom}getRank(){return 1}}},46140(e,t,s){s.d(t,{A:()=>r});var i=s(49186);class r{constructor(e,t,s=""){this.major=e,this.minor=t,this._context=s}lessThan(e,t){return this.major<e||e===this.major&&this.minor<t}greaterEqual(e,t){return!this.lessThan(e,t)}toString(){return`${this.major}.${this.minor}`}validate(e){if(this.major!==e.major){const t=this._context&&this._context+":",s=this._context&&this._context+" ";throw new i.A(t+"unsupported-version",`Required major ${s}version is '${this.major}', but got '\${version.major}.\${version.minor}'`,{version:e})}}clone(){return new r(this.major,this.minor,this._context)}static parse(e,t=""){const[s,n]=e.split("."),o=/^\s*\d+\s*$/;if(!s?.match||!o.test(s))throw new i.A((t&&t+":")+"invalid-version","Expected major version to be a number, but got '${version}'",{version:e});if(!n?.match||!o.test(n))throw new i.A((t&&t+":")+"invalid-version","Expected minor version to be a number, but got '${version}'",{version:e});const a=parseInt(s,10),c=parseInt(n,10);return new r(a,c,t)}}},6797(e,t,s){s.d(t,{Ui:()=>d});var i=s(69622),r=s(7762),n=s(88620);const o=new Set(["esri.Color","esri.portal.Portal","esri.symbols.support.Symbol3DAnchorPosition2D","esri.symbols.support.Symbol3DAnchorPosition3D"]);function a(e){return e instanceof i.A}function c(e){return e instanceof r.A?Object.keys(e.items):a(e)?(0,n.oY)(e).keys():e?Object.keys(e):[]}function l(e,t){return e instanceof r.A?e.items[t]:e[t]}function u(e){return e?e.declaredClass:null}function h(e,t){const s=e.diff;if(s&&"function"==typeof s)return s(e,t);const i=c(e),r=c(t);if(0===i.length&&0===r.length)return;if(!i.length||!r.length||function(e,t){return!(!Array.isArray(e)||!Array.isArray(t))&&e.length!==t.length}(e,t))return{type:"complete",oldValue:e,newValue:t};const n=r.filter(e=>!i.includes(e)),d=i.filter(e=>!r.includes(e)),p=i.filter(s=>r.includes(s)&&l(e,s)!==l(t,s)).concat(n,d).sort(),f=u(e);if(f&&o.has(f)&&p.length)return{type:"complete",oldValue:e,newValue:t};let _;const m=a(e)&&a(t);for(const i of p){const r=l(e,i),n=l(t,i);let o;if((m||"function"!=typeof r&&"function"!=typeof n)&&r!==n&&(null!=r||null!=n)){if(s&&s[i]&&"function"==typeof s[i])o=s[i]?.(r,n);else if(r instanceof Date&&n instanceof Date){if(r.getTime()===n.getTime())continue;o={type:"complete",oldValue:r,newValue:n}}else o="object"==typeof r&&"object"==typeof n&&u(r)===u(n)?h(r,n):{type:"complete",oldValue:r,newValue:n};null!=o&&(null!=_?_.diff[i]=o:_={type:"partial",diff:{[i]:o}})}}return _}function d(e,t){if("function"!=typeof e&&"function"!=typeof t&&(null!=e||null!=t))return null==e||null==t||"object"==typeof e&&"object"==typeof t&&u(e)!==u(t)?{type:"complete",oldValue:e,newValue:t}:h(e,t)}},67482(e,t,s){function i(e){return null!=a(e)||null!=o(e)}function r(e){return c.test(e)}function n(e){return a(e)??o(e)}function o(e){const t=new Date(e);return function(e,t){if(Number.isNaN(e.getTime()))return!1;let s=!0;if(u&&/\d+\W*$/.test(t)){const e=t.match(/[a-zA-Z]{2,}/);if(e){let t=!1,i=0;for(;!t&&i<=e.length;)t=!l.test(e[i]),i++;s=!t}}return s}(t,e)?Number.isNaN(t.getTime())?null:t.getTime()-6e4*t.getTimezoneOffset():null}function a(e){const t=c.exec(e);if(!t?.groups)return null;const s=t.groups,i=+s.year,r=+s.month-1,n=+s.day,o=+(s.hours??"0"),a=+(s.minutes??"0"),l=+(s.seconds??"0");if(o>23)return null;if(a>59)return null;if(l>59)return null;const u=s.ms??"0",h=u?+u.padEnd(3,"0").slice(0,3):0;let d;if(s.isUTC||!s.offsetSign)d=Date.UTC(i,r,n,o,a,l,h);else{const e=+s.offsetHours,t=+s.offsetMinutes;d=6e4*("+"===s.offsetSign?-1:1)*(60*e+t)+Date.UTC(i,r,n,o,a,l,h)}return Number.isNaN(d)?null:d}s.d(t,{Br:()=>r,Cq:()=>i,_U:()=>n});const c=/^(?:(?<year>-?\d{4,})-(?<month>\d{2})-(?<day>\d{2}))(?:T(?<hours>\d{2}):(?<minutes>\d{2}):(?<seconds>\d{2})(?:\.(?<ms>\d+))?)?(?:(?<isUTC>Z)|(?:(?<offsetSign>\+|-)(?<offsetHours>\d{2}):(?<offsetMinutes>\d{2})))?$/,l=/^((jan(uary)?)|(feb(ruary)?)|(mar(ch)?)|(apr(il)?)|(may)|(jun(e)?)|(jul(y)?)|(aug(ust)?)|(sep(tember)?)|(oct(ober)?)|(nov(ember)?)|(dec(ember)?)|(am)|(pm)|(gmt)|(utc))$/i,u=!Number.isNaN(new Date("technology 10").getTime())},15585(e,t,s){s.d(t,{If:()=>p,O5:()=>y,O9:()=>_,QT:()=>m,l3:()=>f});var i=s(5482),r=s(2741),n=s(49186),o=s(44208),a=s(34727);let c=null,l=null,u=null,h=null;const d=(new Float32Array(0),new Uint32Array(0),new Uint32Array(0),new Uint32Array(0),{vertices:new Float64Array(0),indices:new Uint32Array(0),outlineIndices:new Uint32Array(0),outlineRingLengths:new Uint32Array(0),vertexCount:0,indexCount:0,outlineIndexCount:0,outlineRingCount:0});async function p(){return c??=async function(){const e=await s.e(2997).then(s.bind(s,42997)),t=await e.default({locateFile:e=>(0,r.s)(`esri/core/libs/libtess/${e}`)});u=t}(),c}async function f(){return l??=async function(){const e=await s.e(9134).then(s.bind(s,99134)),t=await e.default({locateFile:e=>(0,r.s)(`esri/core/libs/libtess/${e}`)});h=t}(),l}function _(){return null!==h}function m(e,t,s=2){const r={stack:[],error:void 0,hasError:!1};try{const a=u;if(!a)throw new n.A("libtess:not-loaded","libtessF32 not loaded");const c=(0,i.mS)(r,b.from(a,e),!1),l=(0,i.mS)(r,S.from(a,t),!1),h=e.length/s*4,d=(0,i.mS)(r,new b(a,h*s),!1),p=a.triangulate(c.ptr,l.ptr,l.size,s,d.ptr,h);if((0,o.A)("esri-tessellation-debug")){const e=a.getError();0!==e&&console.warn("libtess:triangulation",I(e))}return{buffer:d.slice(0,p*s),vertexCount:p}}catch(e){r.error=e,r.hasError=!0}finally{(0,i.hk)(r)}}function y(e,t,s=2,r=!0){const c={stack:[],error:void 0,hasError:!1};try{const l=h;if(!l)throw new n.A("libtess:not-loaded","libtessF64 not loaded");const u=(0,i.mS)(c,v.from(l,e),!1),p=(0,i.mS)(c,S.from(l,t),!1),f=(0,i.mS)(c,new S(l,1),!1),_=(0,i.mS)(c,new S(l,1),!1),m=(0,i.mS)(c,new S(l,1),!1),y=(0,i.mS)(c,new S(l,1),!1),{maxVertexCount:g,maxIndexCount:x,maxOutlineIndexCount:b,maxOutlineRingCount:T}=function(e,t){const s=e.reduce((e,t)=>e+t,0),i=e.length,r=Math.max(0,e.length-1),n=Math.max(0,s+2*r-2),o=Math.max(0,Math.ceil(2*s)),c=Math.max(0,Math.ceil(3*n*2)),l=(0,a.mP)(c,3),u=s>0?Math.max(2,Math.ceil(.25*s)):0,h=s>0?Math.max(1,Math.ceil(u/3)):0;return{maxVertexCount:o,maxIndexCount:l,maxOutlineIndexCount:t?Math.max(0,s+i+u):0,maxOutlineRingCount:t?Math.max(0,i+h):0}}(t,r);let k=0,A=0,M=0,C=0,F=0;{const e={stack:[],error:void 0,hasError:!1};try{const t=(0,i.mS)(e,new v(l,g*s),!1),n=(0,i.mS)(e,new S(l,x),!1),o=(0,i.mS)(e,r?new S(l,b):null,!1),a=(0,i.mS)(e,r?new S(l,T):null,!1);if(l.triangulateIndexed(u.ptr,p.ptr,p.size,s,t.ptr,g,s,n.ptr,x,f.ptr,_.ptr,o?.ptr??0,b,a?.ptr??0,T,m.ptr,y.ptr),F=l.getError(),k=w(l)[f.ptr/Int32Array.BYTES_PER_ELEMENT],A=w(l)[_.ptr/Int32Array.BYTES_PER_ELEMENT],M=w(l)[m.ptr/Int32Array.BYTES_PER_ELEMENT],C=w(l)[y.ptr/Int32Array.BYTES_PER_ELEMENT],0===F){const e=t.slice(0,k*s);return{vertices:e,indices:n.slice(0,A),outlineIndices:r&&o?o.slice(0,M):d.outlineIndices,outlineRingLengths:r&&a?a.slice(0,C):d.outlineRingLengths,vertexCount:k,indexCount:A,outlineIndexCount:r?M:0,outlineRingCount:r?C:0}}}catch(t){e.error=t,e.hasError=!0}finally{(0,i.hk)(e)}}if(100903!==F)return(0,o.A)("esri-tessellation-debug")&&console.warn("libtess:triangulation",I(F)),d;const E=(0,i.mS)(c,new v(l,k*s),!1),P=(0,i.mS)(c,new S(l,A),!1),R=(0,i.mS)(c,r?new S(l,M):null,!1),O=(0,i.mS)(c,r?new S(l,C):null,!1);if(l.triangulateIndexed(u.ptr,p.ptr,p.size,s,E.ptr,k,s,P.ptr,A,f.ptr,_.ptr,R?.ptr??0,r?M:0,O?.ptr??0,r?C:0,m.ptr,y.ptr),F=l.getError(),0!==F)return(0,o.A)("esri-tessellation-debug")&&console.warn("libtess:triangulation",I(F)),d;const z=w(l)[f.ptr/Int32Array.BYTES_PER_ELEMENT],L=w(l)[_.ptr/Int32Array.BYTES_PER_ELEMENT],D=w(l)[m.ptr/Int32Array.BYTES_PER_ELEMENT],N=w(l)[y.ptr/Int32Array.BYTES_PER_ELEMENT],q=E.slice(0,z*s);return{vertices:q,indices:P.slice(0,L),outlineIndices:r&&R?R.slice(0,D):d.outlineIndices,outlineRingLengths:r&&O?O.slice(0,N):d.outlineRingLengths,vertexCount:z,indexCount:L,outlineIndexCount:r?D:0,outlineRingCount:r?N:0}}catch(e){c.error=e,c.hasError=!0}finally{(0,i.hk)(c)}}function g(e){return e.HEAPF64}function x(e){return e.HEAPF32}function w(e){return e.HEAP32}class b{static from(e,t){const s=new b(e,t.length);return s.set(t),s}constructor(e,t){this._libtess=e,this.size=t,this.ptr=e.allocateCoordinateArray(t)}destroy(){this._libtess.destroyCoordinateArray(this.ptr)}[Symbol.dispose](){this.destroy()}get bytesPerCoordinate(){return Float32Array.BYTES_PER_ELEMENT}set(e){x(this._libtess).set(e,this.ptr/this.bytesPerCoordinate)}slice(e,t){const s=this.ptr/this.bytesPerCoordinate;return x(this._libtess).slice(s+e,s+t)}}class v{static from(e,t){const s=new v(e,t.length);return s.set(t),s}constructor(e,t){this._libtess=e,this.size=t,this.ptr=e.allocateCoordinateArray(t)}destroy(){this._libtess.destroyCoordinateArray(this.ptr)}[Symbol.dispose](){this.destroy()}get bytesPerCoordinate(){return Float64Array.BYTES_PER_ELEMENT}set(e){g(this._libtess).set(e,this.ptr/this.bytesPerCoordinate)}slice(e,t){const s=this.ptr/this.bytesPerCoordinate;return g(this._libtess).slice(s+e,s+t)}}class S{static from(e,t){const s=new S(e,t.length);return s.set(t),s}constructor(e,t){this._libtess=e,this.size=t,this.ptr=e.allocateLengthsArray(t)}destroy(){this._libtess.destroyLengthsArray(this.ptr)}[Symbol.dispose](){this.destroy()}get bytesPerCoordinate(){return Int32Array.BYTES_PER_ELEMENT}set(e){w(this._libtess).set(e,this.ptr/this.bytesPerCoordinate)}slice(e,t){const s=this.ptr/this.bytesPerCoordinate;return function(e){const t=w(e);return new Uint32Array(t.buffer,t.byteOffset,t.length)}(this._libtess).slice(s+e,s+t)}}function I(e){switch(e){case 100903:return"Insufficient output buffer";case 100902:return"Out of memory";case 100151:return"Missing begin polygon";case 100152:return"Missing begin contour";case 100153:return"Missing end polygon";case 100154:return"Missing end countour";case 100155:return"Coordinates too large";case 100156:return"Missing combine callback";default:return`Unknown: ${e}`}}},77085(e,t,s){s.d(t,{Hh:()=>a,fz:()=>u,g7:()=>c,s1:()=>o,zo:()=>l});var i=s(76061),r=s(83290);let n;function o(){return!!n&&(0,r.i)()}async function a(){if(!o()){const[e,t]=await Promise.all([Promise.all([s.e(3661),s.e(1878),s.e(8885),s.e(5756),s.e(1088)]).then(s.bind(s,31088)),Promise.all([s.e(3661),s.e(1878),s.e(8885),s.e(5756)]).then(s.bind(s,15756)).then(e=>e.aP).then(({injectPe:e})=>e),(0,r.l)()]);n=new e.OperatorGeodeticDensifyByLength,t(r.p)}}function c(e,t,s,i){return n.execute(e,t,s,i,null)}function l(e,t,s,r){const o=n.executeMany(new i.S(e),t,s,r,null);return Array.from(o)}function u(){return n.supportsCurves()}},5808(e,t,s){s.d(t,{O:()=>i});const i={geodesic:0,loxodrome:1,"great-elliptic":2,"normal-section":3,"shape-preserving":4}},89056(e,t,s){s.d(t,{b3:()=>h,jZ:()=>u});var i=s(12195),r=s(19419),n=s(537),o=s(95108),a=s(60408),c=s(80754),l=s(21325);function u(e){return d(e,!0)}function h(e){return d(e,!1)}function d(e,t){if(null==e)return null;const s=e.spatialReference,r=(0,l.Vp)(s),o=(0,i.W)(e)?e.toJSON():e;if(!r)return o;const u=(0,l.K8)(s)?102100:4326,h=c.j7[u].maxX,d=c.j7[u].minX;if((0,a.fT)(o))return f(o,h,d);if((0,a.U9)(o))return o.points=o.points.map(e=>f(e,h,d)),o;if((0,a.ZC)(o))return p(o,r);if((0,a.Bi)(o)||(0,a.Rg)(o)){const e=(0,n.Rg)(w,o),s={xmin:e[0],ymin:e[1],xmax:e[2],ymax:e[3]},i=(0,c.kd)(s.xmin,d)*(2*h),r=0===i?o:(0,c.kS)(o,i);return s.xmin+=i,s.xmax+=i,s.xmax>h?g(r,h,t):s.xmin<d?g(r,d,t):r}return o}function p(e,t){if(!t)return e;const s=function(e,t){const s=[],{ymin:i,ymax:r,xmin:n,xmax:o}=e,a=e.xmax-e.xmin,[c,l]=t.valid,{x:u,frameId:h}=_(e.xmin,t),{x:d,frameId:p}=_(e.xmax,t),f=u===d&&a>0;if(a>2*l){const e={xmin:n<o?u:d,ymin:i,xmax:l,ymax:r},t={xmin:c,ymin:i,xmax:n<o?d:u,ymax:r},a={xmin:0,ymin:i,xmax:l,ymax:r},f={xmin:c,ymin:i,xmax:0,ymax:r},_=[],y=[];m(e,a)&&_.push(h),m(e,f)&&y.push(h),m(t,a)&&_.push(p),m(t,f)&&y.push(p);for(let e=h+1;e<p;e++)_.push(e),y.push(e);s.push(new x(e,[h]),new x(t,[p]),new x(a,_),new x(f,y))}else u>d||f?s.push(new x({xmin:u,ymin:i,xmax:l,ymax:r},[h]),new x({xmin:c,ymin:i,xmax:d,ymax:r},[p])):s.push(new x({xmin:u,ymin:i,xmax:d,ymax:r},[h]));return s}(e,t).map(e=>e.extent);return s.length<2?s[0]||e:s.length>2?(e.xmin=t.valid[0],e.xmax=t.valid[1],e):{rings:s.map(e=>[[e.xmin,e.ymin],[e.xmin,e.ymax],[e.xmax,e.ymax],[e.xmax,e.ymin],[e.xmin,e.ymin]])}}function f(e,t,s){if(Array.isArray(e)){const i=e[0];if(i>t){const s=(0,c.kd)(i,t);e[0]=i+s*(-2*t)}else if(i<s){const t=(0,c.kd)(i,s);e[0]=i+t*(-2*s)}}else{const i=e.x;if(i>t){const s=(0,c.kd)(i,t);e.x+=s*(-2*t)}else if(i<s){const t=(0,c.kd)(i,s);e.x+=t*(-2*s)}}return e}function _(e,t){const[s,i]=t.valid,r=2*i;let n,o=0;return e>i?(n=Math.ceil(Math.abs(e-i)/r),e-=n*r,o=n):e<s&&(n=Math.ceil(Math.abs(e-s)/r),e+=n*r,o=-n),{x:e,frameId:o}}function m(e,t){const{xmin:s,ymin:i,xmax:r,ymax:n}=t;return y(e,s,i)&&y(e,s,n)&&y(e,r,n)&&y(e,r,i)}function y(e,t,s){return t>=e.xmin&&t<=e.xmax&&s>=e.ymin&&s<=e.ymax}function g(e,t,s=!0){const i=!(0,a.Rg)(e);if(i&&(0,o.m3)(e),s)return(new b).cut(e,t);const r=i?e.rings:e.paths,n=i?4:2,c=r.length,l=-2*t;for(let e=0;e<c;e++){const t=r[e];if(t&&t.length>=n){const e=[];for(const[s,...i]of t)e.push([s+l,...i]);r.push(e)}}return i?e.rings=r:e.paths=r,e}class x{constructor(e,t){this.extent=e,this.frameIds=t}}const w=(0,r.vt)();class b{constructor(){this._linesIn=[],this._linesOut=[]}cut(e,t){let s;if(this._xCut=t,e.rings)this._closed=!0,s=e.rings,this._minPts=4;else{if(!e.paths)return null;this._closed=!1,s=e.paths,this._minPts=2}for(const e of s){if(!e||e.length<this._minPts)continue;let t=!0;for(const s of e)t?(this.moveTo(s),t=!1):this.lineTo(s);this._closed&&this.close()}this._pushLineIn(),this._pushLineOut(),s=[];for(const e of this._linesIn)e&&e.length>=this._minPts&&s.push(e);const i=-2*this._xCut;for(const e of this._linesOut)if(e&&e.length>=this._minPts){for(const t of e)t[0]+=i;s.push(e)}return this._closed?e.rings=s:e.paths=s,e}moveTo(e){this._pushLineIn(),this._pushLineOut(),this._prevSide=this._side(e[0]),this._moveTo(e[0],e[1],this._prevSide),this._prevPt=e,this._firstPt=e}lineTo(e){const t=this._side(e[0]);if(t*this._prevSide===-1){const s=this._intersect(this._prevPt,e);this._lineTo(this._xCut,s,0),this._prevSide=0,this._lineTo(e[0],e[1],t)}else this._lineTo(e[0],e[1],t);this._prevSide=t,this._prevPt=e}close(){const e=this._firstPt,t=this._prevPt;e[0]===t[0]&&e[1]===t[1]||this.lineTo(e),this._checkClosingPt(this._lineIn),this._checkClosingPt(this._lineOut)}_moveTo(e,t,s){this._closed?(this._lineIn.push([s<=0?e:this._xCut,t]),this._lineOut.push([s>=0?e:this._xCut,t])):(s<=0&&this._lineIn.push([e,t]),s>=0&&this._lineOut.push([e,t]))}_lineTo(e,t,s){this._closed?(v(this._lineIn,s<=0?e:this._xCut,t),v(this._lineOut,s>=0?e:this._xCut,t)):s<0?(0===this._prevSide&&this._pushLineOut(),this._lineIn.push([e,t])):s>0?(0===this._prevSide&&this._pushLineIn(),this._lineOut.push([e,t])):this._prevSide<0?(this._lineIn.push([e,t]),this._lineOut.push([e,t])):this._prevSide>0&&(this._lineOut.push([e,t]),this._lineIn.push([e,t]))}_checkClosingPt(e){const t=e.length;t>3&&e[0][0]===this._xCut&&e[t-2][0]===this._xCut&&e[1][0]===this._xCut&&(e[0][1]=e[t-2][1],e.pop())}_side(e){return e<this._xCut?-1:e>this._xCut?1:0}_intersect(e,t){const s=(this._xCut-e[0])/(t[0]-e[0]);return e[1]+s*(t[1]-e[1])}_pushLineIn(){this._lineIn&&this._lineIn.length>=this._minPts&&this._linesIn.push(this._lineIn),this._lineIn=[]}_pushLineOut(){this._lineOut&&this._lineOut.length>=this._minPts&&this._linesOut.push(this._lineOut),this._lineOut=[]}}function v(e,t,s){const i=e.length;i>1&&e[i-1][0]===t&&e[i-2][0]===t?e[i-1][1]=s:e.push([t,s])}},37730(e,t,s){s.d(t,{T:()=>r});var i=s(43334);const r={getObjectId:e=>e.objectId,getAttributes:e=>e.attributes,getAttribute:(e,t)=>e.attributes[t],cloneWithGeometry:(e,t,s)=>new i.Om(t,e.attributes,null,e.objectId,e.displayId,e.distance),getGeometry:e=>e.geometry,getCentroid:(e,t)=>e.ensureCentroid(t)}},30624(e,t,s){s.r(t),s.d(t,{createConnection:()=>S});var i=s(5482),r=s(11254),n=s(49186),o=s(53966),a=s(84952),c=s(91429),l=s(16930),u=s(65864),h=s(17676),d=s(62815),p=s(65529);let f=class extends p.nJ{destroy(){this.emit("destroy")}get connectionError(){return this.errorString?new n.A("stream-connection",this.errorString):null}onFeature(e){this.emit("data-received",e)}onMessage(e){this.emit("message-received",e)}};(0,i.Cg)([(0,c.MZ)({readOnly:!0})],f.prototype,"connectionError",null),f=(0,i.Cg)([(0,c.$K)("esri.layers.support.StreamConnection")],f);let _=class extends f{constructor(e){super({}),this._outstandingMessages=[],this.errorString=null;const{geometryType:t,spatialReference:s,sourceSpatialReference:i}=e;this._config=e,this._featureZScaler=(0,d.N)(t,i,s),this._open()}normalizeCtorArgs(){return{}}async _open(){await this._tryCreateWebSocket(),this.destroyed||await this._handshake()}destroy(){super.destroy(),null!=this._websocket&&(this._websocket.onopen=null,this._websocket.onclose=null,this._websocket.onerror=null,this._websocket.onmessage=null,this._websocket.close()),this._websocket=null}get connectionStatus(){if(null==this._websocket)return"disconnected";switch(this._websocket.readyState){case 0:case 1:return"connected";case 2:case 3:return"disconnected"}}sendMessageToSocket(e){null!=this._websocket?this._websocket.send(JSON.stringify(e)):this._outstandingMessages.push(e)}sendMessageToClient(e){this._onMessage(e)}updateCustomParameters(e){this._config.customParameters=e,null!=this._websocket&&this._websocket.close()}async _tryCreateWebSocket(e=this._config.source.path,t=1e3,s=0){try{if(this.destroyed)return;const t=(0,a.a6)(e,this._config.customParameters??{});this._websocket=await this._createWebSocket(t),this.notifyChange("connectionStatus")}catch(i){const r=t/1e3;return this._config.maxReconnectionAttempts&&s>=this._config.maxReconnectionAttempts?(o.A.getLogger(this).error(new n.A("websocket-connection","Exceeded maxReconnectionAttempts attempts. No further attempts will be made")),void this.destroy()):(o.A.getLogger(this).error(new n.A("websocket-connection",`Failed to connect. Attempting to reconnect in ${r}s`,i)),await(0,h.Pl)(t),this._tryCreateWebSocket(e,Math.min(1.5*t,1e3*this._config.maxReconnectionInterval),s+1))}}_setWebSocketJSONParseHandler(e){e.onmessage=e=>{try{const t=JSON.parse(e.data);this._onMessage(t)}catch(e){return void o.A.getLogger(this).error(new n.A("websocket-connection","Failed to parse message, invalid JSON",{error:e}))}}}_createWebSocket(e){return new Promise((t,s)=>{const i=new WebSocket(e);i.onopen=()=>{if(i.onopen=null,this.destroyed)return i.onclose=null,void i.close();i.onclose=e=>this._onClose(e),i.onerror=e=>this._onError(e),this._setWebSocketJSONParseHandler(i),t(i)},i.onclose=e=>{i.onopen=i.onclose=null,s(e)}})}async _handshake(e=1e4){const t=this._websocket;if(null==t)return;const s=Promise.withResolvers(),i=t.onmessage,{filter:r,outFields:a,spatialReference:c}=this._config,l=setTimeout(()=>s.reject(),e),u=()=>{clearTimeout(l),s.reject()};return t.onmessage=e=>{let h=null;try{h=JSON.parse(e.data)}catch(e){}h&&"object"==typeof h||(o.A.getLogger(this).error(new n.A("websocket-connection","Protocol violation. Handshake failed - malformed message",e.data)),u(),this.destroy()),h.spatialReference?.wkid!==c?.wkid&&(o.A.getLogger(this).error(new n.A("websocket-connection",`Protocol violation. Handshake failed - expected wkid of ${c.wkid}`,e.data)),u(),this.destroy()),"json"!==h.format&&(o.A.getLogger(this).error(new n.A("websocket-connection","Protocol violation. Handshake failed - format is not set",e.data)),u(),this.destroy()),r&&h.filter!==r&&o.A.getLogger(this).error(new n.A("websocket-connection","Tried to set filter, but server doesn't support it")),a&&h.outFields!==a&&o.A.getLogger(this).error(new n.A("websocket-connection","Tried to set outFields, but server doesn't support it")),t.onmessage=i;for(const e of this._outstandingMessages)t.send(JSON.stringify(e));this._outstandingMessages=[],clearTimeout(l),s.resolve()},t.send(JSON.stringify({filter:r,outFields:a,format:"json",spatialReference:{wkid:c.wkid}})),s.promise}_onMessage(e){if(this.onMessage(e),"type"in e)switch(e.type){case"features":case"featureResult":for(const t of e.features)null!=this._featureZScaler&&this._featureZScaler(t.geometry),this.onFeature(t)}}_onError(e){const t="Encountered an error over WebSocket connection";this._set("errorString",t),o.A.getLogger(this).error("websocket-connection",t)}_onClose(e){this._websocket=null,this.notifyChange("connectionStatus"),1e3!==e.code&&o.A.getLogger(this).error("websocket-connection",`WebSocket closed unexpectedly with error code ${e.code}`),this.destroyed||this._open()}};(0,i.Cg)([(0,c.MZ)()],_.prototype,"connectionStatus",null),(0,i.Cg)([(0,c.MZ)()],_.prototype,"errorString",void 0),_=(0,i.Cg)([(0,c.$K)("esri.layers.graphics.sources.connections.WebSocketConnection")],_);var m=s(80893),y=s(61956);const g={maxQueryDepth:5,maxRecordCountFactor:3};let x=class extends _{constructor(e){super({...g,...e}),this._buddyServicesQuery=null,this._relatedFeatures=null}async _open(){const e=await this._fetchServiceDefinition(this._config.source);e.timeInfo.trackIdField||o.A.getLogger(this).warn("GeoEvent service was configured without a TrackIdField. This may result in certain functionality being disabled. The purgeOptions.maxObservations property will have no effect.");const t=this._fetchWebSocketUrl(e.streamUrls,this._config.spatialReference);this._buddyServicesQuery||(this._buddyServicesQuery=this._queryBuddyServices()),await this._buddyServicesQuery,await this._tryCreateWebSocket(t);const{filter:s,outFields:i}=this._config;this.destroyed||this._setFilter(s,i)}_onMessage(e){if("attributes"in e){let t;try{t=this._enrich(e),null!=this._featureZScaler&&this._featureZScaler(t.geometry)}catch(e){return void o.A.getLogger(this).error(new n.A("geoevent-connection","Failed to parse message",e))}this.onFeature(t)}else this.onMessage(e)}async _fetchServiceDefinition(e){const t={f:"json",...this._config.customParameters},s=(0,r.A)(e.path,{query:t,responseType:"json"}),i=(await s).data;return this._serviceDefinition=i,i}_fetchWebSocketUrl(e,t){const s=e[0],{urls:i,token:r}=s,n=this._inferWebSocketBaseUrl(i);return(0,a.a6)(`${n}/subscribe`,{outSR:""+t.wkid,token:r})}_inferWebSocketBaseUrl(e){if(1===e.length)return e[0];for(const t of e)if(t.includes("wss"))return t;return o.A.getLogger(this).error(new n.A("geoevent-connection","Unable to infer WebSocket url",e)),null}async _setFilter(e,t){const s=this._websocket;if(null==s||null==e&&null==t)return;const i=JSON.stringify({filter:this._serializeFilter(e,t)});let r=!1;const a=Promise.withResolvers();return s.onmessage=e=>{const t=JSON.parse(e.data);t.filter&&(t.error&&(o.A.getLogger(this).error(new n.A("geoevent-connection","Failed to set service filter",t.error)),this._set("errorString",`Could not set service filter - ${t.error}`),a.reject(t.error)),this._setWebSocketJSONParseHandler(s),r=!0,a.resolve())},s.send(i),setTimeout(()=>{r||(this.destroyed||this._websocket!==s||o.A.getLogger(this).error(new n.A("geoevent-connection","Server timed out when setting filter")),a.reject())},1e4),a.promise}_serializeFilter(e,t){const s={};if(null==e&&null==t)return s;if(e?.geometry)try{const t=(0,u.rS)(e.geometry);if("extent"!==t.type)throw new n.A("geoevent-connection",`Expected extent but found type ${t.type}`);s.geometry=JSON.stringify(t.shiftCentralMeridian())}catch(e){o.A.getLogger(this).error(new n.A("geoevent-connection","Encountered an error when setting connection geometryDefinition",e))}return e?.where&&"1 = 1"!==e.where&&"1=1"!==e.where&&(s.where=e.where),null!=t&&(s.outFields=t.join(",")),s}_enrich(e){if(!this._relatedFeatures)return e;const t=this._serviceDefinition.relatedFeatures.joinField,s=e.attributes[t],i=this._relatedFeatures.get(s);if(!i)return o.A.getLogger(this).warn("geoevent-connection","Feature join failed. Is the join field configured correctly?",e),e;const{attributes:r,geometry:a}=i;for(const t in r)e.attributes[t]=r[t];return a&&(e.geometry=a),e.geometry||e.centroid||o.A.getLogger(this).error(new n.A("geoevent-connection","Found malformed feature - no geometry found",e)),e}async _queryBuddyServices(){try{const{relatedFeatures:e,keepLatestArchive:t}=this._serviceDefinition,s=this._queryRelatedFeatures(e),i=this._queryArchive(t);await s;const r=await i;if(!r)return;for(const e of r.features)this.onFeature(this._enrich(e))}catch(e){o.A.getLogger(this).error(new n.A("geoevent-connection","Encountered an error when querying buddy services",{error:e}))}}async _queryRelatedFeatures(e){if(!e)return;const t=await this._queryBuddy(e.featuresUrl);this._addRelatedFeatures(t)}async _queryArchive(e){if(e)return this._queryBuddy(e.featuresUrl)}async _queryBuddy(e){const t=new((await Promise.all([s.e(7632),s.e(8278),s.e(7865),s.e(6554),s.e(2869),s.e(3910),s.e(9953),s.e(1733),s.e(1214),s.e(8399),s.e(1017),s.e(4674),s.e(6606),s.e(8589),s.e(7609),s.e(812),s.e(4460)]).then(s.bind(s,18589))).default)({url:e}),{capabilities:i}=await t.load(),r=i.query.supportsMaxRecordCountFactor,n=i.query.supportsPagination,o=i.query.supportsCentroid,a=this._config.maxRecordCountFactor,c=t.capabilities.query.maxRecordCount,u=r?c*a:c,h=new y.A;if(h.outFields=this._config.outFields??["*"],h.where=this._config.filter?.where??"1=1",h.returnGeometry=!0,h.returnExceededLimitFeatures=!0,h.outSpatialReference=l.A.fromJSON(this._config.spatialReference),o&&(h.returnCentroid=!0),r&&(h.maxRecordCountFactor=a),n)return h.num=u,t.destroy(),this._queryPages(e,h);const d=await(0,m.eW)(e,h,this._config.sourceSpatialReference);return t.destroy(),d}async _queryPages(e,t,s=[],i=0){t.start=null!=t.num?i*t.num:null;const r=await(0,m.eW)(e,t,this._config.sourceSpatialReference);return r.exceededTransferLimit&&i<(this._config.maxQueryDepth??0)?(r.features.forEach(e=>s.push(e)),this._queryPages(e,t,s,i+1)):(s.forEach(e=>r.features.push(e)),r)}_addRelatedFeatures(e){const t=new Map,s=e.features,i=this._serviceDefinition.relatedFeatures.joinField;for(const e of s){const s=e.attributes[i];t.set(s,e)}this._relatedFeatures=t}};x=(0,i.Cg)([(0,c.$K)("esri.layers.graphics.sources.connections.GeoEventConnection")],x);var w=s(64108);let b=class extends f{constructor(e){super({}),this.connectionStatus="connected",this.errorString=null;const{geometryType:t,spatialReference:s,sourceSpatialReference:i}=e;this._featureZScaler=(0,d.N)(t,i,s)}normalizeCtorArgs(){return{}}updateCustomParameters(e){}sendMessageToSocket(e){}sendMessageToClient(e){if("type"in e)switch(e.type){case"features":case"featureResult":for(const t of e.features)null!=this._featureZScaler&&this._featureZScaler(t.geometry),this.onFeature(t)}this.onMessage(e)}};function v(e,t){if(null==e&&null==t)return null;const s={};return null!=t&&(s.geometry=t),null!=e&&(s.where=e),s}function S(e,t,s,i,r,n,o,a,c){const l={source:e,sourceSpatialReference:t,spatialReference:s,geometryType:i,filter:v(r,n),maxReconnectionAttempts:o,maxReconnectionInterval:a,customParameters:c};return e?e.path.startsWith("wss://")||e.path.startsWith("ws://")?new _(l):new x(l):new b(l)}(0,i.Cg)([(0,c.MZ)()],b.prototype,"connectionStatus",void 0),(0,i.Cg)([(0,c.MZ)()],b.prototype,"errorString",void 0),b=(0,i.Cg)([(0,w.$)("esri.layers.support.ClientSideConnection")],b)},85113(e,t,s){s.d(t,{BM:()=>T,bd:()=>k,sO:()=>I,xD:()=>h});var i=s(67482),r=s(49186),n=s(21325),o=s(90708),a=s(43334),c=s(92722),l=s(30524);const u={LineString:"esriGeometryPolyline",MultiLineString:"esriGeometryPolyline",MultiPoint:"esriGeometryMultipoint",Point:"esriGeometryPoint",Polygon:"esriGeometryPolygon",MultiPolygon:"esriGeometryPolygon"};function h(e){return u[e]}function*d(e){switch(e.type){case"Feature":yield e;break;case"FeatureCollection":for(const t of e.features)t&&(yield t)}}function*p(e){if(e)switch(e.type){case"Point":yield e.coordinates;break;case"LineString":case"MultiPoint":yield*e.coordinates;break;case"MultiLineString":case"Polygon":for(const t of e.coordinates)yield*t;break;case"MultiPolygon":for(const t of e.coordinates)for(const e of t)yield*e}}function f(e){for(const t of e)if(t.length>2)return!0;return!1}function _(e){let t=0;for(let s=0;s<e.length;s++){const i=e[s],r=e[(s+1)%e.length];t+=i[0]*r[1]-r[0]*i[1]}return t<=0}function m(e){const t=e[0],s=e[e.length-1];t[0]===s[0]&&t[1]===s[1]&&t[2]===s[2]||e.push(t)}function y(e,t){const{coordinates:s,type:i}=e,r=t.hasZ??!1,n=!0;switch(i){case"Point":return new c.A([],[...s],r,!1);case"LineString":return(0,o.Ap)({paths:[s],hasZ:n},r,!1);case"MultiLineString":return(0,o.Ap)({paths:s,hasZ:n},r,!1);case"MultiPoint":return(0,o.PR)({points:s,hasZ:n},r,!1);case"Polygon":case"MultiPolygon":{const e=new c.A([],[],r,!1);for(const t of"Polygon"===i?[s]:s){g(e,t[0],r);for(let s=1;s<t.length;s++)x(e,t[s],r)}return e}}}function g(e,t,s){m(t),function(e){return!_(e)}(t)?b(e,t,s):w(e,t,s)}function x(e,t,s){m(t),function(e){return _(e)}(t)?b(e,t,s):w(e,t,s)}function w(e,t,s){for(const i of t)v(e,i,s);e.lengths.push(t.length)}function b(e,t,s){for(let i=t.length-1;i>=0;i--)v(e,t[i],s);e.lengths.push(t.length)}function v(e,[t,s,i],r){e.coords.push(t,s),r&&e.coords.push(i||0)}function S(e){switch(typeof e){case"string":return(0,i.Br)(e)?"esriFieldTypeDate":"esriFieldTypeString";case"number":return"esriFieldTypeDouble";default:return"unknown"}}function I(e,t=4326){if(!e)throw new r.A("geojson-layer:empty","GeoJSON data is empty");if("Feature"!==e.type&&"FeatureCollection"!==e.type)throw new r.A("geojson-layer:unsupported-geojson-object","missing or not supported GeoJSON object type",{data:e});const{crs:s}=e;if(!s)return;const i="string"==typeof s?s:"name"===s.type?s.properties.name:"EPSG"===s.type?s.properties.code:null,o=(0,n.oT)({wkid:t})?new RegExp(".*(CRS84H?|4326)$","i"):new RegExp(`.*(${t})$`,"i");if(!i||!o.test(i))throw new r.A("geojson:unsupported-crs","unsupported GeoJSON 'crs' member",{crs:s})}function T(e,t={}){const s=[],i=new Set,r=new Set;let n,o=!1,a=null,c=!1,{geometryType:u=null}=t;for(const t of d(e)){const{geometry:e,properties:d,id:_}=t;if((!e||(u||(u=h(e.type)),h(e.type)===u))&&(o||(o=f(p(e))),c||(c=null!=_,c&&(n=typeof _,d&&(a=Object.keys(d).filter(e=>d[e]===_)))),d&&a&&c&&null!=_&&(a.length>1?a=a.filter(e=>d[e]===_):1===a.length&&(a=d[a[0]]===_?a:[])),d))for(const e in d){if(i.has(e))continue;const t=S(d[e]);if("unknown"===t){r.add(e);continue}r.delete(e),i.add(e);const n=(0,l.rS)(e);n&&s.push({name:n,alias:e,type:t})}}const _=(0,l.rS)(1===a?.length&&a[0]||null)??void 0;if(_)for(const e of s)if(e.name===_&&(0,l.WA)(e)){e.type="esriFieldTypeOID";break}return{fields:s,geometryType:u,hasZ:o,objectIdFieldName:_,objectIdFieldType:n,unknownFields:Array.from(r)}}function k(e,t){return Array.from(function*(e,t={}){const{geometryType:s,objectIdField:i}=t;for(const r of e){const{geometry:e,properties:n,id:o}=r;if(e&&h(e.type)!==s)continue;const c=n||{};let l;i&&(l=c[i],null==o||l||(c[i]=l=o)),yield new a.Om(e&&y(e,t),c,null,l)}}(d(e),t))}},82832(e,t,s){s.d(t,{$1:()=>m,CR:()=>_,MB:()=>d,PC:()=>y,Yx:()=>c,bP:()=>u});var i=s(67482),r=s(21325),n=s(30524);class o{constructor(e){this.description=e,this.code=null}}class a{constructor(e){this.globalId=null,this.objectId=null,this.success=!1,this.uniqueId=null,this.error=new o(e)}}function c(e){return new a(e)}class l{constructor(e){this.globalId=null,this.success=!0,this.objectId=this.uniqueId=e}}function u(e){return new l(e)}const h=new Set;function d(e,t,s,i=!1){h.clear();for(const r in s){const o=e.get(r);if(!o)continue;const a=p(o,s[r]);if(h.add(o.name),o&&(i||o.editable)){const e=(0,n.CJ)(o,a);if(e)return c((0,n.uo)(e,o,a));t[o.name]=a}}for(const t of e.requiredFields??[])if(!h.has(t.name))return c(`missing required field "${t.name}"`);return null}function p(e,t){let s=t;return(0,n.WA)(e)&&"string"==typeof t?s=parseFloat(t):(0,n.yM)(e)&&null!=t&&"string"!=typeof t?s=String(t):(0,n.vE)(e)&&"string"==typeof t&&(s=(0,i._U)(t)),(0,n.WX)(s)}let f;function _(e,t){if(!e||!(0,r.fn)(t))return e;if("rings"in e||"paths"in e){if(null==f)throw new TypeError("geometry engine not loaded");return f.simplify(t,e)}return e}async function m(e,t){!(0,r.fn)(e)||"esriGeometryPolygon"!==t&&"esriGeometryPolyline"!==t||await async function(){return null==f&&(f=await s.e(1023).then(s.bind(s,81023))),f}()}const y={supportsAutoIntervalBin:!0,supportsFixedIntervalBin:!0,supportsFixedBoundariesBin:!0,supportsDateBin:!0,supportsStackBy:!0,supportsSplitBy:!0,supportsNormalization:!0,supportedStatisticTypes:["COUNT","SUM","AVG","VAR","STDDEV","MIN","MAX","PERCENTILE_CONT","PERCENTILE_DISC","CentroidAggregate","EnvelopeAggregate","ConvexHullAggregate"],supportedNormalizationTypes:["field","log","naturalLog","percentOfTotal","squareRoot"]}},75321(e,t,s){s.d(t,{CJ:()=>I,GA:()=>A,GL:()=>S,I:()=>F,J0:()=>M,Ki:()=>k,Px:()=>T,QE:()=>v,bW:()=>C,vJ:()=>b});var i=s(11254),r=s(49186),n=s(53966),o=s(84952),a=s(16930),c=s(21325),l=s(28735),u=s(90708),h=s(58512),d=s(85113),p=s(64714),f=s(82832),_=s(95466),m=s(98453),y=s(98623);const g=()=>n.A.getLogger("esri.layers.ogc.ogcFeatureUtils"),x="startindex",w=new Set([x,"offset"]),b="http://www.opengis.net/def/crs/",v=`${b}OGC/1.3/CRS84`;async function S(e,t,s={},n=5){const{links:a}=e,c=z(a);if(!c)throw new r.A("ogc-feature-layer:missing-items-page","Missing items url");const{apiKey:l,customParameters:u,signal:h}=s,f=(0,o.s2)(c.href,e.landingPage.url),w={limit:n,...u,token:l},b=(0,o.a6)(f,w),{data:v}=await(0,i.A)(b,{signal:h,headers:{accept:"application/geo+json"}}),S=N(b,n,v.links)??x;(0,d.sO)(v);const I=v.numberMatched,T=(0,d.BM)(v,{geometryType:t.geometryType}),k=t.fields||T.fields||[],A=null!=t.hasZ?t.hasZ:T.hasZ,M=T.geometryType,C=t.objectIdField||T.objectIdFieldName||"OBJECTID";let F=t.timeInfo;const E=k.find(({name:e})=>e===C);if(E)E.editable=!1,E.nullable=!1;else{if(!T.objectIdFieldType)throw new r.A("ogc-feature-layer:missing-feature-id","Collection geojson require a feature id as a unique identifier");k.unshift({name:C,alias:C,type:"number"===T.objectIdFieldType?"esriFieldTypeOID":"esriFieldTypeString",editable:!1,nullable:!1})}if(C!==T.objectIdFieldName){const e=k.find(({name:e})=>e===T.objectIdFieldName);e&&(e.type="esriFieldTypeInteger")}k===T.fields&&T.unknownFields.length>0&&g().warn({name:"ogc-feature-layer:unknown-field-types",message:"Some fields types couldn't be inferred from the features and were dropped",details:{unknownFields:T.unknownFields}});for(const e of k){if(e.name??=e.alias,e.alias??=e.name,"esriFieldTypeOID"!==e.type&&"esriFieldTypeGlobalID"!==e.type&&(e.editable??=!0,e.nullable??=!0),!e.name)throw new r.A("ogc-feature-layer:invalid-field-name","field name is missing",{field:e});if(!m.m.jsonValues.includes(e.type))throw new r.A("ogc-feature-layer:invalid-field-type",`invalid type for field "${e.name}"`,{field:e})}if(F){const e=new _.A(k);if(F.startTimeField){const t=e.get(F.startTimeField);t?(F.startTimeField=t.name,t.type="esriFieldTypeDate"):F.startTimeField=null}if(F.endTimeField){const t=e.get(F.endTimeField);t?(F.endTimeField=t.name,t.type="esriFieldTypeDate"):F.endTimeField=null}if(F.trackIdField){const t=e.get(F.trackIdField);t?F.trackIdField=t.name:(F.trackIdField=null,g().warn({name:"ogc-feature-layer:invalid-timeInfo-trackIdField",message:"trackIdField is missing",details:{timeInfo:F}}))}F.timeReference||={timeZoneIANA:y.n$},F.startTimeField||F.endTimeField||(g().warn({name:"ogc-feature-layer:invalid-timeInfo",message:"startTimeField and endTimeField are missing",details:{timeInfo:F}}),F=void 0)}return{drawingInfo:M?(0,p.F0)(M):null,extent:O(e),geometryType:M,fields:k,hasZ:!!A,objectIdField:C,paginationParameter:S,timeInfo:F,featureCount:I}}async function I(e,t={}){const{links:s,url:n}=e,a=L(c=s,"data","application/json")??L(c,"http://www.opengis.net/def/rel/ogc/1.0/data","application/json");var c;if(!a)throw new r.A("ogc-feature-layer:missing-collections-page","Missing collections url");const{apiKey:l,customParameters:u,signal:h}=t,d=(0,o.s2)(a.href,n),{data:p}=await(0,i.A)(d,{signal:h,headers:{accept:"application/json"},query:{...u,token:l}});for(const t of p.collections)t.landingPage=e;return p}async function T(e,t={}){const{links:s,url:n}=e,a=L(c=s,"conformance","application/json")??L(c,"http://www.opengis.net/def/rel/ogc/1.0/conformance","application/json");var c;if(!a)throw new r.A("ogc-feature-layer:missing-conformance-page","Missing conformance url");const{apiKey:l,customParameters:u,signal:h}=t,d=(0,o.s2)(a.href,n),{data:p}=await(0,i.A)(d,{signal:h,headers:{accept:"application/json"},query:{...u,token:l}});return p}async function k(e,t={}){const{apiKey:s,customParameters:r,signal:n}=t,{data:o}=await(0,i.A)(e,{signal:n,headers:{accept:"application/json"},query:{...r,token:s}});return o.url=e,o}async function A(e,t={}){const{links:s,url:r}=e,n=L(s,"service-desc","application/vnd.oai.openapi+json;version=3.0");if(!n)return g().warn("ogc-feature-layer:missing-openapi-page","The OGC API-Features server does not have an OpenAPI page."),null;const{apiKey:a,customParameters:c,signal:l}=t,u=(0,o.s2)(n.href,r),{data:h}=await(0,i.A)(u,{signal:l,headers:{accept:"application/vnd.oai.openapi+json;version=3.0"},query:{...c,token:a}});return h}function M(e){const t=/^http:\/\/www\.opengis.net\/def\/crs\/(?<authority>.*)\/(?<version>.*)\/(?<code>.*)$/i.exec(e),s=t?.groups;if(!s)return null;const{authority:i,code:r}=s;switch(i.toLowerCase()){case"ogc":switch(r.toLowerCase()){case"crs27":return a.A.GCS_NAD_1927.wkid;case"crs83":return 4269;case"crs84":case"crs84h":return a.A.WGS84.wkid;default:return null}case"esri":case"epsg":{const e=Number.parseInt(r,10);return Number.isNaN(e)?null:e}default:return null}}async function C(e,t,s){const i=await F(e,t,s);return(0,u.ZF)(i)}async function F(e,t,s){const{collection:{links:n,landingPage:{url:p}},layerDefinition:m,maxRecordCount:y,queryParameters:{apiKey:g,customParameters:x},spatialReference:w,supportedCrs:b}=e,v=z(n);if(!v)throw new r.A("ogc-feature-layer:missing-items-page","Missing items url");const{geometry:S,num:I,start:T,timeExtent:k,where:A}=t;if(t.objectIds)throw new r.A("ogc-feature-layer:query-by-objectids-not-supported","Queries with object ids are not supported");const M=a.A.fromJSON(w),C=t.outSpatialReference??M,F=C.isWGS84?null:E(C,b),P=R(S,b),O=function(e){if(!e)return null;const{start:t,end:s}=e;return`${null!=t?t.toISOString():".."}/${null!=s?s.toISOString():".."}`}(k),L=(Q=A)&&"1=1"!==Q?Q:null,N=I??(null==T?y:10),q=0===T?void 0:T,{fields:B,geometryType:G,hasZ:U,objectIdField:j,paginationParameter:W}=m,V=(0,o.s2)(v.href,p),{data:Y}=await(0,i.A)(V,{...s,query:{...x,...P,crs:F,datetime:O,query:L,limit:N,[W]:q,token:g},headers:{accept:"application/geo+json"}}),$=(0,d.bd)(Y,{geometryType:G,hasZ:U,objectIdField:j}),H=$.length===N&&!!D(Y.links??[]),Z=new _.A(B);var Q;for(const e of $){const t={};(0,f.MB)(Z,t,e.attributes,!0);for(const e of Z.fields)e.nullable&&!(e.name in t)&&(t[e.name]=null);t[j]=e.attributes[j],e.attributes=t}if(!F&&C.isWebMercator)for(const e of $)if(null!=e.geometry&&null!=G){const t=(0,u.zv)(e.geometry,G,U,!1);t.spatialReference=a.A.WGS84,e.geometry=(0,u.Ux)((0,l.Cv)(t,C))}for(const e of $)e.objectId=e.attributes[j];const X=F||!F&&C.isWebMercator?C.toJSON():c.KK,K=new h.A;return K.exceededTransferLimit=H,K.features=$,K.fields=B,K.geometryType=G,K.hasZ=U,K.spatialReference=X,K}function E(e,t){const{isWebMercator:s,wkid:i,latestWkid:r}=e;if(!i&&!r)return null;const n=s?t[3857]??t[102100]??t[102113]??t[900913]:i&&t[i]||r&&t[r];return n?`${b}${n}`:null}function P(e){if(!e)return"";const{xmin:t,ymin:s,xmax:i,ymax:r}=e;return`${t},${s},${i},${r}`}function R(e,t){if(!function(e){return null!=e&&"extent"===e.type}(e))return null;const{spatialReference:s}=e;if(!s||s.isWGS84)return{bbox:P(e)};const i=E(s,t);return null!=i?{bbox:P(e),"bbox-crs":i}:s.isWebMercator?{bbox:P((0,l.Cv)(e,a.A.WGS84))}:null}function O(e){const t=e.extent?.spatial;if(!t)return null;const s=t.bbox[0],i=4===s.length,[r,n]=s,o=i?void 0:s[2];return{xmin:r,ymin:n,xmax:i?s[2]:s[3],ymax:i?s[3]:s[4],zmin:o,zmax:i?void 0:s[5],spatialReference:a.A.WGS84.toJSON()}}function z(e){return L(e,"items","application/geo+json","http://www.opengis.net/def/profile/ogc/0/rfc7946")??L(e,"http://www.opengis.net/def/rel/ogc/1.0/items","application/geo+json","http://www.opengis.net/def/profile/ogc/0/rfc7946")}function L(e,t,s,i){return i?e.find(({rel:e,type:r,profile:n})=>e===t&&r===s&&n?.includes(i))??e.find(({rel:e,type:i,profile:r})=>e===t&&i===s&&!r):e.find(({rel:e,type:i})=>e===t&&i===s)??e.find(({rel:e,type:s})=>e===t&&!s)}function D(e){return L(e,"next","application/geo+json")}function N(e,t,s){if(!s)return;const i=D(s),r=(0,o.An)(i?.href)?.query;if(!r)return;const n=(0,o.An)(e).query,a=Object.keys(n??{}),c=Object.entries(r).filter(([e])=>!a.includes(e)).find(([e,s])=>w.has(e.toLowerCase())&&Number.parseInt(s,10)===t),l=c?.[0];return l}},41560(e,t,s){s.d(t,{Ch:()=>o,mW:()=>n});var i=s(34727),r=s(39516);function n(e,t){return{...t,filterMode:e.mode}}function o(e,t,s){const n=function(e){if("manual"===l(e))return null;const t=[Number.NEGATIVE_INFINITY,Number.POSITIVE_INFINITY];for(const{minScale:s,maxScale:i}of e.filters)t[0]=Math.max(t[0],u(s)),t[1]=Math.min(t[1],h(i));return t}(e);if(n&&((0,i.gg)(t,n[0])||(0,i.ZH)(s,n[1])))return"";const o=Array.from(a(e,t,s)),c=function(e,t,s){if(0===e.length)return!0;const r=u(e.at(0)?.minScale),n=h(e.at(-1)?.maxScale);if((0,i.ZH)(r,t)||(0,i.gg)(n,s))return!0;for(let t=0;t<e.length-1;t++){const s=e[t],r=e[t+1];if((0,i.ZH)(u(r.minScale),h(s.maxScale)))return!0}return!1}(o,t,s)?"1=1":o.map(e=>e.where||"1=1").reduce((e,t)=>(0,r.IW)(e,t),"");return c&&"1=1"!==c?c:""}function*a(e,t,s){if("manual"===l(e)){const t=e.filters.find(t=>t.id===e.activeFilterId);t&&(yield t)}else{"object"==typeof t&&(t=t.scale);for(const i of e.filters)c(i.minScale,i.maxScale,t,s)&&(yield i)}}function c(e,t,s,r){return e=u(e),s=u(s),t=h(t),!(!(0,i.Sp)(s,e)&&(r??s)>e||(0,i.Hx)(t,s)||void 0!==r&&(0,i.Sp)(r,e))}function l(e){return"mode"in e?e.mode:e.filterMode}function u(e){return e||Number.POSITIVE_INFINITY}function h(e){return e||0}},32730(e,t,s){s.d(t,{BI:()=>p,D3:()=>h,XJ:()=>d,lc:()=>u,mX:()=>_,rU:()=>f,tH:()=>w,vK:()=>b,zA:()=>v});var i=s(799);const r="__begin__",n="__end__",o=new RegExp(r,"ig"),a=new RegExp(n,"ig"),c=new RegExp("^"+r,"i"),l=new RegExp(n+"$","i");function u(e){return e.replaceAll(new RegExp("\\[","g"),"{").replaceAll(new RegExp("\\]","g"),"}")}function h(e){return e.replaceAll(new RegExp("\\{","g"),"[").replaceAll(new RegExp("\\}","g"),"]")}function d(e){const t={expression:"",type:"none"};return e.labelExpressionInfo?e.labelExpressionInfo.value?(t.expression=e.labelExpressionInfo.value,t.type="conventional"):e.labelExpressionInfo.expression&&(t.expression=e.labelExpressionInfo.expression,t.type="arcade"):null!=e.labelExpression&&(t.expression=u(e.labelExpression),t.type="conventional"),t}function p(e){const t=d(e);if(!t)return null;switch(t.type){case"conventional":return _(t.expression);case"arcade":return t.expression}return null}function f(e){const t=d(e);if(!t)return null;switch(t.type){case"conventional":return function(e){const t=e?.match(m);return t?.[1].trim()||null}(t.expression);case"arcade":return w(t.expression)}return null}function _(e){let t;return e?(t=(0,i.HC)(e,e=>r+'$feature["'+e+'"]'+n),t=c.test(t)?t.replace(c,""):'"'+t,t=l.test(t)?t.replace(l,""):t+'"',t=t.replaceAll(o,'" + ').replaceAll(a,' + "')):t='""',t}const m=/^\s*\{([^}]+)\}\s*$/i,y=/^\s*(?:(?:\$feature\.(\w+))|(?:\$feature\[(["'])(.+)(\2)\]));?\s*$/i,g=/^\s*(?:(?:\$feature\.(\w+))|(?:\$feature\[(["'])(.+)(\2)\]));?\s*(?:DomainName\(\s*\$feature\s*,\s*(["'])(\1|\3)(\5)\s*\));?\s*$/i,x=/^\s*(?:DomainName\(\s*\$feature\s*,\s*(["'])(.+)(\1)\s*\));?\s*$/i;function w(e){if(!e)return null;let t=y.exec(e)||g.exec(e);return t?t[1]||t[3]:(t=x.exec(e),t?t[2]:null)}const b=Symbol("LabelClassInstance");function v(e){return null!=e&&"object"==typeof e&&b in e}},72691(e,t,s){s.d(t,{Aw:()=>o,DN:()=>i,EA:()=>n,Gm:()=>r,xq:()=>a});const i="__esri_stream_id__",r="__esri_timestamp__",n="__esri_track_part__",o="__esri_time_received__",a="__esri_track_line__"},73681(e,t,s){s.d(t,{n:()=>c});var i=s(49186),r=s(53966),n=s(46140),o=s(95466),a=s(55674);class c{static async from(e,t,s){const o=e.dictionary_version?n.A.parse(e.dictionary_version):null,u=new Set(e.itemsNames),h={};if(t)for(const e in t)h[e]=t[e];if(e.authoringInfo.configuration)for(const t of e.authoringInfo.configuration)h.hasOwnProperty(t.name)||(h[t.name]=t.value);const d=new Set(e.authoringInfo.symbol);for(const e of Object.keys(s))d.delete(e);d.size&&r.A.getLogger("esri.renderers.support.DictionaryScriptEvaluator").warnOnce("missing-fields: fieldMap entries for the following symbol fields are missing",{symbolFields:d});const p=await(0,a.xR)(e.expression,null,h);if(!p)throw new i.A("dictionary-renderer:expression-error","Unable to create dictionary renderer expression");const f=!o||!o.greaterEqual(4,0);f&&r.A.getLogger("esri.renderers.support.DictionaryScriptEvaluator").warnOnce("Dictionary script does not support native field types. Applying fallback",{version:o});const _=new l(s,f);return new c(f,u,p,_)}constructor(e,t,s,i){this._requiresFieldCoercionToString=e,this._itemNames=t,this._compiled=s,this._reader=i}get itemNames(){return this._itemNames}evaluate(e,t,s,i){try{return this._reader.bind(e,s,i),this._compiled.evaluate(this._reader,{$view:{scale:t}})}catch(e){r.A.getLogger("esri.renderers.support.DictionaryScriptEvaluator").warnOnce("arcade: dictionary script evaluation failed",{error:e})}return null}createDictionaryFieldsIndex(e){if(!this._requiresFieldCoercionToString)return new o.A(e);const t=e.map(e=>({...e,type:"esriFieldTypeString"}));return new o.A(t)}}class l extends a.Gj{constructor(e,t){super(),this._fieldMap=e,this._requiresFieldCoercionToString=t}_getField(e){const t=this._fieldMap[e]??e;return this._boundSchema.fieldsIndex.get(t)}field(e){if(!this._requiresFieldCoercionToString)return super.field(e,!1);const t=this._getField(e);return null==t||null==this._boundTarget.attributes[t.name]?"":""+this._boundTarget.attributes[t.name]}}},55674(e,t,s){s.d(t,{Ad:()=>p,Gj:()=>m,QY:()=>d,lL:()=>y,xR:()=>f});var i=s(66131),r=s(49186),n=(s(44208),s(44729)),o=s(15032),a=s(65864),c=s(95466),l=s(43668),u=s(98623);const h=["geometry","scale","timeProperties"];function d(e,t){if(null!=t)for(const s of h)t.hasArcadeDependency(s)&&e.add(s);return e}function p(e,t){return _.create(e,t,null,["$feature","$view"])}function f(e,t,s){return _.create(e,t,s,["$feature","$view","$config"])}class _{static async create(e,t,s,i){const{arcade:n,Dictionary:o}=await(0,l.l)();let a;try{a=n.parseScript(e)}catch(t){throw new r.A("arcade-bad-expression","Failed to parse arcade script",{script:e,error:t})}const c=n.scriptUsesGeometryEngine(a);c&&await n.enableGeometrySupport(),await n.loadDependentModules(new Set,a,null,!1,c);const u={vars:i.reduce((e,t)=>({...e,[t]:null}),{}),spatialReference:t,useAsync:!1},h=n.compileScript(a,u);let d=null;null!=s&&(d=new o(s),d.immutable=!0);const p=new o;return p.immutable=!1,p.setField("scale",0),new _(e,n,a,h,t,p,d,o)}constructor(e,t,s,i,r,n,o,a){this.script=e,this._arcade=t,this._syntaxTree=s,this._compiled=i,this._spatialReference=r,this._viewDict=n,this._configDict=o,this._dictionaryCtor=a,this._dependencies=new Map,this._featureReader=new m,this._dependencies.set("geometry",t.scriptTouchesGeometry(this._syntaxTree)),this._dependencies.set("scale",this._arcade.referencesMember(this._syntaxTree,"scale")),this._dependencies.set("timeProperties",this._arcade.scriptUsesViewProperties(this._syntaxTree,["timeProperties"]))}evaluate(e,t){const s=t.$view?.timeZone;if(t.$view){let e;if(this._viewDict.setField("scale",t.$view.scale),null!=t.$view.timeProperties){const{currentStart:r,currentEnd:n}=t.$view.timeProperties;e=new this._dictionaryCtor({currentStart:null!=r?null!=s?i.lY.epochToArcadeDate(r,s):i.lY.unknownEpochToArcadeDate(r):void 0,currentEnd:null!=n?null!=s?i.lY.epochToArcadeDate(n,s):i.lY.unknownEpochToArcadeDate(n):void 0,startIncluded:!0,endIncluded:!0})}this._viewDict.setField("timeProperties",e)}return this._compiled({vars:{$view:this._viewDict,$config:this._configDict,$feature:e},spatialReference:this._spatialReference,timeZone:s})}repurposeFeature(e,t){return this._featureReader.bind(e,t,this._spatialReference),this._featureReader}references(e){return this._dependencies.get(e)??!1}}class m{constructor(){this._boundTarget=null,this._boundSchema={fields:null,fieldsIndex:null,spatialReference:null,get geometryType(){return null},get objectIdField(){return null}},this.arcadeDeclaredClass="esri.arcade.Feature",this._contextTimeZone=null}bind(e,t,s){const i=t??new c.A(y(e.attributes));this._boundTarget=e,this._boundSchema.fields=i.fields,this._boundSchema.fieldsIndex=i,this._boundSchema.spatialReference=s}_getField(e){return this._boundSchema.fieldsIndex.get(e)}get contextTimeZone(){return this._contextTimeZone}set contextTimeZone(e){this._contextTimeZone=e}readArcadeFeature(){return this}hasField(e){return this._boundSchema.fieldsIndex.has(e)}geometry(){if("fromJSON"in this._boundTarget)return this._boundTarget.geometry;const e=(0,a.rS)(this._boundTarget.geometry);if(e){if(!this._boundSchema.spatialReference)throw new Error("InternalError: Expected spatial reference to be defined");e.spatialReference=this._boundSchema.spatialReference}return e}_hasGeometry(){return null!=this._boundTarget.geometry}isUnknownDateTimeField(e){return this._boundSchema.fieldsIndex.getTimeZone(e)===u.L5}field(e,t=!0){const s=this._getField(e);if(s){const t=this._boundTarget.attributes[s.name];if(null==t)return null;switch(s.type){case"date-only":case"esriFieldTypeDateOnly":return n.n.fromReader(t);case"time-only":case"esriFieldTypeTimeOnly":return o.k.fromReader(t);case"esriFieldTypeTimestampOffset":case"timestamp-offset":return i.lY.fromReaderAsTimeStampOffset(t);case"date":case"esriFieldTypeDate":return this.isUnknownDateTimeField(e)?i.lY.unknownEpochToArcadeDate(t):i.lY.epochToArcadeDate(t,this.contextTimeZone??u.qU);default:return t}}if(t)throw new Error(`Field ${e} does not exist`);return null}setField(e,t){throw new Error("Unable to update feature attribute values, feature is readonly")}keys(){return this._boundSchema.fieldsIndex.fields.map(e=>e.name)}isEmpty(){return this._boundSchema.fields.length<=0&&!this._hasGeometry()}castToText(e=!1){return JSON.stringify(this._boundTarget)}gdbVersion(){return null}fullSchema(){return this._boundSchema}castAsJson(e=null){return{attributes:this._boundTarget.attributes,geometry:!0===e?.keepGeometryType?this.geometry():this.geometry()?.toJSON()??null}}castAsJsonAsync(e=null,t=null){return Promise.resolve(this.castAsJson(t))}}function y(e){const t=[];for(const s in e)t.push({name:s,alias:s,type:"string"==typeof e[s]?"esriFieldTypeString":"esriFieldTypeDouble"});return t}},11831(e,t,s){s.d(t,{A:()=>l});var i,r=s(5482),n=s(25482),o=s(90629),a=s(91429),c=s(5760);let l=i=class extends n.o{constructor(e){super(e),this.decoration="none",this.family="sans-serif",this.style="normal",this.weight="normal"}get size(){return this._get("size")??9}set size(e){this._set("size",e)}castSize(e){return(0,o.cr)(e)}clone(){return new i({decoration:this.decoration,family:this.family,size:this.size,style:this.style,weight:this.weight})}hash(){return`${this.decoration}.${this.family}.${this.size}.${this.style}.${this.weight}`}};(0,r.Cg)([(0,a.MZ)({type:c.h9,json:{default:"none",write:!0}})],l.prototype,"decoration",void 0),(0,r.Cg)([(0,a.MZ)({type:String,json:{write:!0}})],l.prototype,"family",void 0),(0,r.Cg)([(0,a.MZ)({type:Number,json:{write:{overridePolicy:(e,t,s)=>({enabled:!s||!s.textSymbol3D})}}})],l.prototype,"size",null),(0,r.Cg)([(0,a.wg)("size")],l.prototype,"castSize",null),(0,r.Cg)([(0,a.MZ)({type:c._R,json:{default:"normal",write:!0}})],l.prototype,"style",void 0),(0,r.Cg)([(0,a.MZ)({type:c.NM,json:{default:"normal",write:!0}})],l.prototype,"weight",void 0),l=i=(0,r.Cg)([(0,a.$K)("esri.symbols.Font")],l)},68249(e,t,s){s.d(t,{A:()=>f});var i,r=s(5482),n=s(68197),o=s(4718),a=s(90629),c=s(91429),l=s(11831),u=s(20378),h=s(5760),d=s(93223),p=s(43937);let f=i=class extends u.A{constructor(...e){super(...e),this.backgroundColor=null,this.borderLineColor=null,this.borderLineSize=null,this.font=new l.A,this.horizontalAlignment="center",this.kerning=!0,this.haloColor=null,this.rightToLeft=null,this.rotated=!1,this.text="",this.type="text",this.verticalAlignment="baseline",this.angle=0,this.width=null,this.lineHeight=1}normalizeCtorArgs(e,t,s){if(e&&"string"!=typeof e)return e;const i={};return e&&(i.text=e),t&&(i.font=t),s&&(i.color=s),i}get haloSize(){return this._get("haloSize")??null}set haloSize(e){this._set("haloSize",e)}get xoffset(){return this._get("xoffset")??0}set xoffset(e){this._set("xoffset",e)}get yoffset(){return this._get("yoffset")??0}set yoffset(e){this._set("yoffset",e)}get lineWidth(){return this._get("lineWidth")??192}set lineWidth(e){this._set("lineWidth",e)}writeLineWidth(e,t,s,i){i&&"string"!=typeof i?i.origin:t[s]=e}castLineWidth(e){return(0,a.cr)(e)}writeLineHeight(e,t,s,i){i&&"string"!=typeof i?i.origin:t[s]=e}clone(){return new i({angle:this.angle,backgroundColor:(0,o.o8)(this.backgroundColor),borderLineColor:(0,o.o8)(this.borderLineColor),borderLineSize:this.borderLineSize,color:(0,o.o8)(this.color),font:this.font&&this.font.clone(),haloColor:(0,o.o8)(this.haloColor),haloSize:this.haloSize,horizontalAlignment:this.horizontalAlignment,kerning:this.kerning,lineHeight:this.lineHeight,lineWidth:this.lineWidth,rightToLeft:this.rightToLeft,rotated:this.rotated,text:this.text,verticalAlignment:this.verticalAlignment,width:this.width,xoffset:this.xoffset,yoffset:this.yoffset})}hash(){return`${this.backgroundColor?.hash()}.${this.borderLineColor}.${this.borderLineSize}.${this.color?.hash()}.${this.font&&this.font.hash()}.${this.haloColor?.hash()}.${this.haloSize}.${this.horizontalAlignment}.${this.kerning}.${this.rightToLeft}.${this.rotated}.${this.text}.${this.verticalAlignment}.${this.width}.${this.xoffset}.${this.yoffset}.${this.lineHeight}.${this.lineWidth}.${this.angle}`}};(0,r.Cg)([(0,c.MZ)({type:n.A,json:{write:!0}})],f.prototype,"backgroundColor",void 0),(0,r.Cg)([(0,c.MZ)({type:n.A,json:{write:!0}})],f.prototype,"borderLineColor",void 0),(0,r.Cg)([(0,c.MZ)({type:Number,json:{write:!0},cast:a.cr})],f.prototype,"borderLineSize",void 0),(0,r.Cg)([(0,c.MZ)({type:l.A,json:{write:!0}})],f.prototype,"font",void 0),(0,r.Cg)([(0,c.MZ)({...h.rM,json:{write:!0}})],f.prototype,"horizontalAlignment",void 0),(0,r.Cg)([(0,c.MZ)({type:Boolean,json:{write:!0}})],f.prototype,"kerning",void 0),(0,r.Cg)([(0,c.MZ)({type:n.A,json:{write:!0}})],f.prototype,"haloColor",void 0),(0,r.Cg)([(0,c.MZ)({type:Number,cast:a.cr,json:{write:!0}})],f.prototype,"haloSize",null),(0,r.Cg)([(0,c.MZ)({type:Boolean,json:{write:!0}})],f.prototype,"rightToLeft",void 0),(0,r.Cg)([(0,c.MZ)({type:Boolean,json:{write:!0}})],f.prototype,"rotated",void 0),(0,r.Cg)([(0,c.MZ)({type:String,json:{write:!0}})],f.prototype,"text",void 0),(0,r.Cg)([(0,d.e)({esriTS:"text"},{readOnly:!0})],f.prototype,"type",void 0),(0,r.Cg)([(0,c.MZ)({...h.x0,json:{write:!0}})],f.prototype,"verticalAlignment",void 0),(0,r.Cg)([(0,c.MZ)({type:Number,cast:a.cr,json:{write:!0}})],f.prototype,"xoffset",null),(0,r.Cg)([(0,c.MZ)({type:Number,cast:a.cr,json:{write:!0}})],f.prototype,"yoffset",null),(0,r.Cg)([(0,c.MZ)({type:Number,json:{read:e=>e&&-1*e,write:(e,t)=>t.angle=e&&-1*e}})],f.prototype,"angle",void 0),(0,r.Cg)([(0,c.MZ)({type:Number,json:{write:!0}})],f.prototype,"width",void 0),(0,r.Cg)([(0,c.MZ)({type:Number})],f.prototype,"lineWidth",null),(0,r.Cg)([(0,p.K)("lineWidth")],f.prototype,"writeLineWidth",null),(0,r.Cg)([(0,c.wg)("lineWidth")],f.prototype,"castLineWidth",null),(0,r.Cg)([(0,c.MZ)(h.Tb)],f.prototype,"lineHeight",void 0),(0,r.Cg)([(0,p.K)("lineHeight")],f.prototype,"writeLineHeight",null),f=i=(0,r.Cg)([(0,c.$K)("esri.symbols.TextSymbol")],f)},5760(e,t,s){s.d(t,{NM:()=>a,Tb:()=>c,_R:()=>o,h9:()=>n,rM:()=>l,x0:()=>u,y7:()=>h});var i=s(34727),r=s(56507);const n=["none","underline","line-through"],o=["normal","italic","oblique"],a=["normal","lighter","bold","bolder"],c={type:Number,cast:e=>{const t=(0,r.GB)(e);return 0===t?1:(0,i.qE)(t,.1,4)},nonNullable:!0},l={type:["left","right","center"],nonNullable:!0},u={type:["baseline","top","middle","bottom"],nonNullable:!0},h=8},83773(e,t,s){s.d(t,{i:()=>f});var i=s(76213);function r(e,t){return e.x===t.x&&e.y===t.y}function n(e){if(!e)return;const t=e.length;if(t<=1)return;let s=0;for(let i=1;i<t;i++)r(e[i],e[s])||++s===i||(e[s]=e[i]);e.length=s+1}function o(e,t){return e.x=t.y,e.y=-t.x,e}function a(e,t){return e.x=-t.y,e.y=t.x,e}function c(e,t){return e.x=t.x,e.y=t.y,e}function l(e,t){return e.x=-t.x,e.y=-t.y,e}function u(e){return Math.sqrt(e.x*e.x+e.y*e.y)}function h(e,t){return e.x*t.y-e.y*t.x}function d(e,t){return e.x*t.x+e.y*t.y}function p(e,t,s,i){return e.x=t.x*s+t.y*i,e.y=t.x*i-t.y*s,e}class f{constructor(e,t,s){this._writeVertex=e,this._writeTriangle=t,this._canUseThinTessellation=s,this._prevNormal={x:void 0,y:void 0},this._nextNormal={x:void 0,y:void 0},this._textureNormalLeft={x:0,y:1},this._textureNormalRight={x:0,y:-1},this._textureNormal={x:void 0,y:void 0},this._joinNormal={x:void 0,y:void 0},this._inner={x:void 0,y:void 0},this._outer={x:void 0,y:void 0},this._roundStart={x:void 0,y:void 0},this._roundEnd={x:void 0,y:void 0},this._startBreak={x:void 0,y:void 0},this._endBreak={x:void 0,y:void 0},this._innerPrev={x:void 0,y:void 0},this._innerNext={x:void 0,y:void 0},this._bevelStart={x:void 0,y:void 0},this._bevelEnd={x:void 0,y:void 0},this._bevelMiddle={x:void 0,y:void 0}}tessellate(e,t,s=this._canUseThinTessellation){n(e),s&&t.halfWidth<i.Gh&&!t.offset?this._tessellateThin(e,t):this._tessellate(e,t)}_tessellateThin(e,t){if(e.length<2)return;const s=t.wrapDistance||65535;let i=t.initialDistance||0,r=!1,n=e[0].x,o=e[0].y;const a=e.length;for(let t=1;t<a;++t){r&&(r=!1,i=0);let a=e[t].x,c=e[t].y,l=a-n,u=c-o,h=Math.sqrt(l*l+u*u);if(l/=h,u/=h,i+h>s){r=!0;const e=(s-i)/h;h=s-i,a=(1-e)*n+e*a,c=(1-e)*o+e*c,--t}const d=this._writeVertex(n,o,0,0,l,u,u,-l,0,-1,i),p=this._writeVertex(n,o,0,0,l,u,-u,l,0,1,i);i+=h;const f=this._writeVertex(a,c,0,0,l,u,u,-l,0,-1,i),_=this._writeVertex(a,c,0,0,l,u,-u,l,0,1,i);this._writeTriangle(d,p,f),this._writeTriangle(p,f,_),n=a,o=c}}_tessellate(e,t){const s=e[0],i=e[e.length-1],n=r(s,i),f=n?3:2;if(e.length<f)return;const _=t.pixelCoordRatio,m=null!=t.capType?t.capType:0,y=null!=t.joinType?t.joinType:2,g=null!=t.miterLimit?Math.min(t.miterLimit,4):2,x=null!=t.roundLimit?Math.min(t.roundLimit,1.05):1.05,w=null!=t.halfWidth?t.halfWidth:2,b=!!t.textured;let v,S,I,T=null;const k=this._prevNormal,A=this._nextNormal;let M=-1,C=-1;const F=this._joinNormal;let E,P;const R=this._textureNormalLeft,O=this._textureNormalRight,z=this._textureNormal;let L=-1,D=-1;const N=t.wrapDistance||65535;let q=t.initialDistance||0;const B=this._writeVertex,G=this._writeTriangle,U=(e,t,s,i,r,n)=>{const o=B(S,I,E,P,s,i,e,t,r,n,q);return L>=0&&D>=0&&o>=0&&G(L,D,o),L=D,D=o,o};n&&(v=e[e.length-2],A.x=i.x-v.x,A.y=i.y-v.y,C=u(A),A.x/=C,A.y/=C);let j=!1;for(let t=0;t<e.length;++t){if(j&&(j=!1,q=0),v&&(k.x=-A.x,k.y=-A.y,M=C,q+M>N&&(j=!0)),j){const s=(N-q)/M;M=N-q,v={x:(1-s)*v.x+s*e[t].x,y:(1-s)*v.y+s*e[t].y},--t}else v=e[t];S=v.x,I=v.y;const s=t<=0&&!j,i=t===e.length-1;if(s||(q+=M),T=i?n?e[1]:null:e[t+1],T?(A.x=T.x-S,A.y=T.y-I,C=u(A),A.x/=C,A.y/=C):(A.x=void 0,A.y=void 0),!n){if(s){a(F,A),E=F.x,P=F.y,2===m&&(U(-A.y-A.x,A.x-A.y,A.x,A.y,0,-1),U(A.y-A.x,-A.x-A.y,A.x,A.y,0,1)),1===m&&(U(-A.y-A.x,A.x-A.y,A.x,A.y,-1,-1),U(A.y-A.x,-A.x-A.y,A.x,A.y,-1,1)),1!==m&&0!==m||(U(-A.y,A.x,A.x,A.y,0,-1),U(A.y,-A.x,A.x,A.y,0,1));continue}if(i){o(F,k),E=F.x,P=F.y,1!==m&&0!==m||(U(k.y,-k.x,-k.x,-k.y,0,-1),U(-k.y,k.x,-k.x,-k.y,0,1)),2===m&&(U(k.y-k.x,-k.x-k.y,-k.x,-k.y,0,-1),U(-k.y-k.x,k.x-k.y,-k.x,-k.y,0,1)),1===m&&(U(k.y-k.x,-k.x-k.y,-k.x,-k.y,1,-1),U(-k.y-k.x,k.x-k.y,-k.x,-k.y,1,1));continue}}let r,f,B=-h(k,A);if(Math.abs(B)<.01)d(k,A)>0?(F.x=k.x,F.y=k.y,B=1,r=Number.MAX_VALUE,f=!0):(a(F,A),B=1,r=1,f=!1);else{F.x=(k.x+A.x)/B,F.y=(k.y+A.y)/B,r=u(F);const e=(r-1)*w*_;f=r>4||e>M&&e>C}E=F.x,P=F.y;let G=y;switch(y){case 0:r<1.05&&(G=2);break;case 1:r<x&&(G=2);break;case 2:r>g&&(G=0)}switch(G){case 2:if(U(F.x,F.y,-k.x,-k.y,0,-1),U(-F.x,-F.y,-k.x,-k.y,0,1),i)break;if(b){const e=j?0:q;L=this._writeVertex(S,I,E,P,A.x,A.y,F.x,F.y,0,-1,e),D=this._writeVertex(S,I,E,P,A.x,A.y,-F.x,-F.y,0,1,e)}break;case 0:{const e=B<0;let t,s,r,n;if(e){const e=L;L=D,D=e,t=R,s=O}else t=O,s=R;if(f)r=e?a(this._innerPrev,k):o(this._innerPrev,k),n=e?o(this._innerNext,A):a(this._innerNext,A);else{const t=e?l(this._inner,F):c(this._inner,F);r=t,n=t}const u=e?o(this._bevelStart,k):a(this._bevelStart,k);U(r.x,r.y,-k.x,-k.y,t.x,t.y);const h=U(u.x,u.y,-k.x,-k.y,s.x,s.y);if(i)break;const d=e?a(this._bevelEnd,A):o(this._bevelEnd,A);if(f){const e=this._writeVertex(S,I,E,P,-k.x,-k.y,0,0,0,0,q);L=this._writeVertex(S,I,E,P,A.x,A.y,n.x,n.y,t.x,t.y,q),D=this._writeVertex(S,I,E,P,A.x,A.y,d.x,d.y,s.x,s.y,q),this._writeTriangle(h,e,D)}else{if(b){const e=this._bevelMiddle;e.x=(u.x+d.x)/2,e.y=(u.y+d.y)/2,p(z,e,-k.x,-k.y),U(e.x,e.y,-k.x,-k.y,z.x,z.y),p(z,e,A.x,A.y),L=this._writeVertex(S,I,E,P,A.x,A.y,e.x,e.y,z.x,z.y,q),D=this._writeVertex(S,I,E,P,A.x,A.y,n.x,n.y,t.x,t.y,q)}else{const e=L;L=D,D=e}U(d.x,d.y,A.x,A.y,s.x,s.y)}if(e){const e=L;L=D,D=e}break}case 1:{const e=B<0;let t,s;if(e){const e=L;L=D,D=e,t=R,s=O}else t=O,s=R;const n=e?l(this._inner,F):c(this._inner,F);let u,h;f?(u=e?a(this._innerPrev,k):o(this._innerPrev,k),h=e?o(this._innerNext,A):a(this._innerNext,A)):(u=n,h=n);const _=e?o(this._roundStart,k):a(this._roundStart,k),m=e?a(this._roundEnd,A):o(this._roundEnd,A),y=U(u.x,u.y,-k.x,-k.y,t.x,t.y),g=U(_.x,_.y,-k.x,-k.y,s.x,s.y);if(i)break;const x=this._writeVertex(S,I,E,P,-k.x,-k.y,0,0,0,0,q);f||this._writeTriangle(L,D,x);const w=l(this._outer,n),v=this._writeVertex(S,I,E,P,A.x,A.y,m.x,m.y,s.x,s.y,q);let T,M;const C=r>2;if(C){let t;r!==Number.MAX_VALUE?(w.x/=r,w.y/=r,t=d(k,w),t=(r*(t*t-1)+1)/t):t=-1,T=e?o(this._startBreak,k):a(this._startBreak,k),T.x+=k.x*t,T.y+=k.y*t,M=e?a(this._endBreak,A):o(this._endBreak,A),M.x+=A.x*t,M.y+=A.y*t}p(z,w,-k.x,-k.y);const N=this._writeVertex(S,I,E,P,-k.x,-k.y,w.x,w.y,z.x,z.y,q);p(z,w,A.x,A.y);const G=b?this._writeVertex(S,I,E,P,A.x,A.y,w.x,w.y,z.x,z.y,q):N,j=x,W=b?this._writeVertex(S,I,E,P,A.x,A.y,0,0,0,0,q):x;let V=-1,Y=-1;if(C&&(p(z,T,-k.x,-k.y),V=this._writeVertex(S,I,E,P,-k.x,-k.y,T.x,T.y,z.x,z.y,q),p(z,M,A.x,A.y),Y=this._writeVertex(S,I,E,P,A.x,A.y,M.x,M.y,z.x,z.y,q)),b?C?(this._writeTriangle(j,g,V),this._writeTriangle(j,V,N),this._writeTriangle(W,G,Y),this._writeTriangle(W,Y,v)):(this._writeTriangle(j,g,N),this._writeTriangle(W,G,v)):C?(this._writeTriangle(x,g,V),this._writeTriangle(x,V,Y),this._writeTriangle(x,Y,v)):(this._writeTriangle(x,g,N),this._writeTriangle(x,G,v)),f?(L=this._writeVertex(S,I,E,P,A.x,A.y,h.x,h.y,t.x,t.y,q),D=v):(L=b?this._writeVertex(S,I,E,P,A.x,A.y,h.x,h.y,t.x,t.y,q):y,this._writeTriangle(L,W,v),D=v),e){const e=L;L=D,D=e}break}}}}}},89518(e,t,s){s.d(t,{M9:()=>o,Ss:()=>a,fw:()=>l,ws:()=>c});const i=new Float32Array(1),r=new Uint32Array(i.buffer);function n(e){return i[0]=e,r[0]}function o(e,t){return 65535&e|t<<16}function a(e,t,s,i){return 255&e|(255&t)<<8|(255&s)<<16|i<<24}function c(e,t){return 255&e|(255&t)<<8}function l(e){const t=n(e),s=t>>>31;let i=t>>>23&255,r=8388607&t;return i-=127,i>15?s<<15|31744:i<-25?0:(i<-14&&(r+=8388608,r/=2**(-14-i),i=-15),i+=15,r/=8192,r=function(e){const t=Math.floor(e),s=e-t;return t<1023&&(s>.5||.5===s&&t%2==1)?t+1:t}(r),s<<15|i<<10|r)}},68572(e,t,s){s.d(t,{H:()=>o,q:()=>a}),s(44208);var i=s(23304),r=s(63907);function n(e){switch(e){case r.pe.BYTE:case r.pe.UNSIGNED_BYTE:return 1;case r.pe.SHORT:case r.pe.UNSIGNED_SHORT:case r.pe.HALF_FLOAT:return 2;case r.pe.FLOAT:case r.pe.INT:case r.pe.UNSIGNED_INT:return 4}}function o(e){const t=[],s=[],i=[];for(const r of e){const e=n(r.type)*r.count;switch(e%2||e%4||4){case 4:t.push(r);continue;case 2:s.push(r);continue;case 1:i.push(r);continue;default:throw new Error("Found unexpected dataType byte count")}}return t.push(...s),t.push(...i),t}class a{static fromVertexSpec(e,t){const{attributes:s,optionalAttributes:i}=e;let r,c,l;const u=[];for(const e in s){if(s[e].otherSource)continue;const t=s[e];"position"===t.pack?r={...t,name:e,offset:0}:"id"===t.pack?c={...t,name:e,offset:4}:"bitset"===e?l={...t,name:e,offset:7}:u.push({...t,name:e})}for(const e in i)if(!0===t[e]){const t=i[e];u.push({...t,name:e})}const h=o(u),d=[];let p=8,f=1;for(const e of h)d.push({...e,offset:p}),p+=n(e.type)*e.count,e.packAlternating&&(f=Math.max(e.packAlternating.count,f));const _=Uint32Array.BYTES_PER_ELEMENT,m=p%_;return new a(r,c,l,d,p+(m?_-m:0),f)}constructor(e,t,s,i,r,n){this.position=e,this.id=t,this.bitset=s,this.standardAttributes=i,this.stride=r,this.packVertexCount=n,i.push(s),this._attributes=[e,t,s,...i]}get attributeLayout(){if(!this._attributeLayout){const e=(0,i.hU)(this._attributes),t=this._attributes.map(e=>({name:e.name,count:e.count,offset:e.offset,type:e.type,packPrecisionFactor:e.packPrecisionFactor,normalized:e.normalized??!1}));this._attributeLayout={attributes:t,hash:e,stride:this.stride}}return this._attributeLayout}}},23304(e,t,s){s.d(t,{Ph:()=>n,Z0:()=>o,hU:()=>r});var i=s(799);function r(e){const t=e.map(({name:e,count:t,type:s})=>`${e}.${t}.${s}`).join(",");return(0,i.Wm)(t)}function n(e,t,s,i,r,o,a){if(e.primitiveName===t){let t=i?.readWithDefault(r,o,e[s]&&a);return"text"===e.type&&(t=t.toString()),void(e[s]=t)}if("type"in e&&null!=e.type){if(e.effects)for(const c of e.effects)n(c,t,s,i,r,o,a);switch(e.type){case"CIMPointSymbol":case"CIMLineSymbol":case"CIMPolygonSymbol":if(e.symbolLayers)for(const c of e.symbolLayers)n(c,t,s,i,r,o,a);break;case"CIMTextSymbol":e.symbol&&n(e.symbol,t,s,i,r,o,a);break;case"CIMHatchFill":e.lineSymbol&&n(e.lineSymbol,t,s,i,r,o,a);break;case"CIMPictureMarker":case"CIMCharacterMarker":case"CIMVectorMarker":if(e.markerPlacement&&n(e.markerPlacement,t,s,i,r,o,a),"CIMVectorMarker"===e.type&&e.markerGraphics)for(const c of e.markerGraphics)n(c,t,s,i,r,o,a),n(c.symbol,t,s,i,r,o,a)}}}function o(e){const t=Math.max(1.25*e.width,20);return null!=e.effects&&e.effects.length>0?400:t}},2661(e,t,s){s.r(t),s.d(t,{default:()=>Aa});var i=s(49186),r=s(36563),n=s(44208),o=s(26390),a=s(17676),c=s(87811),l=s(36708),u=s(90629),h=s(8341),d=s(87045),p=s(76213);class f{constructor(e){this._client=e,this.layerView=this._client.createInvokeProxy(""),this.container=this._client.createInvokeProxy("container"),this._eventLog=this._client.createInvokeProxy("eventLog")}onEvent(e){"error"===e.type&&e.error&&"toJSON"in e.error&&(e.error=e.error.toJSON()),(0,h.oV)(this._eventLog.onEvent(e))}}var _=s(97768),m=s(93637),y=s(6797),g=s(62577),x=s(21325),w=s(44159);function b(e,t){return[e,t]}function v(e,t,s){return e[0]=t,e[1]=s,e}const S=new w.A("0/0/0/0");class I{static create(e,t,s=null){const i=(0,x.Vp)(e.spatialReference),r=t.origin||b(e.origin.x,e.origin.y),n=b(e.size[0]*t.resolution,e.size[1]*t.resolution),o=b(-1/0,-1/0),a=b(1/0,1/0),c=b(1/0,1/0);null!=s&&(v(o,Math.max(0,Math.floor((s.xmin-r[0])/n[0])),Math.max(0,Math.floor((r[1]-s.ymax)/n[1]))),v(a,Math.max(0,Math.floor((s.xmax-r[0])/n[0])),Math.max(0,Math.floor((r[1]-s.ymin)/n[1]))),v(c,a[0]-o[0]+1,a[1]-o[1]+1));const{cols:l,rows:u}=t;let h,d,p,f;return!s&&l&&u&&(v(o,l[0],u[0]),v(a,l[1],u[1]),v(c,l[1]-l[0]+1,u[1]-u[0]+1)),e.isWrappable?(h=b(Math.ceil(Math.round((i.valid[1]-i.valid[0])/t.resolution)/e.size[0]),c[1]),d=!0,p=i.origin,f=i.valid):(h=c,d=!1),new I(t.level,t.resolution,t.scale,r,o,a,c,n,h,d,p,f)}constructor(e,t,s,i,r,n,o,a,c,l,u,h){this.level=e,this.resolution=t,this.scale=s,this.origin=i,this.first=r,this.last=n,this.size=o,this.norm=a,this.worldSize=c,this.wrap=l,this._spatialReferenceOrigin=u,this._spatialReferenceValid=h}normalizeCol(e){if(!this.wrap)return e;const t=this.worldSize[0];return e<0?t-1-Math.abs((e+1)%t):e%t}normalizeKey(e){if(!this.wrap)return;const t=this.worldSize[0],s=e.col;s<0?(e.col=s+t,e.world-=1):s>=t&&(e.col=s-t,e.world+=1)}denormalizeCol(e,t){return this.wrap?this.worldSize[0]*t+e:e}getWorldForColumn(e){return this.wrap?Math.floor(e/this.worldSize[0]):0}getFirstColumnForWorld(e){return e*this.worldSize[0]+this.first[0]}getLastColumnForWorld(e){return e*this.worldSize[0]+this.first[0]+this.size[0]-1}getColumnForX(e){return(e-this.origin[0])/this.norm[0]}getXForColumn(e){const t=this.origin[0]+e*this.norm[0],s=this._spatialReferenceOrigin,i=this._spatialReferenceValid;return this.wrap&&s&&i?t===s[0]?i[0]:this.origin[0]===s[0]&&e===this.worldSize[0]?i[1]:t:t}getRowForY(e){return(this.origin[1]-e)/this.norm[1]}getYForRow(e){return this.origin[1]-e*this.norm[1]}getTileBounds(e,t,s=!1){S.set(t);const i=s?S.col:this.denormalizeCol(S.col,S.world),r=S.row;return function(e,t,s,i,r){e[0]=t,e[1]=s,e[2]=i,e[3]=r}(e,this.getXForColumn(i),this.getYForRow(r+1),this.getXForColumn(i+1),this.getYForRow(r)),e}getTileCoords(e,t,s=!1){S.set(t);const i=s?S.col:this.denormalizeCol(S.col,S.world);return Array.isArray(e)?v(e,this.getXForColumn(i),this.getYForRow(S.row)):(e.x=this.getXForColumn(i),e.y=this.getYForRow(S.row)),e}}var T=s(93687);class k{constructor(){this.spans=[]}static{this.pool=new T.A(()=>new k)}acquire(e){this.lodInfo=e}release(){this.lodInfo=null,this.spans.length=0}*keys(){const e=this.lodInfo;for(const{row:t,colFrom:s,colTo:i}of this.spans)for(let r=s;r<=i;r++){const s=e.getWorldForColumn(r);yield new w.A(e.level,t,e.normalizeCol(r),s)}}forEach(e,t){const{spans:s,lodInfo:i}=this,{level:r}=i;if(0!==s.length)for(const{row:n,colFrom:o,colTo:a}of s)for(let s=o;s<=a;s++)e.call(t,r,n,i.normalizeCol(s),i.getWorldForColumn(s))}}class A{constructor(e,t,s){this.row=e,this.colFrom=t,this.colTo=s}}const M=new w.A("0/0/0/0");class C{static create(e,t){e[1]>t[1]&&([e,t]=[t,e]);const[s,i]=e,[r,n]=t,o=r-s,a=n-i,c=0!==a?o/a:0,l=(Math.ceil(i)-i)*c,u=(Math.floor(i)-i)*c;return new C(s,Math.floor(i),Math.ceil(n),c,o<0?l:u,o<0?u:l,o<0?r:s,o<0?s:r)}constructor(e,t,s,i,r,n,o,a){this.x=e,this.ymin=t,this.ymax=s,this.invM=i,this.leftAdjust=r,this.rightAdjust=n,this.leftBound=o,this.rightBound=a}incrRow(){this.x+=this.invM}getLeftCol(){return Math.max(this.x+this.leftAdjust,this.leftBound)}getRightCol(){return Math.min(this.x+this.rightAdjust,this.rightBound)}}const F=[[0,0],[0,0],[0,0],[0,0]];class E{constructor(e,t=null,s=e.lods[0].level,i=e.lods[e.lods.length-1].level){this.tileInfo=e,this.fullExtent=t,this.scales=[],this._infoByScale={},this._infoByLevel={};const r=e.lods.filter(e=>e.level>=s&&e.level<=i);this.minScale=r[0].scale,this.maxScale=r[r.length-1].scale;const n=this._lodInfos=r.map(s=>I.create(e,s,t));r.forEach((e,t)=>{this._infoByLevel[e.level]=n[t],this._infoByScale[e.scale]=n[t],this.scales[t]=e.scale},this),this._wrap=e.isWrappable}get spatialReference(){return this.tileInfo.spatialReference}get origin(){return this.tileInfo.origin}get size(){return this.tileInfo.size}getLODInfoAt(e){return this._infoByLevel["number"==typeof e?e:e.level]}getTileBounds(e,t,s=!1){M.set(t);const i=this._infoByLevel[M.level];return i?i.getTileBounds(e,M,s):e}getTileCoords(e,t,s=!1){M.set(t);const i=this._infoByLevel[M.level];return i?i.getTileCoords(e,M,s):e}getTileCoverage(e,t=192,s=!0,i="closest"){if(!s&&(e.scale>this.minScale||e.scale<this.maxScale))return null;const r="closest"===i?this.getClosestInfoForScale(e.scale):this.getSmallestInfoForScale(e.scale),n=k.pool.acquire(r),o=this._wrap;let a,c,l,u=1/0,h=-1/0;const d=n.spans;F[0][0]=F[0][1]=F[1][1]=F[3][0]=-t,F[1][0]=F[2][0]=e.size[0]+t,F[2][1]=F[3][1]=e.size[1]+t;for(const t of F)e.toMap(t,t),t[0]=r.getColumnForX(t[0]),t[1]=r.getRowForY(t[1]);const p=[];let f=3;for(let e=0;e<4;e++){if(F[e][1]===F[f][1]){f=e;continue}const t=C.create(F[e],F[f]);u=Math.min(t.ymin,u),h=Math.max(t.ymax,h),void 0===p[t.ymin]&&(p[t.ymin]=[]),p[t.ymin].push(t),f=e}if(null==u||null==h||h-u>100)return null;let _=[];for(a=u;a<h;){null!=p[a]&&(_=_.concat(p[a])),c=1/0,l=-1/0;for(let e=_.length-1;e>=0;e--){const t=_[e];c=Math.min(c,t.getLeftCol()),l=Math.max(l,t.getRightCol())}if(c=Math.floor(c),l=Math.floor(l),a>=r.first[1]&&a<=r.last[1])if(o)if(r.size[0]<r.worldSize[0]){const e=Math.floor(l/r.worldSize[0]);for(let t=Math.floor(c/r.worldSize[0]);t<=e;t++)d.push(new A(a,Math.max(r.getFirstColumnForWorld(t),c),Math.min(r.getLastColumnForWorld(t),l)))}else d.push(new A(a,c,l));else c>r.last[0]||l<r.first[0]||(c=Math.max(c,r.first[0]),l=Math.min(l,r.last[0]),d.push(new A(a,c,l)));a+=1;for(let e=_.length-1;e>=0;e--){const t=_[e];t.ymax>=a?t.incrRow():_.splice(e,1)}}return n}getTileParentId(e){M.set(e);const t=this._infoByLevel[M.level],s=this._lodInfos.indexOf(t)-1;return s<0?null:(this._getTileIdAtLOD(M,this._lodInfos[s],M),M.id)}getTileResolution(e){const t=this._infoByLevel["object"==typeof e?e.level:e];return t?t.resolution:-1}getTileScale(e){const t=this._infoByLevel[e.level];return t?t.scale:-1}intersects(e,t){M.set(t);const s=this._infoByLevel[M.level],i=e.lodInfo;if(i.resolution>s.resolution){this._getTileIdAtLOD(M,i,M);const t=i.denormalizeCol(M.col,M.world);for(const s of e.spans)if(s.row===M.row&&s.colFrom<=t&&s.colTo>=t)return!0}if(i.resolution<s.resolution){const[t,r,n,o]=e.spans.reduce((e,t)=>(e[0]=Math.min(e[0],t.row),e[1]=Math.max(e[1],t.row),e[2]=Math.min(e[2],t.colFrom),e[3]=Math.max(e[3],t.colTo),e),[1/0,-1/0,1/0,-1/0]),a=s.denormalizeCol(M.col,M.world),c=i.getColumnForX(s.getXForColumn(a)),l=i.getRowForY(s.getYForRow(M.row)),u=i.getColumnForX(s.getXForColumn(a+1))-1,h=i.getRowForY(s.getYForRow(M.row+1))-1;return!(c>o||u<n||l>r||h<t)}const r=i.denormalizeCol(M.col,M.world);return e.spans.some(e=>e.row===M.row&&e.colFrom<=r&&e.colTo>=r)}normalizeBounds(e,t,s){if(e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],this._wrap){const t=(0,x.Vp)(this.tileInfo.spatialReference),i=-s*(t.valid[1]-t.valid[0]);e[0]+=i,e[2]+=i}return e}getSmallestInfoForScale(e){const t=this.scales;if(this._infoByScale[e])return this._infoByScale[e];if(e>t[0])return this._infoByScale[t[0]];for(let s=1;s<t.length-1;s++)if(e>t[s]+1e-6)return this._infoByScale[t[s-1]];return this._infoByScale[t[t.length-1]]}getClosestInfoForScale(e){const t=this.scales;return this._infoByScale[e]||(e=t.reduce((t,s)=>Math.abs(s-e)<Math.abs(t-e)?s:t,t[0])),this._infoByScale[e]}scaleToLevel(e){const t=this.scales;if(this._infoByScale[e])return this._infoByScale[e].level;for(let s=t.length-1;s>=0;s--)if(e<t[s])return s===t.length-1?this._infoByScale[t[t.length-1]].level:this._infoByScale[t[s]].level+(t[s]-e)/(t[s]-t[s+1]);return this._infoByScale[t[0]].level}scaleToZoom(e){return this.tileInfo.scaleToZoom(e)}zoomToScale(e){return this.tileInfo.zoomToScale(e)}_getTileIdAtLOD(e,t,s){const i=this._infoByLevel[s.level];return e.set(s),t.resolution<i.resolution?null:(t.resolution===i.resolution||(e.level=t.level,e.col=Math.floor(s.col*i.resolution/t.resolution+.01),e.row=Math.floor(s.row*i.resolution/t.resolution+.01)),e)}}var P=s(5482),R=s(69622),O=s(91869),z=s(3483),L=s(91429),D=s(37585),N=s(9775),q=s(32587),B=s(76030),G=s(44794);class U{constructor(e,t){this.item=e,this.controller=t,this.promise=null}}class j{constructor(e){this._schedule=null,this._task=null,this._deferreds=new q.A,this._controllers=new q.A,this._processingItems=new q.A,this._pausedSignal=(0,G.v)(!1),this.concurrency=1,e.concurrency&&(this.concurrency=e.concurrency),this._queue=new N.A(e.peeker),this.process=e.process;const t=e.scheduler;e.priority&&t&&(this._task=t.registerTask(e.priority,this))}destroy(){this.clear(),this._schedule=(0,_.xt)(this._schedule),this._task=(0,_.xt)(this._task)}get updating(){return!!this._task?.updating||this.readyToRun}get length(){return this._processingItems.size+this._queue.length}abort(e){const t=this._controllers.get(e);t&&t.abort()}clear(){this._queue.clear();const e=[];this._controllers.forEach(t=>e.push(t)),this._controllers.clear(),e.forEach(e=>e.abort()),this._processingItems.clear(),this._cancelNext()}forEach(e){this._deferreds.forEach((t,s)=>e(s))}get(e){const t=this._deferreds.get(e);return t?t.promise:void 0}isOngoing(e){return this._processingItems.has(e)}has(e){return this._deferreds.has(e)}pause(){this._pausedSignal.value||(this._pausedSignal.value=!0,this._cancelNext())}push(e,t){const s=this.get(e);if(s)return s;const i=new AbortController;let r=null;t&&(r=(0,a.u7)(t,()=>i.abort()));const n=()=>{o.remove(),null!=r&&r.remove(),this._removeItem(e),this._queue.remove(e),this._scheduleNext()},o=(0,a.NY)(i.signal,()=>{const t=this._processingItems.get(e);t&&t.controller.abort(),n(),c.reject((0,a.NK)())}),c=Promise.withResolvers();return this._deferreds.set(e,c),this._controllers.set(e,i),c.promise.then(n,n),this._queue.push(e),this._scheduleNext(),c.promise}last(){return this._queue.last()}lastPromise(){const e=this.last();return e?this.get(e):null}peek(){return this._queue.peek()}popLast(){const e=this._queue.popLast();return e&&(this._deferreds.get(e)?.reject((0,a.NK)()),this._removeItem(e)),e}reset(){const e=Array.from(this._processingItems.values());this._processingItems.clear();for(const t of e)this._queue.push(t.item),t.controller.abort();this._scheduleNext()}resume(){this._pausedSignal.value&&(this._pausedSignal.value=!1,this._scheduleNext())}takeAll(){const e=[];for(;this._queue.length;)e.push(this._queue.pop());return this.clear(),e}get readyToRun(){return!this._pausedSignal.value&&this._queue.length>0&&this._processingItems.size<this.concurrency}runTask(e){for(;!e.done&&this._queue.length>0&&this._processingItems.size<this.concurrency;)this._process(this._queue.pop()),e.madeProgress()}_removeItem(e){this._deferreds.delete(e),this._controllers.delete(e),this._processingItems.delete(e)}_scheduleNext(){this._task||this._pausedSignal.value||this._schedule||(this._schedule=(0,B._)(()=>{this._schedule=null,this._next()}))}_next(){for(;this._queue.length>0&&this._processingItems.size<this.concurrency;)this._process(this._queue.pop())}_cancelNext(){this._schedule&&(this._schedule.remove(),this._schedule=null)}_processResult(e,t){this._canProcessFulfillment(e)&&(this._scheduleNext(),this._deferreds.get(e.item).resolve(t))}_processError(e,t){this._canProcessFulfillment(e)&&(this._scheduleNext(),this._deferreds.get(e.item).reject(t))}_canProcessFulfillment(e){return!!this._deferreds.get(e.item)&&this._processingItems.get(e.item)===e}_process(e){if(null==e)return;let t;const s=new AbortController,i=new U(e,s);this._processingItems.set(e,i);try{t=this.process(e,s.signal)}catch(e){this._processError(i,e)}(0,a.$X)(t)?(i.promise=t,t.then(e=>this._processResult(i,e),e=>this._processError(i,e))):this._processResult(i,t)}get test(){}}const W=[0,0];let V=class extends R.A{constructor(e){super(e),this._keyToItem=new Map,this._tilesByScale=new Map,this.concurrency=6}initialize(){const{concurrency:e,process:t,scheduler:s,priority:i}=this;this._queue=new j({concurrency:e,scheduler:s,priority:i,process:(e,s)=>{const i=this._keyToItem.get(e);return t(i,{signal:s})},peeker:e=>this._peek(e)})}destroy(){this.clear(),this._queue=(0,_.pR)(this._queue)}get length(){return this._queue?this._queue.length:0}abort(e){const t="string"==typeof e?e:e.id;this._queue.abort(t)}clear(){this._queue.clear(),this._keyToItem.clear(),this._tilesByScale.clear()}has(e){return"string"==typeof e?this._keyToItem.has(e):this._keyToItem.has(e.id)}pause(){this._queue.pause()}push(e){const t=e.key.id;if(this._queue.has(t))return this._queue.get(t);const s=this._queue.push(t),i=this.tileInfoView.getTileScale(e.key),r=(0,O.tE)(this._tilesByScale,i,()=>new Set),n=()=>{r.delete(e.key),0===r.size&&this._tilesByScale.delete(i),this._keyToItem.delete(t)};return r.add(e.key),this._keyToItem.set(t,e),s.then(n,n),s}reset(){this._queue.reset()}resume(){this._queue.resume()}_peek(e){if(!this.state)return e.values().next().value;const t=new Set;for(const s of e)t.add(this._keyToItem.get(s).key);const s=this.state.scale;let i,r=Number.POSITIVE_INFINITY;for(const[e,n]of this._tilesByScale)if((0,z.bw)(n,e=>t.has(e))){const t=Math.abs(e-s);t<r&&(i=n,r=t)}return this._getClosestTileKey(i,e).id}_getClosestTileKey(e,t){const s=this.tileInfoView,i=this.state.center;let r,n=Number.POSITIVE_INFINITY;for(const o of e)if(t.has(o.id)){s.getTileCoords(W,o);const e=(0,D.Io)(W,i);e<n&&(n=e,r=o)}return r}};(0,P.Cg)([(0,L.MZ)({constructOnly:!0})],V.prototype,"concurrency",void 0),(0,P.Cg)([(0,L.MZ)({constructOnly:!0})],V.prototype,"priority",void 0),(0,P.Cg)([(0,L.MZ)({constructOnly:!0})],V.prototype,"process",void 0),(0,P.Cg)([(0,L.MZ)({constructOnly:!0})],V.prototype,"scheduler",void 0),(0,P.Cg)([(0,L.MZ)()],V.prototype,"state",void 0),(0,P.Cg)([(0,L.MZ)({constructOnly:!0})],V.prototype,"tileInfoView",void 0),V=(0,P.Cg)([(0,L.$K)("esri.views.2d.tiling.TileQueue")],V);var Y=s(19419);new w.A(0,0,0,0),new Map;class ${static{this.byteSizeHint=7*Uint32Array.BYTES_PER_ELEMENT}static{this.estimatedMemory=40}constructor(e,t,s,i,r,n,o){this.instanceId=e,this.textureKey=t,this.indexStart=s,this.indexCount=i,this.vertexStart=r,this.vertexCount=n,this.overlaps=o}updateBaseOffsets(e){this.vertexStart+=e.vertexFrom,this.indexStart+=e.indexFrom}clone(){return new $(this.instanceId,this.textureKey,this.indexStart,this.indexCount,this.vertexStart,this.vertexCount,this.overlaps)}static write(e,t,s,i,r,n,o,a){e.push(t),e.push(s),e.push(i),e.push(r),e.push(n),e.push(o),e.push(a)}serialize(e){return e.push(this.instanceId),e.push(this.textureKey),e.push(this.indexStart),e.push(this.indexCount),e.push(this.vertexStart),e.push(this.vertexCount),e.push(this.overlaps),e}static deserialize(e){const t=e.readInt32(),s=e.readInt32(),i=e.readInt32(),r=e.readInt32(),n=e.readInt32(),o=e.readInt32(),a=e.readInt32();return new $(t,s,i,r,n,o,a)}}function H(e,t){if(null!==t){e.push(t.length);for(const s of t)s.serialize(e);return e}e.push(0)}function Z(e,t,s){const i=e.readInt32(),r=new Array(i);for(let i=0;i<r.length;i++)r[i]=t.deserialize(e,s);return r}class Q{static{this.byteSizeHint=2*Uint32Array.BYTES_PER_ELEMENT+$.byteSizeHint}static estimateMemory(e){return 24+$.estimatedMemory*e}constructor(e,t){this.id=e,this.sortKey=t,this.records=[]}serialize(e){return e.push(this.id),e.writeF32(this.sortKey),H(e,this.records),e}static deserialize(e){const t=e.readInt32(),s=e.readF32(),i=new Q(t,s);return i.records=Z(e,$)??[],i}}class X{get length(){return this._pos}constructor(e,t){this._pos=0;const s=t?this._roundToNearest(t,e.BYTES_PER_ELEMENT):40;this._array=new ArrayBuffer(s),this._buffer=new e(this._array),this._ctor=e,this._i16View=new Int16Array(this._array)}_roundToNearest(e,t){const s=Math.round(e);return 1===t?s:s+(t-s%t)}_ensureSize(e){if(this._pos+e>=this._buffer.length){const t=this._roundToNearest(1.25*(this._array.byteLength+e*this._buffer.BYTES_PER_ELEMENT),this._buffer.BYTES_PER_ELEMENT),s=new ArrayBuffer(t),i=new this._ctor(s);i.set(this._buffer,0),this._array=s,this._buffer=i,this._i16View=new Int16Array(this._array)}}ensureSize(e){this._ensureSize(e)}writeF32(e){this._ensureSize(1);const t=this._pos;return new Float32Array(this._array,4*this._pos,1)[0]=e,this._pos++,t}push(e){this._ensureSize(1);const t=this._pos;return this._buffer[this._pos++]=e,t}writeFixed(e){this._buffer[this._pos++]=e}setValue(e,t){this._buffer[e]=t}i1616Add(e,t,s){this._i16View[2*e]+=t,this._i16View[2*e+1]+=s}getValue(e){return this._buffer[e]}getValueF32(e){return new Float32Array(this._array,4*e,1)[0]}incr(e){if(this._buffer.length<e)throw new Error("Increment index overflows the target buffer");this._buffer[e]++}decr(e){this._buffer[e]--}writeRegion(e){this._ensureSize(e.length);const t=this._pos;return this._buffer.set(e,this._pos),this._pos+=e.length,t}writeManyFrom(e,t,s){this._ensureSize(s-t);for(let i=t;i!==s;i++)this.writeFixed(e._buffer[i])}buffer(){const e=this._array.slice(0,4*this._pos);return this.destroy(),e}toArray(){return[...this._buffer]}seek(e){this._pos=e}destroy(){this._array=null,this._buffer=null}}class K{constructor(e,t,s=0){const i=6*s*Uint32Array.BYTES_PER_ELEMENT,r=4*s*t.stride,n=t.stride/4,o=t.attributes.find(e=>"pos"===e.name||"position"===e.name);if(!o)throw new Error("InternalError: Unable to find position attribute");this.layout={...t,position:o},this._indices=new X(Uint32Array,i),this._vertices=new X(Uint32Array,r),this._metrics=new X(Uint32Array,0),this._metricCountOffset=this._metrics.push(0),this._strideInt=n,this._instanceId=e}serialize(e){const t=this._indices.buffer(),s=this._vertices.buffer(),i=this._metrics.length?this._metrics.buffer():null;return e.push(t,s),{instanceId:this._instanceId,layout:this.layout,indices:t,vertices:s,metrics:i}}get strideInt(){return this._strideInt}get vertexCount(){return this._vertices.length/this._strideInt}get indexCount(){return this._indices.length}get indexWriter(){return this._indices}get vertexWriter(){return this._vertices}get metricWriter(){return this._metrics}vertexEnsureSize(e){this._vertices.ensureSize(e)}indexEnsureSize(e){this._indices.ensureSize(e)}writeIndex(e){this._indices.push(e)}writeVertex(e){this._vertices.push(e)}writeVertexRegion(e){this._vertices.writeRegion(e)}writeVertexF32(e){this._vertices.writeF32(e)}writeMetric(e){this._metrics.incr(this._metricCountOffset),e.serialize(this._metrics)}}class J{constructor(e,t=0){this._id=e,this._sizeHint=t,this._entityRecordCountOffset=0,this._entityCountOffset=0,this._entityIdIndex=0,this._entitySortKeyIndex=0,this._didEntityStart=!1,this._instanceIdToVertexData=new Map,this._recordIndexStart=0,this._recordIndexCount=0,this._recordVertexStart=0,this._recordVertexCount=0,this._current={metric:null,writer:null,start:0,sortKey:0,instanceId:0,layoutHash:0,indexStart:0,vertexStart:0,textureKey:0,metricBoxLenPointer:0},this._requiresRefresh=!1,this._entities=new X(Uint32Array,this._sizeHint*Q.byteSizeHint),this._entityCountOffset=this._entities.push(0)}get id(){return this._id}serialize(){const e=new Array,t=[],s=this._entities.buffer();for(const s of this._instanceIdToVertexData.values())t.push(s.serialize(e));return{message:{data:t,entities:s},transferList:e}}get requiresRefresh(){return this._requiresRefresh}set requiresRefresh(e){this._requiresRefresh=e}vertexStart(){return this._current.vertexStart??0}vertexCount(){return this._current.writer?.vertexCount??0}indexCount(){return this._current.writer?.indexCount??0}vertexEnsureSize(e){this._current.writer.vertexEnsureSize(e)}indexEnsureSize(e){this._current.writer.indexEnsureSize(e)}vertexWrite(e){this._current.writer.writeVertex(e)}vertexWriteRegion(e){this._current.writer.writeVertexRegion(e)}vertexWriteF32(e){this._current.writer.writeVertexF32(e)}recordBounds(e,t,s,i){}indexWrite(e){this._current.writer.writeIndex(e)}metricStart(e){this._current.metric=e,this._current.metric.recordStart=this.recordCount()}metricEnd(){const e=this._current.writer;this._current.metric&&(this._current.metric.recordCount=this.recordCount()-this._current.metric.recordStart),this._current.metric?.bounds.length&&this._current.metric?.recordCount?(e.writeMetric(this._current.metric),this._current.metric=null):this._current.metric=null}metricBoxWrite(e){this._current.metric.bounds.push(e)}entityStart(e,t=e){this._entityIdIndex=this._entities.push(e),this._entitySortKeyIndex=this._entities.writeF32(t),this._entityRecordCountOffset=this._entities.push(0),this._didEntityStart=!0}entityRecordCount(){return this._entities.getValue(this._entityRecordCountOffset)}entityEnd(){this._didEntityStart&&(0===this.entityRecordCount()?this._entities.seek(this._entityIdIndex):this._entities.incr(this._entityCountOffset),this._didEntityStart=!1)}recordCount(){return this._entities.getValue(this._entityRecordCountOffset)}recordStart(e,t,s=0){this._current.writer=this._getVertexWriter(e,t),this._current.indexStart=this._current.writer.indexCount,this._current.vertexStart=this._current.writer.vertexCount,this._current.instanceId=e,this._current.layoutHash=t.hash,this._current.textureKey=s}recordEnd(e=0){const t=this._current.vertexStart,s=this._current.writer.vertexCount-t;if(!s)return!1;const i=this._current.indexStart,r=this._current.writer.indexCount-i;return this._recordIndexStart=i,this._recordIndexCount=r,this._recordVertexStart=t,this._recordVertexCount=s,this._entities.incr(this._entityRecordCountOffset),$.write(this._entities,this._current.instanceId,this._current.textureKey,i,r,t,s,e),!0}copyLast(e,t){const s=this._recordVertexStart+this._recordVertexCount;this._entities.incr(this._entityRecordCountOffset),$.write(this._entities,this._current.instanceId,this._current.textureKey,this._recordIndexStart+this._recordIndexCount,this._recordIndexCount,s,this._recordVertexCount,0);const i=this._current.writer.indexWriter,r=this._current.writer.vertexWriter,n=this._recordIndexStart+this._recordIndexCount,o=this._recordVertexCount;for(let e=this._recordIndexStart;e!==n;e++){const t=i.getValue(e);i.push(t+o)}const a=this._current.writer.layout.stride/Uint32Array.BYTES_PER_ELEMENT,c=this._recordVertexStart*a,l=(this._recordVertexStart+this._recordVertexCount)*a;for(let e=c;e!==l;e++){const t=r.getValue(e);r.push(t)}const u=this._current.writer.layout.position,h=u.packPrecisionFactor??1,d=u.offset/Uint32Array.BYTES_PER_ELEMENT,p=e*h,f=t*h;for(let e=s*a;e<=r.length;e+=a)r.i1616Add(e+d,p,f)}copyLastFrom(e,t,s){const i=e._entities.getValue(e._entityIdIndex);if(i!==this._entities.getValue(this._entityIdIndex)){const t=e._entities.getValueF32(e._entitySortKeyIndex);this.entityStart(i,t)}this.recordStart(e._current.instanceId,e._current.writer.layout,e._current.textureKey);const r=this._current.writer.layout.stride/Uint32Array.BYTES_PER_ELEMENT,n=this._current.vertexStart,o=e._current.vertexStart-n,a=this._current.writer.indexWriter,c=this._current.writer.vertexWriter,l=e._current.writer.indexWriter,u=e._current.writer.vertexWriter;for(let t=e._current.indexStart;t!==l.length;t++){const e=l.getValue(t);a.push(e-o)}for(let t=e._current.vertexStart*r;t!==u.length;t++){const e=u.getValue(t);c.push(e)}const h=this._current.writer.layout.position,d=h.packPrecisionFactor??1,p=h.offset/Uint32Array.BYTES_PER_ELEMENT,f=t*d,_=s*d;for(let e=n*r;e<=c.length;e+=r)c.i1616Add(e+p,f,_);this.recordEnd()}_getVertexWriter(e,t){const s=this._instanceIdToVertexData;return s.has(e)||s.set(e,new K(e,t,this._sizeHint)),s.get(e)}}function ee(e){switch(e){case 1:case 8:case 32:return-1;case 2:case 64:return 0;case 4:case 16:case 128:return 1}}function te(e){switch(e){case 1:case 2:case 4:return-1;case 8:case 16:return 0;case 32:case 64:case 128:return 1}}class se{constructor(e,t,s,i,r=0){this.tileKey=e,this._bufferingEnabled=t,this._sizeHint=r,this._meshes={self:new J(this.id,this._sizeHint),neighbors:new Array},this._currentRecordOverlaps=0,this._currentEntityOverlaps=0;const n=i?1:0;this._copyBufferedDataIntoSelf=s&&this._bufferingEnabled&&e.level===n}get id(){return this.tileKey.id}get requiresRefresh(){return this._meshes.self.requiresRefresh||this._meshes.neighbors.some(e=>e.requiresRefresh)}set requiresRefresh(e){this._meshes.self.requiresRefresh=e}vertexStart(){return this._meshes.self.vertexStart()??0}vertexCount(){return this._meshes.self.vertexCount()}indexCount(){return this._meshes.self.indexCount()}indexEnsureSize(e){this._meshes.self.indexEnsureSize(e)}entityStart(e,t=e){this._currentEntityOverlaps=0,this._meshes.self.entityStart(e,t)}entityRecordCount(){return this._meshes.self.entityRecordCount()}entityEnd(){if(this._meshes.self.entityEnd(),this._bufferingEnabled){if(this._copyBufferedDataIntoSelf)return;for(let e=0;e<8;e++){const t=1<<e;this._currentEntityOverlaps&t&&this._meshes.neighbors[e].entityEnd()}}}recordStart(e,t,s){this._currentRecordOverlaps=0,this._meshes.self.recordStart(e,t,s)}recordEnd(e=0){const t=this._meshes.self.recordEnd(this._currentRecordOverlaps);return t&&0!==this._currentRecordOverlaps?(this._copyIntoNeighbors(),this._currentEntityOverlaps|=this._currentRecordOverlaps,!0):t}recordBounds(e,t,s,i){this._bufferingEnabled&&this._addOverlap(e,t,s,i)}recordCount(){return this._meshes.self.recordCount()}metricStart(e){this._meshes.self.metricStart(e)}metricBoxWrite(e){this._meshes.self.metricBoxWrite(e)}metricEnd(){this._meshes.self.metricEnd()}vertexWrite(e){this._meshes.self.vertexWrite(e)}vertexWriteF32(e){this._meshes.self.vertexWriteF32(e)}vertexWriteRegion(e){this._meshes.self.vertexWriteRegion(e)}indexWrite(e){this._meshes.self.indexWrite(e)}serialize(e){const t={message:[],transferList:[]},s=this._meshes.self.serialize();return t.message.push({tileId:this.tileKey.id,requiresRefresh:this.requiresRefresh,...s.message}),t.transferList.push(...s.transferList),this._meshes.neighbors.forEach((s,i)=>{const r=s.serialize(),n=1<<i,o=ee(n),a=te(n),c=new w.A(this.tileKey).getNormalizedNeighbor(o,a,e);t.message.push({tileId:c.id,requiresRefresh:this.requiresRefresh,...r.message}),t.transferList.push(...r.transferList)}),t}_addOverlap(e,t,s,i){const r=Math.min(p.CQ/2,s),n=Math.min(p.CQ/2,i),o=255^((e<0+r?148:e>=p.CQ-r?41:189)|(t<0+n?224:t>=p.CQ-n?7:231));this._currentRecordOverlaps|=o}_copyIntoNeighbors(){for(let e=0;e<8;e++){const t=1<<e;if(this._currentRecordOverlaps&t){if(this._copyBufferedDataIntoSelf){const e=-ee(t)*p.CQ,s=-te(t)*p.CQ;if(0!==s)continue;this._meshes.self.copyLast(e,s);continue}if(!this._meshes.neighbors[e]){const s=Math.floor(this._sizeHint/16);this._meshes.neighbors[e]=new J(t,s)}const s=this._meshes.neighbors[e],i=-ee(t)*p.CQ,r=-te(t)*p.CQ;s.copyLastFrom(this._meshes.self,i,r)}}}}class ie{}var re=s(72691),ne=s(73681);class oe{constructor(){this._defaultResult=null,this._backgroundFillResult=null}static async from(e,t){const s=new oe;return s.setDefault(await e.createMeshWriters(t.meshes)),s}size(){return 1}getDefault(){return this._defaultResult}setDefault(e){this._defaultResult=e}getBackgroundFill(){return this._backgroundFillResult}setBackgroundFill(e){this._backgroundFillResult=e}hasArcadeDependency(e){return this._defaultResult?.some(t=>t.hasArcadeDependency(e))??!1}match(e,t,s){const i=this.doMatch(e,t)||this.getDefault();if(i&&i.length>0){const e=this.getBackgroundFill();if(e)return[...e,...i]}return i}getSortKey(e,t){return 0}doMatch(e,t){return null}async fetchResources(e,t){}}class ae extends oe{static async fromDictionaryRenderer(e,t){const s=await ne.n.from(t.dictionaryInfo,t.userConfig,t.fieldMap);return new ae(e,s)}constructor(e,t){super(),this._context=e,this._evaluator=t,this._controlStringToPromise=new Map,this._controlStringToGroup=new Map}async fetchResources(e,t){const s=t.getCursor(),i=new Set;for(;s.next();){const e=this._evaluateControlString(s);e&&i.add(e)}const r=Array.from(i.values()).map(t=>this._ensureGroup(e,t));await Promise.all(r)}match(e,t){const s=this._evaluateControlString(e);return s?this._controlStringToGroup.get(s):null}_evaluateControlString(e){const t=e.readLegacyFeatureWorldSpace();return this._evaluator.evaluate(t,0,e.fields,null)}_ensureGroup(e,t){let s=this._controlStringToPromise.get(t);return null==s&&(s=this._fetchGroup(e,t),this._controlStringToPromise.set(t,s)),s}async _fetchGroup(e,t){const s=await e.fetchDictionaryResourceImmediate({type:"dictionary-request",controlString:t});if(!s)return;const i=await this._context.createMeshWriters(s.meshes);this._controlStringToGroup.set(t,i)}}class ce extends oe{constructor(e,t){super(),this._intervals=[],this._isMaxInclusive=t,this._field=e}static async fromIntervalSchema(e,t){const s=await e.storage.createComputedField(t),i=new ce(s,t.isMaxInclusive);await Promise.all(t.intervals.map(async t=>{const s=[...await e.createMeshWriters(t.meshes),...await e.createMeshWriters(t.alternateMeshes)];i.add(t,s)}));const r=await e.createMeshWriters(t.defaultSymbol);i.setDefault(r);const n=await e.createMeshWriters(t.backgroundFill);return i.setBackgroundFill(n),i}add(e,t){this._intervals.push({interval:e,result:t}),this._intervals.sort((e,t)=>e.interval.min-t.interval.min)}size(){return super.size()+this._intervals.length}hasArcadeDependency(e){return this._field?.hasArcadeDependency(e)||this._intervals.some(t=>t.result.some(t=>t.hasArcadeDependency(e)))}doMatch(e,t){const s=this._field?.read(e,t);if(null==s||isNaN(s)||s===1/0||s===-1/0)return null;for(let e=0;e<this._intervals.length;e++){const{interval:t,result:i}=this._intervals[e],r=s>=t.min,n=this._isMaxInclusive?s<=t.max:s<t.max;if(r&&n)return i}return null}}class le extends oe{static async fromLabelSchema(e,t){const s=t.classes.map(async t=>{const s=await e.createMeshWriters(t.meshes);return{minScale:t.minScale,maxScale:t.maxScale,meshes:s,expression:null,where:await e.storage.createWhereClause(t.where)}}),i=await Promise.all(s);return new le(i)}constructor(e){super(),this._labels=e}match(e,t,s){if(!this._labels.length)return null;const i=this._getLabels(t.$view.scale),r=[];for(const t of i)t.where&&!t.where(e,s)||r.push(...t.meshes);return r}hasArcadeDependency(e){return this._labels.some(t=>t.meshes.some(t=>t.hasArcadeDependency(e)))}_getLabels(e){return this._labels.filter(t=>this._validForTileScale(t,e))}_validForTileScale(e,t){const s=t-t/4,i=t+t/2;return(!e.minScale||e.minScale>=s)&&(!e.maxScale||e.maxScale<=i)}}class ue extends oe{constructor(e,t){super(),this._defaultSymbolSortKey=0,this._nullResult=null,this._resultsMap=new Map,this._fields=[],this._fields=e,this._separator=t||""}static async fromMatcherSchema(e,t){const s=t.expression?[e.storage.createComputedField({expression:t.expression})]:[t.field?e.storage.createComputedField({field:t.field}):null,t.field2?e.storage.createComputedField({field:t.field2}):null,t.field3?e.storage.createComputedField({field:t.field3}):null],i=(await Promise.all(s)).filter(e=>!!e),r=new ue(i,t.fieldDelimiter),n=await e.createMeshWriters(t.defaultSymbol);r.setDefault(n);const o=await e.createMeshWriters(t.backgroundFill);return r.setBackgroundFill(o),await Promise.all(t.map.map(async(t,s)=>{const i=[...await e.createMeshWriters(t.meshes),...await e.createMeshWriters(t.alternateMeshes)];"<Null>"===t.value?r.setNullResult(i):r.add(t.value,i,s+1)})),r}setNullResult(e){this._nullResult=e}getSortKey(e,t){const s=this._getValueFromFields(e,t);if(null==s||""===s||"<Null>"===s)return 0;const i=this._resultsMap.get(s.toString());return i?i.sortKey:this._defaultSymbolSortKey}add(e,t,s){this._resultsMap.set(e.toString(),{meshWriters:t,sortKey:s}),this._defaultSymbolSortKey=Math.max(this._defaultSymbolSortKey,s+1)}size(){return super.size()+this._resultsMap.size}hasArcadeDependency(e){return this._fields.some(t=>t.hasArcadeDependency(e))||[...this._resultsMap.values()].some(t=>t.meshWriters.some(t=>t.hasArcadeDependency(e)))||this._nullResult?.some(t=>t.hasArcadeDependency(e))||!1}doMatch(e,t){const s=this._getValueFromFields(e,t);if(null!==this._nullResult&&(null==s||""===s||"<Null>"===s))return this._nullResult;if(null==s)return null;const i=s.toString();return this._resultsMap.get(i)?.meshWriters}_getValueFromFields(e,t){const s=[];for(const i of this._fields){const r=i.read(e,t);null==r||""===r?s.push("<Null>"):s.push(r)}return s.join(this._separator)}}async function he(e,t){switch(t.type){case"simple":case"heatmap":case"dot-density":case"pie-chart":return oe.from(e,t);case"interval":return ce.fromIntervalSchema(e,t);case"dictionary":return ae.fromDictionaryRenderer(e,t);case"label":return le.fromLabelSchema(e,t);case"map":return ue.fromMatcherSchema(e,t);case"subtype":return de.fromSubtypes(e,t);case"cluster":return pe.fromClusterSchema(e,t);case"track":return fe.fromTrackSchema(e,t);default:throw new Error("Impl")}}class de extends oe{constructor(e,t){super(),this._subMatchers=e,this._subtypeField=t}static async fromSubtypes(e,t){const s=new Map,i=[];for(const r in t.renderers){const n=parseInt(r,10),o=he(e,t.renderers[r]).then(e=>s.set(n,e));i.push(o)}return await Promise.all(i),new de(s,t.subtypeField)}match(e,t,s){const i=e.readAttribute(this._subtypeField),r=this._subMatchers.get(i);return r?r.match(e,t,s):null}hasArcadeDependency(e){for(const t of this._subMatchers.values())if(t.hasArcadeDependency(e))return!0;return!1}}class pe extends oe{static async fromClusterSchema(e,t){const[s,i]=await Promise.all([he(e,t.feature),he(e,t.cluster)]);return new pe(s,i)}constructor(e,t){super(),this._featureMatcher=e,this._clusterMatcher=t}match(e,t,s){return 1===e.readAttribute("cluster_count")?this._featureMatcher.match(e,t,s):this._clusterMatcher.match(e,t,s)}hasArcadeDependency(e){return this._featureMatcher.hasArcadeDependency(e)||this._clusterMatcher.hasArcadeDependency(e)}}class fe extends oe{static async fromTrackSchema(e,t){const[s,i,r]=await Promise.all([he(e,t.previousObservation),he(e,t.latestObservation),he(e,t.trackLine)]);return new fe(s,i,r)}constructor(e,t,s){super(),this._previousObservationMatcher=e,this._latestObservationMatcher=t,this._trackLineMatcher=s}match(e,t,s){switch(e.readAttribute(re.EA)){case 0:return this._trackLineMatcher.match(e,t,s);case 1:return this._latestObservationMatcher.match(e,t,s);case 2:return this._previousObservationMatcher.match(e,t,s)}return null}hasArcadeDependency(e){return this._trackLineMatcher.hasArcadeDependency(e)||this._latestObservationMatcher.hasArcadeDependency(e)||this._previousObservationMatcher.hasArcadeDependency(e)}}class _e extends ie{static async create(e,t){const s=await he(e,t.symbology),i=t.labels?await he(e,t.labels):null;return new _e(s,i)}constructor(e,t){super(),this._symbology=e,this._labels=t}destroy(){}async enqueueMatcherRequests(e,t){await Promise.all([this._symbology.fetchResources(e,t),this._labels?.fetchResources(e,t)])}enqueueWriterRequests(e,t,s,i){const r=this._symbology.match(t,s,i);if(r){for(const i of r)i.enqueueRequest(e,t,s);if(this._labels){const r=this._labels.match(t,s,i);if(!r)return;for(const i of r)i.enqueueRequest(e,t,s)}}}write(e,t,s,i,r,n,o){const a=this._symbology.match(s,i,r);if(a){for(const r of a)r.write(e,t,s,i,n);if(e.entityRecordCount()>=1&&this._labels){const c=this._labels.match(s,i,r);if(!c)return;for(const r of c)r.setReferences(a),r.write(e,t,s,i,n,o)}}}getSortKey(e,t){return this._symbology.getSortKey(e,t)}hasArcadeDependency(e){return!(!this._symbology.hasArcadeDependency(e)&&!this._labels?.hasArcadeDependency(e))}}var me=s(799);class ye{}class ge extends ye{constructor(e){super(),this._fetcher=e,this._controller=new AbortController,this._pendingRequests=new Map,this._resourceIdToResource=new Map}destroy(){this._controller.abort()}get _abortOptions(){return{signal:this._controller.signal}}enqueueRequest(e){const t=function(e){return"url"in e&&"urlHash"in e?{...e,url:""}:e}(e.resource),s=(0,me.xq)(JSON.stringify(t));return this._pendingRequests.has(s)||this._pendingRequests.set(s,e),s}async fetchEnqueuedResources(){const e=Array.from(this._pendingRequests.entries()),t=e.map(e=>e[1]);if(0===t.length)return;const s=await this._fetcher.fetch(t,this._abortOptions);for(let t=0;t<s.length;t++){const i=e[t][0];this._resourceIdToResource.set(i,s[t])}this._pendingRequests.clear()}async fetchResourceImmediate(e){const t=await this._fetcher.fetch([e]);if(1!==t.length)throw new Error("FeaturePipelineResourceProxy: failed to fetch resources");return t[0]}async fetchDictionaryResourceImmediate(e){const t=await this._fetcher.fetchDictionary([e]);if(1!==t.length)throw new Error("FeaturePipelineResourceProxy: failed to fetch dictionary resources");return t[0]}getResource(e){return this._resourceIdToResource.get(e)}}var xe=s(36745),we=s(35521),be=s(92580);class ve{static getPlacement(e,t,s,i,r){const n=(0,be.c)(s);return n?(-1===t&&e.invertY(),n.execute(e,s,i,r)):null}}var Se=s(68197),Ie=s(53966);function Te(e,t){return[!!e?.minScale&&t.scaleToZoom(e.minScale)||0,!!e?.maxScale&&t.scaleToZoom(e.maxScale)||100]}function ke(e){return 1<<e}function Ae(e){let t=0;for(const[s,i]of e)i&&(t|=1<<s);return t}function Me(e){let t;if(!e)return[0,0,0,0];if("string"==typeof e){const s=Se.A.fromString(e);if(!s)return Ie.A.getLogger("esri.views.2d.engine.webgl.shaderGraph.techniques.meshWriterUtils").errorOnce(new i.A("mapview:mesh-processing","Unable to parse string into color",{color:e})),[0,0,0,0];t=s.toArray()}else t=e;const[s,r,n,o]=t;return[s*(o/255),r*(o/255),n*(o/255),o]}function Ce(e){switch(e){case"butt":case"Butt":return 0;case"round":case"Round":return 1;case"square":case"Square":return 2}}function Fe(e){switch(e){case"bevel":case"Bevel":return 0;case"miter":case"Miter":return 2;case"round":case"Round":return 1}}function Ee(e,t){return Math.round(Math.min(Math.sqrt(e*t),255))}function Pe(e,t){return Math.round(e*t)/t}const Re=0,Oe=1,ze=2,Le=3,De=4,Ne=5;var qe=s(35833),Be=s(51118),Ge=s(92649);const Ue=96/72;class je{static executeEffects(e,t,s,i){const r=Ue,n=(0,Ge.getEffectsInflateSize)(e);let o=new qe.kT(t);for(const t of e){const e=(0,be.A)(t);e&&(o=e.execute(o,t,r,s,n,i))}return o}static applyEffects(e,t){if(!e)return t;const s=(0,Ge.getEffectsInflateSize)(e);let i,r=new qe.kT(xe.z.fromJSONCIM(t));for(const t of e){const e=(0,be.A)(t);e&&(r=e.execute(r,t,1,null,s,!1))}const n=[];let o=null;for(;i=r.next();)n.push(...(0,Be.x)(i)),o=i.geometryType;return 0===n.length||null===o?null:"esriGeometryPolygon"===o?{rings:n}:{paths:n}}}var We=s(89518),Ve=s(68572),Ye=s(63907);class $e{static fromVertexSpec(e,t){const s=Ve.q.fromVertexSpec(e,t);return new $e(s)}constructor(e){this._spec=e,this._packed=new Uint8Array(this._spec.stride*this._spec.packVertexCount),this._packedU32View=new Uint32Array(this._packed.buffer),this._dataView=new DataView(this._packed.buffer)}get attributeLayout(){return this._spec.attributeLayout}get stride(){return this._spec.stride}writeVertex(e,t,s,i,r,n){for(let e=0;e<this._spec.packVertexCount;e++){const o=e*this._spec.stride;this._packPosition(s,i,o),this._packId(t,o);const a=this._spec.bitset;if(n){if(a.packTessellation){const e=a.packTessellation(n,r,s,i);this._pack(e,a,o)}for(const e of this._spec.standardAttributes)if(null!=e.packTessellation){const t=e.packTessellation(n,r,s,i);this._pack(t,e,o)}else if(e.packAlternating?.packTessellation){const t=e.packAlternating.packTessellation(n,r,s,i);for(let s=0;s<this._spec.packVertexCount;s++){const i=t[s];this._pack(i,e,s*this._spec.stride)}}}}e.vertexWriteRegion(this._packedU32View)}pack(e,t){for(const s of this._spec.standardAttributes)if(s.pack&&"string"!=typeof s.pack){const i=s.pack(e,t);for(let e=0;e<this._spec.packVertexCount;e++)this._pack(i,s,e*this._spec.stride)}else if(s.packAlternating?.pack){const i=s.packAlternating.pack(e,t);for(let e=0;e<this._spec.packVertexCount;e++){const t=i[e];this._pack(t,s,e*this._spec.stride)}}}_packPosition(e,t,s){const{offset:i}=this._spec.position,r=this._spec.position.packPrecisionFactor??1,n=(0,We.M9)(e*r,t*r);this._dataView.setUint32(s+i,n,!0)}_packId(e,t){const s=e*(this._spec.id.packPrecisionFactor??1),i=4278190080&this._dataView.getUint32(t+this._spec.id.offset,!0);this._dataView.setUint32(t+this._spec.id.offset,s|i,!0)}_pack(e,t,s){!function(e,t,s,i){const r=s.packPrecisionFactor??1;switch(s.type){case Ye.pe.BYTE:if(1===s.count)e.setInt8(i+s.offset,t*r);else for(let n=0;n<s.count;n++){const o=n*Int8Array.BYTES_PER_ELEMENT;e.setInt8(i+s.offset+o,t[n]*r)}break;case Ye.pe.UNSIGNED_BYTE:if(1===s.count)e.setUint8(i+s.offset,t*r);else for(let n=0;n<s.count;n++){const o=n*Uint8Array.BYTES_PER_ELEMENT;e.setUint8(i+s.offset+o,t[n]*r)}break;case Ye.pe.SHORT:if(1===s.count)e.setInt16(i+s.offset,t*r,!0);else for(let n=0;n<s.count;n++){const o=n*Int16Array.BYTES_PER_ELEMENT;e.setInt16(i+s.offset+o,t[n]*r,!0)}break;case Ye.pe.UNSIGNED_SHORT:if(1===s.count)e.setUint16(i+s.offset,t*r,!0);else for(let n=0;n<s.count;n++){const o=n*Uint16Array.BYTES_PER_ELEMENT;e.setUint16(i+s.offset+o,t[n]*r,!0)}break;case Ye.pe.INT:if(1===s.count)e.setInt32(i+s.offset,t*r,!0);else for(let n=0;n<s.count;n++){const o=n*Int32Array.BYTES_PER_ELEMENT;e.setInt32(i+s.offset+o,t[n]*r,!0)}break;case Ye.pe.UNSIGNED_INT:if(1===s.count)e.setUint32(i+s.offset,t*r,!0);else for(let n=0;n<s.count;n++){const o=n*Uint32Array.BYTES_PER_ELEMENT;e.setUint32(i+s.offset+o,t[n]*r,!0)}break;case Ye.pe.FLOAT:if(1===s.count)e.setFloat32(i+s.offset,t*r,!0);else for(let n=0;n<s.count;n++){const o=n*Float32Array.BYTES_PER_ELEMENT;e.setFloat32(i+s.offset+o,t[n]*r,!0)}break;case Ye.pe.HALF_FLOAT:if(1===s.count)e.setUint16(i+s.offset,(0,We.fw)(t*r),!0);else for(let n=0;n<s.count;n++){const o=n*Uint16Array.BYTES_PER_ELEMENT;e.setUint16(i+s.offset+o,(0,We.fw)(t[n]*r),!0)}}}(this._dataView,e,t,s)}}class He{constructor(e,t,s,i){this._instanceId=e,this._evaluator=t,this._enabledOptionalAttributes=s,this._viewParams=i,this._evaluator.evaluator=e=>this.vertexSpec.createComputedParams(e)}get _vertexPack(){if(!this._cachedVertexPack){const e=$e.fromVertexSpec(this.vertexSpec,this._enabledOptionalAttributes);this._evaluator.hasDynamicProperties||e.pack(this._evaluator.evaluatedMeshParams,this._viewParams),this._cachedVertexPack=e}return this._cachedVertexPack}get evaluatedMeshParams(){return this._evaluator.evaluatedMeshParams}get hasEffects(){return!!this.evaluatedMeshParams.effects}get effectInfos(){return this._evaluator.inputMeshParams.effects?.effectInfos}get placementInfo(){return this._evaluator.inputMeshParams.placement}get instanceId(){return this._instanceId}get attributeLayout(){return this._vertexPack.attributeLayout}get _preventEffectClipping(){return!1}setReferences(e){this._references=e}getBoundsInfo(){return null}getTileInfo(){return this._viewParams.tileInfo}async loadDependencies(){for(const{effect:e}of this.effectInfos||[])await(0,qe.ai)(e);this.placementInfo&&await(0,qe.g1)(this.placementInfo.placement)}enqueueRequest(e,t,s){this._evaluator.hasDynamicProperties&&this._evaluator.enqueueRequest(e,t,s)}write(e,t,s,i,r,n){this.ensurePacked(t,s,i);const o=this.evaluatedMeshParams.effects;if(!o||0===o.length)return void this._write(e,s,void 0,r,n);const a=this.getEffectCursor(e,s,o);if(!a)return;let c;for(;c=a.next();)c.invertY(),this._write(e,s,c,r,n)}ensurePacked(e,t,s){if(!this._evaluator.hasDynamicProperties)return;const i=this._evaluator.evaluateMeshParams(e,t,s);this._vertexPack.pack(i,this._viewParams)}hasArcadeDependency(e){return this._evaluator.hasArcadeDependency(e)}_writeVertex(e,t,s,i,r){const n=this.evaluatedMeshParams;this._vertexPack.writeVertex(e,t,s,i,n,r)}getEffectCursor(e,t,s){const i=t.readGeometryForDisplay()?.clone();if(!i)return;const r=xe.z.fromOptimizedCIM(i,t.geometryType);r.invertY();const n=e.id||"";return je.executeEffects(s,r,n,this._preventEffectClipping)}}class Ze extends He{}var Qe=s(13195);function Xe(e,t){let s;if("string"==typeof e)s=(0,me.Wm)(e+`-seed(${t})`);else{let i=12;s=e^t;do{s=107*(s>>8^s)+i|0}while(0!==--i)}return(1+s/(1<<31))/2}function Ke(e){return Math.floor(Xe(e,Je)*et)}const Je=53290320,et=10;class tt{generateSource(e){const t=[];for(let s=1;s<this.length;s++)t.push(`vec4 atom${s} = texture(${e.animationTexture}, (pointer + 0.5) / size);`),t.push("pointer.x += 1.0;");for(let e=0;e<this.ins;e++)t.push("top--;"),t.push(`vec4 in${this.ins-e-1} = stack[top];`);for(let e=0;e<this.outs;e++)t.push(`vec4 out${e};`);const{microcode:s}=this;for(const e of s)t.push(e);for(let e=0;e<this.outs;e++)t.push(`stack[top] = out${e};`),t.push("top++;"),t.push(`if (top >= ${lt}) { top = ${lt-1}; }`);return t}}let st=128;function it(e){return[`float duration = clamp(${e.duration}, 0.05, 3600.0);`,`float startTimeOffset = ${e.startTimeOffset};`,`float repeatDelay = ${e.repeatDelay};`,`float timeOriginSelector = ${e.timeOriginSelector};`,`float repeatType = ${e.repeatType};`,`float easing = ${e.easing};`,`float playAnimation = ${e.playAnimation} * (1.0 - step(0.0, -${e.duration}));`,`float reverseAnimation = ${e.reverseAnimation};`,"float time = globalTime - (timeOriginSelector == 1.0 ? localTimeOrigin : 0.0);","time *= playAnimation;","time *= 1.0 - reverseAnimation * 2.0;","float period = duration + repeatDelay;","time += reverseAnimation == 1.0 ? (period - startTimeOffset - 0.001) : startTimeOffset + 0.001;","float omega = time / period;","float oi = floor(omega);","omega = repeatType == 1.0 || repeatType == 3.0 ? omega - oi : omega;","float of = omega * period;","of = (clamp(of, reverseAnimation * repeatDelay, period - (1.0 - reverseAnimation) * repeatDelay) - reverseAnimation * repeatDelay) / duration;","of = easing == 2.0 ? pow(of, 3.0) : of;","of = easing == 3.0 ? 1.0 - pow(1.0 - of, 3.0) : of;","of = easing == 4.0 ? of < 0.5 ? 4.0 * pow(of, 3.0) : 1.0 - pow(-2.0 * of + 2.0, 3.0) / 2.0 : of;","bool oscillate = repeatType == 3.0 && mod(oi, 2.0) == 1.0;",`${e.out} = oscillate ? 1.0 - of : of;`]}const rt={Linear:1,EaseIn:2,EaseOut:3,EaseInOut:4},nt={Loop:1,None:2,Oscillate:3},ot={Local:1,Global:2};function at(e){const t=rt[e.easing],s=nt[e.repeatType],i=ot[e.timeOriginSelector];return[[e.duration,e.startTimeOffset,e.repeatDelay,i],[s,t,e.playAnimation,e.reverseAnimation]]}const ct={scalar:new class extends tt{constructor(){super(...arguments),this.opcode=++st,this.length=1,this.ins=0,this.outs=1,this.microcode=["out0 = vec4(atom0.y, atom0.y, atom0.y, atom0.y);"]}encode(e){return[[this.opcode,e,0,0]]}},vector3:new class extends tt{constructor(){super(...arguments),this.opcode=++st,this.length=1,this.ins=0,this.outs=1,this.microcode=["out0 = vec4(atom0.yzw, 0.0);"]}encode(e){return[[this.opcode,e[0]||0,e[1]||0,e[2]||0]]}},vector4:new class extends tt{constructor(){super(...arguments),this.opcode=++st,this.length=2,this.ins=0,this.outs=1,this.microcode=["out0 = atom1;"]}encode(e){return[[this.opcode,0,0,0],e]}},animatedTransform:new class extends tt{constructor(){super(...arguments),this.opcode=++st,this.length=10,this.ins=1,this.outs=1,this.microcode=["vec2 fromTranslation = atom1.xy;","vec2 toTranslation = atom1.zw;","float fromRotation = atom2.x;","float toRotation = atom2.y;","float fromScale = atom2.z;","float toScale = atom2.w;","bool relativeTranslation = atom9.x == 1.0;","bool absoluteScale = atom9.y == 1.0;","vec2 translationMultiplier = relativeTranslation ? pixelDimensions : vec2(1.0, 1.0);","float scaleDivisor = absoluteScale ? pixelDimensions.y : 1.0;","float fTranslation;","{",...it({duration:"atom3.x",startTimeOffset:"atom3.y",repeatDelay:"atom3.z",timeOriginSelector:"atom3.w",repeatType:"atom4.x",easing:"atom4.y",playAnimation:"atom4.z",reverseAnimation:"atom4.w",out:"fTranslation"}),"}","float fRotation;","{",...it({duration:"atom5.x",startTimeOffset:"atom5.y",repeatDelay:"atom5.z",timeOriginSelector:"atom5.w",repeatType:"atom6.x",easing:"atom6.y",playAnimation:"atom6.z",reverseAnimation:"atom6.w",out:"fRotation"}),"}","float fScale;","{",...it({duration:"atom7.x",startTimeOffset:"atom7.y",repeatDelay:"atom7.z",timeOriginSelector:"atom7.w",repeatType:"atom8.x",easing:"atom8.y",playAnimation:"atom8.z",reverseAnimation:"atom8.w",out:"fScale"}),"}","vec2 aTranslation = mix(fromTranslation, toTranslation, fTranslation);","float aRotation = mix(fromRotation, toRotation, fRotation);","float aScale = mix(fromScale, toScale, fScale);","vec2 pTranslation = in0.xy;","float pRotation = in0.z;","float pScale = in0.w;","aTranslation *= translationMultiplier;","aScale /= scaleDivisor;","float rotation = pRotation + aRotation;","float scale = pScale * aScale;","float sin1 = sin(pRotation);","float cos1 = cos(pRotation);","float s1 = pScale;","float x1 = pTranslation.x;","float y1 = pTranslation.y;","float x2 = aTranslation.x;","float y2 = aTranslation.y;","\n vec2 translation = vec2(\n cos1 * s1 * x2 - sin1 * s1 * y2 + x1,\n sin1 * s1 * x2 + cos1 * s1 * y2 + y1\n );\n ","out0 = vec4(translation, rotation, scale);"]}encode(e){return[[this.opcode,0,0,0],[e.translation.from[0],e.translation.from[1],e.translation.to[0],e.translation.to[1]],[e.rotation.from,e.rotation.to,e.scale.from,e.scale.to],...at(e.translation.timing),...at(e.rotation.timing),...at(e.scale.timing),[e.relativeTranslation?1:0,e.absoluteScale?1:0,0,0]]}},animatedColor:new class extends tt{constructor(){super(...arguments),this.opcode=++st,this.length=7,this.ins=1,this.outs=1,this.microcode=["float fromOpacity = atom0.y;","float toOpacity = atom0.z;","vec4 fromColor = atom1;","vec4 toColor = atom2;","float fColor;","{",...it({duration:"atom3.x",startTimeOffset:"atom3.y",repeatDelay:"atom3.z",timeOriginSelector:"atom3.w",repeatType:"atom4.x",easing:"atom4.y",playAnimation:"atom4.z",reverseAnimation:"atom4.w",out:"fColor"}),"}","float fOpacity;","{",...it({duration:"atom5.x",startTimeOffset:"atom5.y",repeatDelay:"atom5.z",timeOriginSelector:"atom5.w",repeatType:"atom6.x",easing:"atom6.y",playAnimation:"atom6.z",reverseAnimation:"atom6.w",out:"fOpacity"}),"}","vec4 aColor = mix(fromColor, toColor, fColor);","aColor.a *= mix(fromOpacity, toOpacity, fOpacity);","vec4 pColor = in0;","out0 = aColor * pColor;"]}encode(e){return[[this.opcode,e.opacity.from,e.opacity.to,0],[e.color.from[0],e.color.from[1],e.color.from[2],e.color.from[3]],[e.color.to[0],e.color.to[1],e.color.to[2],e.color.to[3]],...at(e.color.timing),...at(e.opacity.timing)]}},animatedShift:new class extends tt{constructor(){super(...arguments),this.opcode=++st,this.length=4,this.ins=1,this.outs=1,this.microcode=["float fromShift = atom0.y;","float toShift = atom0.z;","float duration = atom1.x;","bool multiplyByLineLength = atom3.x == 1.0;","float fShift;","{",...it({duration:"duration",startTimeOffset:"atom1.y",repeatDelay:"atom1.z",timeOriginSelector:"atom1.w",repeatType:"atom2.x",easing:"atom2.y",playAnimation:"atom2.z",reverseAnimation:"atom2.w",out:"fShift"}),"}","toShift *= multiplyByLineLength ? lineLength : 1.0;","float aShift = mix(fromShift, toShift, fShift);","vec4 pShift = in0;","out0 = mod(aShift + pShift, lineLength);"]}encode(e){return[[this.opcode,e.shift.from,e.shift.to,0],...at(e.shift.timing),[e.multiplyByLineLength?1:0,0,0,0]]}},ret:new class extends tt{constructor(){super(...arguments),this.opcode=++st,this.length=1,this.ins=0,this.outs=0,this.microcode=["break;"]}encode(){return[[this.opcode,0,0,0]]}}},lt=4;function ut(e){return e instanceof ht?e:"object"==typeof e&&"type"in e?mt[e.type].hydrate(e):new dt(e)}class ht{constructor(e){this.inputs=e}encode(){const e=[];for(const t of this.inputs)e.push(...t.encode());return e.push(...this.instructions),e}}class dt extends ht{constructor(e){super([]),this.value=e}simplify(){return this}get instructions(){if(Array.isArray(this.value)){const[e,t,s,i]=this.value;return null!=i?ct.vector4.encode([e,t||0,s||0,i]):ct.vector3.encode([e,t||0,s||0])}return ct.scalar.encode(this.value)}}class pt extends ht{constructor(e,t){super([t]),this._config=e,this._parent=t}static hydrate(e){return new pt(e,ut(e.parent))}simplify(){if(this._config.relativeTranslation||this._config.absoluteScale)return this;const e=this._parent.simplify();if(!(e instanceof dt))return this;const[t,s,i,r]=e.value,n=this._config.translation.from[0],o=this._config.translation.from[1],a=this._config.rotation.from,c=this._config.scale.from;if(n===this._config.translation.to[0]&&o===this._config.translation.to[1]&&a===this._config.rotation.to&&c===this._config.scale.to){const e=i+a,l=r*c,u=Math.sin(i),h=Math.cos(i);return new dt([h*r*n-u*r*o+t,u*r*n+h*r*o+s,e,l])}return new pt(this._config,e)}get instructions(){return ct.animatedTransform.encode(this._config)}}class ft extends ht{constructor(e,t){super([t]),this._config=e,this._parent=t}static hydrate(e){return new ft(e,ut(e.parent))}simplify(){const e=this._parent.simplify();if(!(e instanceof dt))return this;const[t,s,i,r]=e.value,n=this._config.color.from[0],o=this._config.color.from[1],a=this._config.color.from[2];let c=this._config.color.from[3];const l=this._config.opacity.from;return n===this._config.color.to[0]&&o===this._config.color.to[1]&&a===this._config.color.to[2]&&c===this._config.color.to[3]&&l===this._config.opacity.to?(c*=l,new dt([t*n,s*o,i*a,r*c])):new ft(this._config,e)}get instructions(){return ct.animatedColor.encode(this._config)}}class _t extends ht{constructor(e,t){super([t]),this._config=e,this._parent=t}static hydrate(e){return new _t(e,ut(e.parent))}simplify(){const e=this._parent.simplify();return e instanceof dt?new _t(this._config,e):this}get instructions(){return ct.animatedShift.encode(this._config)}}const mt={AnimatedTransform:pt,AnimatedColor:ft,AnimatedShift:_t};function yt(e){return xt(e.map(e=>bt(e)).map(e=>ut(e).simplify()))}function gt(e){const t=[];return t.push(e.transform),t.push(e.fromColor),t.push(e.toColor),t.push(e.colorMix),t.push(e.toOpacity),t.push(e.opacityMix),e?.shift?t.push(e?.shift):t.push([1,1,1,1]),t}function xt(e){const t=[],s=[];let i=0;for(const r of e){const n=[...r.encode(),...ct.ret.encode()];t.push([i+e.length,0,0,0]),s.push(...n),i+=n.length}return[...t,...s]}async function wt(e,t){const s=e;let i;if("number"==typeof s||"string"==typeof s||"boolean"==typeof s)i=s;else if(Array.isArray(s))i=await Promise.all(s.map(e=>wt(e,t)));else if("object"==typeof s)if("valueExpressionInfo"in s){const{valueExpressionInfo:e}=s,{expression:r}=e;i={...s,computed:await t.createComputedField({expression:r})}}else{i={};for(const e in s)i[e]=await wt(s[e],t)}return i}function bt(e,t,s){const i=e;let r;if("number"==typeof i||"string"==typeof i||"boolean"==typeof i)r=i;else if(Array.isArray(i))r=i.map(e=>bt(e,t,s));else if("object"==typeof i)if("type"in i&&null!=i.type&&"Process"===i.type)switch(i.op){case"ArcadeColor":{const e=bt(i.value,t,s);St(Array.isArray(e)&&4===e.length),r=[e[0]/255,e[1]/255,e[2]/255,e[3]]}break;case"Transparency":{const e=bt(i.value,t,s);St("number"==typeof e),r=1-e/100}break;case"Divide":case"Multiply":case"Add":{const e=bt(i.left,t,s);St("number"==typeof e);const n=bt(i.right,t,s);switch(St("number"==typeof n),i.op){case"Divide":r=e/n;break;case"Multiply":r=e*n;break;case"Add":r=e+n}}break;case"Random":{const e=bt(i.seed,t,s),n=bt(i.min,t,s),o=bt(i.max,t,s);r=n+Xe(Ke(t.getObjectId()||0),e)*(o-n)}break;case"Cond":{const e=bt(i.condition,t,s),n=bt(i.ifTrue,t,s),o=bt(i.ifFalse,t,s);r=e?n:o}break;case"MatchWinding":{const e=bt(i.sign,t,s);let n=bt(i.angle,t,s);if(e>0)for(;n<0;)n+=2*Math.PI;else for(;n>0;)n-=2*Math.PI;r=n}}else if("computed"in i)r=function(e){if(!("computed"in e))return e;let i=e.computed.readWithDefault(t,s,[255*e.defaultValue[0],255*e.defaultValue[1],255*e.defaultValue[2],e.defaultValue[3]]);if("string"==typeof i){const e=Se.A.fromString(i);e&&(i=[e.r,e.g,e.b,e.a])}return i}(i);else{r={};for(const e in i)r[e]=bt(i[e],t,s)}return r}function*vt(e){const t=e;if(Array.isArray(t))for(const e of t)yield*vt(e);else if("object"==typeof t)if("type"in t&&null!=t.type&&"Process"===t.type)switch(t.op){case"ArcadeColor":case"Transparency":yield*vt(t.value);break;case"Divide":case"Multiply":case"Add":yield*vt(t.left),yield*vt(t.right);break;case"Random":yield*vt(t.seed),yield*vt(t.min),yield*vt(t.max);break;case"Cond":yield*vt(t.condition),yield*vt(t.ifTrue),yield*vt(t.ifFalse);break;case"MatchWinding":yield*vt(t.sign),yield*vt(t.angle)}else if("computed"in t)yield t.computed;else for(const e in t)yield*vt(t[e])}function St(e){if(!e)throw new Error("Assertion failed.")}const It={type:Ye.pe.SHORT,count:2,packPrecisionFactor:p.fq,pack:({scaleInfo:e},{tileInfo:t})=>Te(e,t)},Tt={type:Ye.pe.FLOAT,count:4,packPrecisionFactor:1,packTessellation:({value1Position2Value2:e})=>(St(e),e)},kt={type:Ye.pe.FLOAT,count:4,packPrecisionFactor:1,packTessellation:()=>[0,0,0,1]},At={type:Ye.pe.FLOAT,count:1,packPrecisionFactor:1,pack:()=>0},Mt={type:Ye.pe.FLOAT,count:1,packPrecisionFactor:1,packTessellation:({lineLength:e})=>e},Ct={type:Ye.pe.UNSIGNED_SHORT,count:1,packTessellation:({distance:e})=>e},Ft={type:Ye.pe.BYTE,count:2,packPrecisionFactor:16,packTessellation:({directionX:e,directionY:t})=>[e,t]},Et={type:Ye.pe.FLOAT,count:2,packPrecisionFactor:16,packTessellation:({normalX:e,normalY:t})=>[e,t]},Pt={type:Ye.pe.UNSIGNED_BYTE,count:3,pack:"id"},Rt={type:Ye.pe.UNSIGNED_BYTE,count:1,pack:function(e){const{sprite:t,isMapAligned:s,colorLocked:i,scaleSymbolsProportionally:r,isStroke:n}=e;let o=0;return s&&(o|=ke(Oe)),i&&(o|=ke(De)),t.sdf&&(o|=ke(Re)),r&&(o|=ke(ze)),n&&(o|=ke(Ne)),o}},Ot={type:Ye.pe.SHORT,count:2,pack:"position",packPrecisionFactor:1},zt={marker:{type:Ye.pe.FLOAT,count:2,packAlternating:{count:4,pack:({texelDimensions:e})=>[[-.5*e[0],-.5*e[1]],[.5*e[0],-.5*e[1]],[-.5*e[0],.5*e[1]],[.5*e[0],.5*e[1]]]}},line:{type:Ye.pe.FLOAT,count:2,packTessellation:({extrusionOffsetX:e,extrusionOffsetY:t},{baseSize:s})=>[e*s/2,t*s/2]},fill:{type:Ye.pe.FLOAT,count:2,packTessellation:()=>[0,0]}},Lt={marker:{type:Ye.pe.SHORT,count:2,packPrecisionFactor:1,packAlternating:{count:4,packTessellation:({texXmax:e,texXmin:t,texYmax:s,texYmin:i})=>[[t,i],[e,i],[t,s],[e,s]]}}},Dt={type:Ye.pe.UNSIGNED_SHORT,count:4,pack:({sprite:e})=>{const{rect:t,width:s,height:i}=e,r=t.x+p.hM,n=t.y+p.hM;return[r+1,n+1,r+s-1,n+i-1]}},Nt={type:Ye.pe.UNSIGNED_SHORT,count:4,packPrecisionFactor:4,pack:({animations:e,baseSize:t,referenceSize:s})=>[e.dataColumn,e.dataRow,t,s]},qt={type:Ye.pe.UNSIGNED_SHORT,count:4,packPrecisionFactor:8,pack:({strokeWidth:e,pixelDimensions:t,baseSize:s,sprite:i,sizeRatio:r})=>{const n=Math.max(s*i.width/i.height,s),o=i.sdfDecodeCoeff*n*r;return[t[0],t[1],e,o]}},Bt={type:Ye.pe.BYTE,count:1,packTessellation:({angle:e})=>e*Qe.aA},Gt={type:Ye.pe.BYTE,count:1,pack:({angle:e})=>e?e*Qe.aA:0},Ut={type:Ye.pe.BYTE,count:1,pack:()=>0};function jt(e){let{pixelDimensions:t,texelDimensions:s,baseSize:i,referenceSize:r,strokeWidth:n,sizeRatio:o}=e;if(t||(t=e.sprite.sdf?[0,0]:[e.sprite.width,e.sprite.height]),s||(s=e.sprite.sdf?[0,0]:t),null!=e.patternHeight){const s=e.patternHeight/t[1];t[1]*=s,t[0]*=s}-1===i&&(i=t[1]),i=(0,u.Lz)(i),r=(0,u.Lz)(r),n=(0,u.Lz)(n);const a=(e.sprite.sdfDecodeCoeff??1)*o;return{...e,pixelDimensions:t,texelDimensions:s,baseSize:i,referenceSize:r,strokeWidth:n,sdfDecodeCoeff:a}}class Wt extends Ze{get vertexSpec(){return{createComputedParams:jt,optionalAttributes:{zoomRange:It,value1Position2Value2:Tt,lineLength:Mt},attributes:{id:Pt,bitset:Rt,pos:Ot,offset:zt.marker,uv:Lt.marker,animationPointerAndBaseSizeAndReferenceSize:Nt,sizing:qt,angle:Bt}}}_write(e,t,s){const i=this.evaluatedMeshParams.sprite,{textureBinding:r}=i;e.recordStart(this.instanceId,this.attributeLayout,r);const n=t.getDisplayId();if(this.shift&&"esriGeometryPolyline"===t.geometryType){if(!s){const s=xe.z.fromFeatureSetReaderCIM(t);s&&this._writeParticles(e,t,s)}}else if(null!=this.evaluatedMeshParams.placement)this._writePlacedMarkers(e,t);else if("esriGeometryPolygon"===t.geometryType){const s=t.readCentroidForDisplay();if(!s)return;const[i,r]=s.coords;this._writeQuad(e,n,i,r)}else if("esriGeometryPoint"===t.geometryType){const s=t.readXForDisplay(),i=t.readYForDisplay();this._writeQuad(e,n,s,i)}else{const s=t.readGeometryForDisplay();s&&s.forEachVertex((t,s)=>{this._writeQuad(e,n,t,s)})}e.recordEnd()}_writePlacedMarkers(e,t){const s=xe.z.fromFeatureSetReaderCIM(t)?.clone();if(!s)return;const i=ve.getPlacement(s,-1,this.evaluatedMeshParams.placement,(0,u.Lz)(1),e.id);if(!i)return;const r=t.getDisplayId();let n=i.next(),o=null;for(;null!=n;){const t=n.tx,s=-n.ty;if(Math.abs(t)>we.$u||Math.abs(s)>we.$u){n=i.next();continue}const a=-n.getAngle();e.recordBounds(t,s,64,64),this.shift?o&&this._writeQuad(e,r,o[0],o[1],void 0,a):this._writeQuad(e,r,t,s,void 0,a),o=[t,s],n=i.next()}}_writeParticles(e,t,s){const i=t.getDisplayId();for(;s.nextPath();){const t=[];for(;s.nextPoint();)t.push([s.x,s.y]);const r=Vt(t);let n=0;for(let e=1;e<t.length;e++){const s=t[e][0]-t[e-1][0],i=t[e][1]-t[e-1][1],r=Math.sqrt(s*s+i*i);n+=r}const o=t=>{for(const s of r){const{a:r,b:o}=s;this._writeQuad(e,i,r.position[0],r.position[1],[r.distance-t,o.position[0],o.position[1],o.distance-t],this.evaluatedMeshParams.angleToLine?Math.atan2(r.direction[1],r.direction[0]):0,n,!0)}},{placement:a}=this.evaluatedMeshParams;if(!a||"placementTemplate"in a||"CIMMarkerPlacementOnVertices"===a.type){let e;if(a&&"CIMMarkerPlacementOnVertices"!==a.type)e=a.placementTemplate;else{e=[0];for(const t of r){const{a:s,b:i}=t,r=s.position[0]-i.position[0],n=s.position[1]-i.position[1],o=Math.sqrt(r*r+n*n);e.push(o)}}let t=-1*n;for(;t<2*n;)for(const s of e)t+=s,o(t)}else"CIMMarkerPlacementAtExtremities"===a.type?"JustBegin"===a.extremityPlacement?o(1):"JustEnd"===a.extremityPlacement?(o(n-1),o(-1)):"Both"===a.extremityPlacement&&(o(1),o(n-1)):"CIMMarkerPlacementOnLine"===a.type&&("LineBeginning"===a.relativeTo?o(1):"LineEnd"===a.relativeTo?(o(n-1),o(-1)):"LineMiddle"===a.relativeTo&&o(n/2))}}_writeQuad(e,t,s,i,r,n=0,o=0,a=!1){const c=this.evaluatedMeshParams.sprite,{rect:l}=c,u=l.x+p.hM,h=l.y+p.hM,d=l.x+l.width-p.hM,f=l.y+l.height-p.hM,_=e.vertexCount();a||e.recordBounds(s,i,64,64);const m={texXmin:u,texYmin:h,texXmax:d,texYmax:f,value1Position2Value2:r,angle:n/.024543692606171875,lineLength:o};for(let r=0;r<4;r++)this._writeVertex(e,t,s,i,m);e.indexEnsureSize(6),e.indexWrite(_),e.indexWrite(_+1),e.indexWrite(_+2),e.indexWrite(_+1),e.indexWrite(_+3),e.indexWrite(_+2)}}function Vt(e){const t=[];let s=0;for(let i=1;i<e.length;i++){const r=e[i-1],n=e[i],o=n[0]-r[0],a=n[1]-r[1],c=Math.sqrt(o*o+a*a),l=o/c,u=a/c;t.push({a:{position:r,distance:s,direction:[l,u]},b:{position:n,distance:s+c,direction:[l,u]}}),s+=c}return t}class Yt extends Wt{constructor(){super(...arguments),this.shift=!1}}class $t extends Wt{constructor(){super(...arguments),this.shift=!0}}var Ht=s(15585),Zt=s(83773),Qt=s(6774),Xt=s(92722);function Kt(e,t,s,i,r,n,o){vs=0;const a=(i-s)*n,c=r&&r.length,l=c?(r[0]-s)*n:a;let u,h,d,p,f,_=Jt(t,s,0,0,l,n,!0);if(_&&_.next!==_.prev){if(c&&(_=function(e,t,s,i,r,n){const o=new Array;for(let r=0,a=i.length;r<a;r++){const c=Jt(e,t,0,i[r]*n,r<a-1?i[r+1]*n:s*n,n,!1);c===c.next&&(c.steiner=!0),o.push(os(c))}o.sort(_s);for(const e of o)r=as(e,r);return r}(t,s,i,r,_,n)),a>80*n){u=d=t[0+s*n],h=p=t[1+s*n];for(let e=n;e<l;e+=n){const i=t[e+s*n],r=t[e+1+s*n];u=Math.min(u,i),h=Math.min(h,r),d=Math.max(d,i),p=Math.max(p,r)}f=Math.max(d-u,p-h),f=0!==f?1/f:0}ts(_,e,n,u,h,f,o,0)}}function Jt(e,t,s,i,r,n,o){let a;if(o===function(e,t,s,i,r,n){let o=0;for(let s=i,a=r-n;s<r;s+=n)o+=(e[a+t*n]-e[s+t*n])*(e[s+1+t*n]+e[a+1+t*n]),a=s;return o}(e,t,0,i,r,n)>0)for(let s=i;s<r;s+=n)a=rs(s+t*n,e[s+t*n],e[s+1+t*n],a);else for(let s=r-n;s>=i;s-=n)a=rs(s+t*n,e[s+t*n],e[s+1+t*n],a);return a&&fs(a,a.next)&&(ns(a),a=a.next),a}function es(e,t=e){if(!e)return e;let s,i=e;do{if(s=!1,i.steiner||!fs(i,i.next)&&0!==ls(i.prev,i,i.next))i=i.next;else{if(ns(i),i=t=i.prev,i===i.next)break;s=!0}}while(s||i!==t);return t}function ts(e,t,s,i,r,n,o,a){if(!e)return;!a&&n&&(e=cs(e,i,r,n));let c=e;for(;e.prev!==e.next;){const l=e.prev,u=e.next;if(n?is(e,i,r,n):ss(e))t.push(l.index/s+o),t.push(e.index/s+o),t.push(u.index/s+o),ns(e),e=u.next,c=u.next;else if((e=u)===c){a?1===a?ts(e=ms(e,t,s,o),t,s,i,r,n,o,2):2===a&&ys(e,t,s,i,r,n,o):ts(es(e),t,s,i,r,n,o,1);break}}}function ss(e){const t=e.prev,s=e,i=e.next;if(ls(t,s,i)>=0)return!1;let r=e.next.next;const n=r;let o=0;for(;r!==e.prev&&(0===o||r!==n);){if(o++,hs(t.x,t.y,s.x,s.y,i.x,i.y,r.x,r.y)&&ls(r.prev,r,r.next)>=0)return!1;r=r.next}return!0}function is(e,t,s,i){const r=e.prev,n=e,o=e.next;if(ls(r,n,o)>=0)return!1;const a=r.x<n.x?r.x<o.x?r.x:o.x:n.x<o.x?n.x:o.x,c=r.y<n.y?r.y<o.y?r.y:o.y:n.y<o.y?n.y:o.y,l=r.x>n.x?r.x>o.x?r.x:o.x:n.x>o.x?n.x:o.x,u=r.y>n.y?r.y>o.y?r.y:o.y:n.y>o.y?n.y:o.y,h=ps(a,c,t,s,i),d=ps(l,u,t,s,i);let p=e.prevZ,f=e.nextZ;for(;p&&p.z>=h&&f&&f.z<=d;){if(p!==e.prev&&p!==e.next&&hs(r.x,r.y,n.x,n.y,o.x,o.y,p.x,p.y)&&ls(p.prev,p,p.next)>=0)return!1;if(p=p.prevZ,f!==e.prev&&f!==e.next&&hs(r.x,r.y,n.x,n.y,o.x,o.y,f.x,f.y)&&ls(f.prev,f,f.next)>=0)return!1;f=f.nextZ}for(;p&&p.z>=h;){if(p!==e.prev&&p!==e.next&&hs(r.x,r.y,n.x,n.y,o.x,o.y,p.x,p.y)&&ls(p.prev,p,p.next)>=0)return!1;p=p.prevZ}for(;f&&f.z<=d;){if(f!==e.prev&&f!==e.next&&hs(r.x,r.y,n.x,n.y,o.x,o.y,f.x,f.y)&&ls(f.prev,f,f.next)>=0)return!1;f=f.nextZ}return!0}function rs(e,t,s,i){const r=ws.create(e,t,s);return i?(r.next=i.next,r.prev=i,i.next.prev=r,i.next=r):(r.prev=r,r.next=r),r}function ns(e){e.next.prev=e.prev,e.prev.next=e.next,e.prevZ&&(e.prevZ.nextZ=e.nextZ),e.nextZ&&(e.nextZ.prevZ=e.prevZ)}function os(e){let t=e,s=e;do{(t.x<s.x||t.x===s.x&&t.y<s.y)&&(s=t),t=t.next}while(t!==e);return s}function as(e,t){const s=function(e,t){let s=t;const i=e.x,r=e.y;let n,o=-1/0;do{if(r<=s.y&&r>=s.next.y&&s.next.y!==s.y){const e=s.x+(r-s.y)*(s.next.x-s.x)/(s.next.y-s.y);if(e<=i&&e>o){if(o=e,e===i){if(r===s.y)return s;if(r===s.next.y)return s.next}n=s.x<s.next.x?s:s.next}}s=s.next}while(s!==t);if(!n)return null;if(i===o)return n.prev;const a=n,c=n.x,l=n.y;let u,h=1/0;for(s=n.next;s!==a;)i>=s.x&&s.x>=c&&i!==s.x&&hs(r<l?i:o,r,c,l,r<l?o:i,r,s.x,s.y)&&(u=Math.abs(r-s.y)/(i-s.x),(u<h||u===h&&s.x>n.x)&&ds(s,e)&&(n=s,h=u)),s=s.next;return n}(e,t);if(!s)return t;const i=xs(s,e);return es(i,i.next),es(s,s.next)}function cs(e,t,s,i){let r;for(;r!==e;r=r.next){if(r=r||e,null===r.z&&(r.z=ps(r.x,r.y,t,s,i)),r.prev.next!==r||r.next.prev!==r)return r.prev.next=r,r.next.prev=r,cs(e,t,s,i);r.prevZ=r.prev,r.nextZ=r.next}return e.prevZ.nextZ=null,e.prevZ=null,function(e){let t,s=1;for(;;){let i,r=e;e=null,t=null;let n=0;for(;r;){n++,i=r;let o=0;for(;o<s&&i;o++)i=i.nextZ;let a=s;for(;o>0||a>0&&i;){let s;0===o?(s=i,i=i.nextZ,a--):0!==a&&i?r.z<=i.z?(s=r,r=r.nextZ,o--):(s=i,i=i.nextZ,a--):(s=r,r=r.nextZ,o--),t?t.nextZ=s:e=s,s.prevZ=t,t=s}r=i}if(t.nextZ=null,s*=2,n<2)return e}}(e)}function ls(e,t,s){return(t.y-e.y)*(s.x-t.x)-(t.x-e.x)*(s.y-t.y)}function us(e,t,s,i){return!!(fs(e,t)&&fs(s,i)||fs(e,i)&&fs(s,t))||ls(e,t,s)>0!=ls(e,t,i)>0&&ls(s,i,e)>0!=ls(s,i,t)>0}function hs(e,t,s,i,r,n,o,a){return(r-o)*(t-a)-(e-o)*(n-a)>=0&&(e-o)*(i-a)-(s-o)*(t-a)>=0&&(s-o)*(n-a)-(r-o)*(i-a)>=0}function ds(e,t){return ls(e.prev,e,e.next)<0?ls(e,t,e.next)>=0&&ls(e,e.prev,t)>=0:ls(e,t,e.prev)<0||ls(e,e.next,t)<0}function ps(e,t,s,i,r){return(e=1431655765&((e=858993459&((e=252645135&((e=16711935&((e=32767*(e-s)*r)|e<<8))|e<<4))|e<<2))|e<<1))|(t=1431655765&((t=858993459&((t=252645135&((t=16711935&((t=32767*(t-i)*r)|t<<8))|t<<4))|t<<2))|t<<1))<<1}function fs(e,t){return e.x===t.x&&e.y===t.y}function _s(e,t){return e.x-t.x}function ms(e,t,s,i){let r=e;do{const n=r.prev,o=r.next.next;!fs(n,o)&&us(n,r,r.next,o)&&ds(n,o)&&ds(o,n)&&(t.push(n.index/s+i),t.push(r.index/s+i),t.push(o.index/s+i),ns(r),ns(r.next),r=e=o),r=r.next}while(r!==e);return r}function ys(e,t,s,i,r,n,o){let a=e;do{let e=a.next.next;for(;e!==a.prev;){if(a.index!==e.index&&gs(a,e)){let c=xs(a,e);return a=es(a,a.next),c=es(c,c.next),ts(a,t,s,i,r,n,o,0),void ts(c,t,s,i,r,n,o,0)}e=e.next}a=a.next}while(a!==e)}function gs(e,t){return e.next.index!==t.index&&e.prev.index!==t.index&&!function(e,t){let s=e;do{if(s.index!==e.index&&s.next.index!==e.index&&s.index!==t.index&&s.next.index!==t.index&&us(s,s.next,e,t))return!0;s=s.next}while(s!==e);return!1}(e,t)&&ds(e,t)&&ds(t,e)&&function(e,t){let s=e,i=!1;const r=(e.x+t.x)/2,n=(e.y+t.y)/2;do{s.y>n!=s.next.y>n&&s.next.y!==s.y&&r<(s.next.x-s.x)*(n-s.y)/(s.next.y-s.y)+s.x&&(i=!i),s=s.next}while(s!==e);return i}(e,t)}function xs(e,t){const s=ws.create(e.index,e.x,e.y),i=ws.create(t.index,t.x,t.y),r=e.next,n=t.prev;return e.next=t,t.prev=e,s.next=r,r.prev=s,i.next=s,s.prev=i,n.next=i,i.prev=n,i}class ws{constructor(){this.index=0,this.x=0,this.y=0,this.prev=null,this.next=null,this.z=null,this.prevZ=null,this.nextZ=null,this.steiner=!1}static create(e,t,s){const i=vs<bs.length?bs[vs++]:new ws;return i.index=e,i.x=t,i.y=s,i.prev=null,i.next=null,i.z=null,i.prevZ=null,i.nextZ=null,i.steiner=!1,i}}const bs=[];let vs=0;for(let e=0;e<8096;e++)bs.push(new ws);const Ss=new Qt.O3(0,0,0,1,0),Is=new Qt.O3(0,0,0,1,0);function Ts(e,t,s){let i=0;for(let r=1;r<s;r++){const s=e[2*(t+r-1)],n=e[2*(t+r-1)+1];i+=(e[2*(t+r)]-s)*(e[2*(t+r)+1]+n)}return i}function ks(e,t,s,i,r){let n=0;for(let o=s;o<i;o+=3){const s=2*(e[o]-r),i=2*(e[o+1]-r),a=2*(e[o+2]-r);n+=Math.abs((t[s]-t[a])*(t[i+1]-t[s+1])-(t[s]-t[i])*(t[a+1]-t[s+1]))}return n}function As(e,t){const{coords:s,lengths:i}=t,r=e;let n=0;for(let e=0;e<i.length;){let t=e,o=i[e],a=Ts(s,n,o);const c=[];for(;++t<i.length;){const e=i[t],r=Ts(s,n+o,e);if(!(r>0))break;a+=r,c.push(n+o),o+=e}const l=r.length;Kt(r,s,n,n+o,c,2,0);const u=ks(r,s,l,r.length,0),h=Math.abs(a);if(Math.abs((u-h)/Math.max(1e-7,h))>1e-5)return r.length=0,!1;e=t,n+=o}return!0}function Ms(e){const{coords:t,lengths:s}=e,{buffer:i}=(0,Ht.QT)(t,s);return i}function Cs(e,t){if(null==e)return null;if(!function(e,t,s){let i=0;for(let t=0;t<e.lengths.length;t++){const r=e.lengths[t];for(let t=0;t<r;t++){const r=e.coords[2*(t+i)],n=e.coords[2*(t+i)+1];if(r<-128||r>s||n<-128||n>s)return!0}i+=r}return!1}(e,0,p.CQ+128))return e;Ss.setPixelMargin(t),Ss.reset(3);const{stride:s,lengths:i,coords:r}=e;let n=0;for(const e of i){const t=n+e*s;for(Ss.moveTo(r[n],r[n+1]),n+=s;n<t;)Ss.lineTo(r[n],r[n+1]),n+=s;Ss.close()}const o=Ss.result(!1);if(!o)return null;const a=new Xt.A;for(const e of o){for(const{x:t,y:s}of e)a.coords.push(t,s);a.lengths.push(e.length)}return a}function Fs(e,t){Is.setPixelMargin(t);const s=Is,i=-t,r=p.CQ+t;let n=[],o=!1;if(!e.nextPath())return null;let a=e.pathLength(),c=!0;for(;c;){e.seekPathStart();const t=[];if(!e.pathSize)return null;s.reset(2),e.nextPoint();let l=e.x,u=e.y;if(o)s.moveTo(l,u);else{if(l<i||l>r||u<i||u>r){o=!0;continue}t.push({x:l,y:u})}let h=!1;for(;e.nextPoint();)if(l=e.x,u=e.y,o)s.lineTo(l,u);else{if(l<i||l>r||u<i||u>r){h=!0;break}t.push({x:l,y:u})}if(h)o=!0;else{if(o){const e=s.resultWithStarts();if(e)for(const t of e)n.push({...t,pathLength:a})}else n.push({line:t,start:0,pathLength:a});c=e.nextPath(),a=c?e.pathLength():0,o=!1}}return n=n.filter(e=>e.line.length>1),0===n.length?null:n}Ss.setExtent(p.CQ),Is.setExtent(p.CQ);var Es=s(23304);class Ps{constructor(){this.extrusionOffsetX=0,this.extrusionOffsetY=0,this.normalX=0,this.normalY=0,this.directionX=0,this.directionY=0,this.distance=0,this.pathLength=0,this.distanceOffset=0,this.lineLength=0}}const Rs={createComputedParams:e=>e,optionalAttributes:{zoomRange:{type:Ye.pe.SHORT,count:2,packPrecisionFactor:p.fq,pack:({scaleInfo:e},{tileInfo:t})=>Te(e,t)}},attributes:{id:{type:Ye.pe.UNSIGNED_BYTE,count:3,pack:"id"},pos:{type:Ye.pe.SHORT,count:2,pack:"position",packPrecisionFactor:10},bitset:{type:Ye.pe.UNSIGNED_BYTE,count:1},color:{type:Ye.pe.UNSIGNED_BYTE,count:4,normalized:!0,pack:({color:e})=>Me(e)},offset:{type:Ye.pe.BYTE,count:2,packPrecisionFactor:16,packTessellation:({extrusionOffsetX:e,extrusionOffsetY:t})=>[Pe(e,16),Pe(t,16)]},normal:{type:Ye.pe.BYTE,count:2,packPrecisionFactor:16,packTessellation:({normalX:e,normalY:t})=>[Pe(e,16),Pe(t,16)]},halfWidth:{type:Ye.pe.HALF_FLOAT,count:1,pack:({width:e})=>(0,u.Lz)(.5*e)},referenceHalfWidth:{type:Ye.pe.HALF_FLOAT,count:1,pack:({referenceWidth:e})=>(0,u.Lz)(.5*e)}}};class Os{constructor(){this.id=0,this.bitset=0,this.indexCount=0,this.vertexCount=0,this.vertexFrom=0,this.vertexBounds=0,this.pathLength=0,this.distanceOffset=0}}const zs=65535;class Ls extends He{constructor(e,t,s,i){super(e,t,s,i),this.vertexSpec=Rs,this._currentWrite=new Os,this._tessellationOptions={halfWidth:0,pixelCoordRatio:1,offset:0,wrapDistance:zs,textured:!1},this._tessParams=new Ps,this._initializeTessellator()}writeLineVertices(e,t,s){const i=this._getLines(t);null!=i&&this._writeVertices(e,s,i)}_initializeTessellator(){this._lineTessellator=new Zt.i(this._writeTesselatedVertex.bind(this),this._writeTriangle.bind(this),!0)}_write(e,t,s){const i=s??xe.z.fromFeatureSetReaderCIM(t);i&&this._writeGeometry(e,t,i)}_writeGeometry(e,t,s,i){e.recordStart(this.instanceId,this.attributeLayout,i),this.writeLineVertices(e,s,t),e.recordEnd()}_getLines(e){return Fs(e,(0,Es.Z0)(this.evaluatedMeshParams))}_writeVertices(e,t,s){const{_currentWrite:i,_tessellationOptions:r,evaluatedMeshParams:n}=this,{width:o,capType:a,joinType:c,miterLimit:l,hasSizeVV:h}=n,d=(0,u.Lz)(.5*o);r.halfWidth=d,r.capType=Ce(a),r.joinType=Fe(c),r.miterLimit=l;const f=!h;i.out=e,i.id=t.getDisplayId(),i.vertexCount=0,i.indexCount=0,i.vertexFrom=e.vertexCount(),i.vertexBounds=f&&d<p.Gh?0:1;for(const{line:e,start:t,pathLength:n}of s)r.initialDistance=t%zs,i.pathLength=n,i.distanceOffset=Math.floor(t/zs)*zs,this._lineTessellator.tessellate(e,r,f)}_writeTesselatedVertex(e,t,s,i,r,n,o,a,c,l,u){const{out:h,id:d,vertexBounds:p,pathLength:f,distanceOffset:_}=this._currentWrite;return this.hasEffects&&h.recordBounds(e,t,p,p),this._tessParams.extrusionOffsetX=o,this._tessParams.extrusionOffsetY=a,this._tessParams.normalX=c,this._tessParams.normalY=l,this._tessParams.directionX=r,this._tessParams.directionY=n,this._tessParams.distance=u,this._tessParams.pathLength=f,this._tessParams.distanceOffset=_,this._writeVertex(h,d,e,t,this._tessParams),this._currentWrite.vertexFrom+this._currentWrite.vertexCount++}_writeTriangle(e,t,s){const{out:i}=this._currentWrite;i.indexEnsureSize(3),i.indexWrite(e),i.indexWrite(t),i.indexWrite(s),this._currentWrite.indexCount+=3}}class Ds extends Ze{_write(e,t,s){const i=s??xe.z.fromFeatureSetReaderCIM(t);if(!i)return;const r=this.evaluatedMeshParams.sprite,{textureBinding:n}=r;e.recordStart(this.instanceId,this.attributeLayout,n);const o=t.getDisplayId();this._writePoly(e,o,i.asOptimized()),e.recordEnd()}}class Ns extends Ds{constructor(){super(...arguments),this.vertexSpec={createComputedParams:jt,attributes:{id:Pt,bitset:Rt,pos:Ot,offset:zt.fill,tlbr:Dt,animationPointerAndBaseSizeAndReferenceSize:Nt,sizing:qt},optionalAttributes:{zoomRange:It,value1Position2Value2:kt,lineLength:At,angle:Gt}}}_writePoly(e,t,s){const i=this._clip(s);if(!i)return;s=i;const r=[],n=e.vertexCount();let o;if(As(r,s)){if(0===r.length)return;o=0;for(const i of r){const r=s.coords[2*i],n=s.coords[2*i+1];this._writeVertex(e,t,r,n),o++}}else{const{coords:i,lengths:r}=s,n=(0,Ht.QT)(i,r);o=n.vertexCount;for(let s=0;s<n.buffer.length/2;s++){const i=n.buffer[2*s],r=n.buffer[2*s+1];this._writeVertex(e,t,i,r)}}if(o>0){e.indexEnsureSize(o);for(let t=0;t<o;t++)e.indexWrite(t+n)}}_clip(e){return Cs(e,this.hasEffects?256:8)}}class qs{constructor(){this.id=0,this.bitset=0,this.indexCount=0,this.vertexCount=0,this.vertexFrom=0,this.vertexBounds=0,this.pathLength=0}}class Bs extends Ds{constructor(){super(...arguments),this.vertexSpec={createComputedParams:jt,attributes:{id:Pt,bitset:Rt,pos:Ot,offset:zt.line,tlbr:Dt,animationPointerAndBaseSizeAndReferenceSize:Nt,sizing:qt,accumulatedDistance:Ct,normal:Et,segmentDirection:Ft},optionalAttributes:{zoomRange:It,value1Position2Value2:kt,lineLength:Mt,angle:Ut}},this._tessParams=new Ps,this._currentWrite=new qs,this._tessellationOptions={halfWidth:0,pixelCoordRatio:1,offset:0,wrapDistance:65535,textured:!1},this._lineLength=0,this._lineTessellator=new Zt.i((e,t,s,i,r,n,o,a,c,l,u)=>this._writeTesselatedVertex(e,t,s,i,r,n,o,a,c,l,u,this._lineLength),this._writeTriangle.bind(this),!1)}_writePoly(e,t,s){const i=Fs(xe.z.fromOptimized(s,"esriGeometryPolyline"),64);if(null==i)return;const{_currentWrite:r,_tessellationOptions:n}=this,{baseSize:o,capType:a,joinType:c,miterLimit:l}=this.evaluatedMeshParams,h=(0,u.Lz)(.5*o);n.halfWidth=h,n.capType=Ce(a||"Round"),n.joinType=Fe(c||"Round"),n.miterLimit=l||2,r.out=e,r.id=t,r.vertexCount=0,r.indexCount=0,r.vertexFrom=e.vertexCount(),r.vertexBounds=1;for(const{line:e,start:t,pathLength:s}of i){n.initialDistance=t%65535,r.pathLength=s,this._lineLength=0;for(let t=1;t<e.length;t++){const s=e[t].x-e[t-1].x,i=e[t].y-e[t-1].y;this._lineLength+=Math.sqrt(s*s+i*i)}this._lineTessellator.tessellate(e,n,!1)}}_writeTesselatedVertex(e,t,s,i,r,n,o,a,c,l,u,h){const{out:d,id:p,vertexBounds:f,pathLength:_}=this._currentWrite;return this.hasEffects&&d.recordBounds(e,t,f,f),this._tessParams.extrusionOffsetX=o,this._tessParams.extrusionOffsetY=a,this._tessParams.normalX=c,this._tessParams.normalY=l,this._tessParams.directionX=r,this._tessParams.directionY=n,this._tessParams.distance=u,this._tessParams.pathLength=_,this._tessParams.lineLength=h,this._writeVertex(d,p,e,t,this._tessParams),this._currentWrite.vertexFrom+this._currentWrite.vertexCount++}_writeTriangle(e,t,s){const{out:i}=this._currentWrite;i.indexEnsureSize(3),i.indexWrite(e),i.indexWrite(t),i.indexWrite(s),this._currentWrite.indexCount+=3}}class Gs extends He{async loadDependencies(){await Promise.all([super.loadDependencies(),(0,Ht.If)()])}_write(e,t,s){const i=s?.asOptimized()??t.readGeometryForDisplay(),r=this._clip(i);r&&(e.recordStart(this.instanceId,this.attributeLayout),this._writeGeometry(e,t,r),e.recordEnd())}_clip(e){return e?Cs(e,this.hasEffects?256:8):null}_writeGeometry(e,t,s){const i=function(e){const t=[];return e.maxLength>100||!As(t,e)?{indices:null,vertices:Ms(e)}:t.length?{indices:t,vertices:e.coords}:null}(s=s.justXY());if(!i||!i.vertices.length)return;const r=this.createTesselationParams(t);this._writeVertices(e,t,i,r)}_writeVertices(e,t,s,i){const r=t.getDisplayId(),n=e.vertexCount(),o=this.hasEffects,{vertices:a,indices:c}=s;let l=0;if(c)for(const t of c){const s=a[2*t],n=a[2*t+1];o&&e.recordBounds(s,n,0,0),this._writeVertex(e,r,s,n,i),l++}else for(let t=0;t<a.length;t+=2){const s=Math.round(a[t]),n=Math.round(a[t+1]);o&&e.recordBounds(s,n,0,0),this._writeVertex(e,r,s,n,i),l++}e.indexEnsureSize(l);for(let t=0;t<l;t++)e.indexWrite(t+n)}}const Us={createComputedParams:e=>e,optionalAttributes:{},attributes:{id:{type:Ye.pe.UNSIGNED_BYTE,count:3,pack:"id"},bitset:{type:Ye.pe.UNSIGNED_BYTE,count:1},pos:{type:Ye.pe.SHORT,count:2,pack:"position",packPrecisionFactor:10},inverseArea:{type:Ye.pe.FLOAT,count:1,packTessellation:({inverseArea:e})=>e}}};class js extends Gs{constructor(){super(...arguments),this.vertexSpec=Us}createTesselationParams(e){return{inverseArea:1/e.readGeometryArea()}}}const Ws={createComputedParams:e=>e,optionalAttributes:{zoomRange:{type:Ye.pe.SHORT,count:2,packPrecisionFactor:p.fq,pack:({scaleInfo:e},{tileInfo:t})=>Te(e,t)}},attributes:{id:{type:Ye.pe.UNSIGNED_BYTE,count:3,pack:"id"},bitset:{type:Ye.pe.UNSIGNED_BYTE,count:1},pos:{type:Ye.pe.SHORT,count:2,pack:"position",packPrecisionFactor:10},color:{type:Ye.pe.UNSIGNED_BYTE,count:4,normalized:!0,pack:({color:e})=>Me(e)}}};class Vs extends Gs{constructor(){super(...arguments),this.vertexSpec=Ws}createTesselationParams(e){return null}}const Ys={createComputedParams:e=>e,optionalAttributes:Ws.optionalAttributes,attributes:{...Ws.attributes,tlbr:{count:4,type:Ye.pe.UNSIGNED_SHORT,pack:({sprite:e})=>{const{rect:t,width:s,height:i}=e,r=t.x+p.hM,n=t.y+p.hM;return[r,n,r+s,n+i]}},inverseRasterizationScale:{count:1,type:Ye.pe.BYTE,packPrecisionFactor:16,pack:({sprite:e})=>1/e.rasterizationScale}}};class $s extends Vs{constructor(){super(...arguments),this.vertexSpec=Ys}_write(e,t,s){const i=s?.asOptimized()??t.readGeometryForDisplay(),r=this._clip(i);if(!r)return;const n=this.evaluatedMeshParams.sprite?.textureBinding;e.recordStart(this.instanceId,this.attributeLayout,n),this._writeGeometry(e,t,r),e.recordEnd()}}function Hs(e){const{sprite:t,aspectRatio:s,scaleProportionally:i}=e,r=(0,u.Lz)(e.height),n=r>0?r:t.height;let o=r*s;return o<=0?o=t.width:i&&(o*=t.width/t.height),{width:o,height:n}}function Zs(e){const{applyRandomOffset:t,sampleAlphaOnly:s}=e;return Ae([[2,t],[4,s]])}const Qs={createComputedParams:e=>e,optionalAttributes:Ys.optionalAttributes,attributes:{...Ys.attributes,bitset:{count:1,type:Ye.pe.UNSIGNED_BYTE,pack:Zs},width:{count:1,type:Ye.pe.HALF_FLOAT,pack:e=>Hs(e).width},height:{count:1,type:Ye.pe.HALF_FLOAT,pack:e=>Hs(e).height},offset:{count:2,type:Ye.pe.HALF_FLOAT,pack:({offsetX:e,offsetY:t})=>[(0,u.Lz)(e),-(0,u.Lz)(t)]},scale:{count:2,type:Ye.pe.UNSIGNED_BYTE,packPrecisionFactor:16,pack:({scaleX:e,scaleY:t})=>[e,t]},angle:{count:1,type:Ye.pe.UNSIGNED_BYTE,pack:({angle:e})=>(0,Qe.wV)(e)}}};class Xs extends $s{constructor(){super(...arguments),this.vertexSpec=Qs}}const Ks={createComputedParams:e=>e,optionalAttributes:Rs.optionalAttributes,attributes:{...Rs.attributes,bitset:{type:Ye.pe.UNSIGNED_BYTE,count:1,pack:e=>0},color:{type:Ye.pe.UNSIGNED_BYTE,count:4,normalized:!0,pack:({color:e})=>Me(e)}}},Js={createComputedParams:e=>e,optionalAttributes:Rs.optionalAttributes,attributes:{...Rs.attributes,bitset:{type:Ye.pe.UNSIGNED_BYTE,count:1,pack:e=>Ae([[0,!0],[1,e.outlineUsesColorVV]])},color:{type:Ye.pe.UNSIGNED_BYTE,count:4,normalized:!0,pack:({outlineColor:e})=>Me(e)}}};class ei extends Ls{constructor(){super(...arguments),this.vertexSpec=Js}}class ti extends Vs{constructor(e,t,s,i){super(e,t,s,i),this.vertexSpec=Ks,this._lineMeshWriter=this._createOutlineWriter(e,t,s,i)}_createOutlineWriter(e,t,s,i){return new ei(e,t,s,i)}_write(e,t){const s=this.evaluatedMeshParams.effects,i=this.evaluatedMeshParams.outlineEffects;if(s?.length||i?.length){if(s?.length){const i=this.getEffectCursor(e,t,s);if(i){let s;for(;s=i?.next();)s.invertY(),this._writeFill(e,t,s)}}else this._writeFill(e,t);if(i?.length){const s=this.getEffectCursor(e,t,i);if(s){let i;for(;i=s?.next();)i.invertY(),this._writeOutline(e,t,i)}}else this._writeOutline(e,t)}else this._writeSimpleOutlineFill(e,t)}_writeSimpleOutlineFill(e,t){const s=t.readGeometryForDisplay(),i=this._clip(s);i&&(this._writeGeometry(e,t,i),this._lineMeshWriter.writeLineVertices(e,xe.z.fromOptimizedCIM(i,"esriGeometryPolyline"),t))}_writeFill(e,t,s){const i=s?.asOptimized()??t.readGeometryForDisplay(),r=this._clip(i);r&&this._writeGeometry(e,t,r)}_writeOutline(e,t,s){const i=s?.asOptimized()??t.readGeometryForDisplay(),r=this._clip(i);r&&this._lineMeshWriter.writeLineVertices(e,xe.z.fromOptimizedCIM(r,"esriGeometryPolyline"),t)}_clip(e){return e?Cs(e,(0,Es.Z0)(this.evaluatedMeshParams)):null}get effectInfos(){return[...this._evaluator.inputMeshParams.effects?.effectInfos??[],...this._evaluator.inputMeshParams.outlineEffects?.effectInfos??[]]}write(e,t,s,i,r){this.ensurePacked(t,s,i),e.recordStart(this.instanceId,this.attributeLayout),this._write(e,s),e.recordEnd()}ensurePacked(e,t,s){super.ensurePacked(e,t,s),this._lineMeshWriter.ensurePacked(e,t,s)}enqueueRequest(e,t,s){super.enqueueRequest(e,t,s),this._lineMeshWriter.enqueueRequest(e,t,s)}async loadDependencies(){await Promise.all([super.loadDependencies(),this._lineMeshWriter.loadDependencies()])}get hasEffects(){return!!this.evaluatedMeshParams.outlineEffects}}const si=Qs,ii=Js,ri={createComputedParams:e=>e,optionalAttributes:si.optionalAttributes,attributes:{...si.attributes,bitset:{type:Ye.pe.UNSIGNED_BYTE,count:1,pack:e=>Zs(e)},aux1:{count:1,type:Ye.pe.HALF_FLOAT,pack:e=>Hs(e).width},aux2:{count:1,type:Ye.pe.HALF_FLOAT,pack:e=>Hs(e).height},aux3:{count:2,type:Ye.pe.HALF_FLOAT,pack:({offsetX:e,offsetY:t})=>[(0,u.Lz)(e),(0,u.Lz)(t)]},aux4:{count:2,type:Ye.pe.UNSIGNED_BYTE,pack:({scaleX:e,scaleY:t})=>[16*e,16*t]}}},ni={createComputedParams:e=>e,optionalAttributes:si.optionalAttributes,attributes:{...si.attributes,color:ii.attributes.color,bitset:{type:Ye.pe.UNSIGNED_BYTE,count:1,pack:e=>Ae([[0,!0]])},aux1:{count:1,type:Ye.pe.HALF_FLOAT,pack:e=>(0,u.Lz)(.5*e.width)},aux2:{count:1,type:Ye.pe.HALF_FLOAT,pack:e=>(0,u.Lz)(.5*e.referenceWidth)},aux3:{count:2,type:Ye.pe.HALF_FLOAT,packTessellation:({extrusionOffsetX:e,extrusionOffsetY:t})=>[e,t]},aux4:{count:2,type:Ye.pe.UNSIGNED_BYTE,packTessellation:({normalX:e,normalY:t})=>[16*e+128,16*t+128]}}};class oi extends ei{constructor(){super(...arguments),this.vertexSpec=ni}}class ai extends ti{constructor(){super(...arguments),this.vertexSpec=ri}_createOutlineWriter(e,t,s,i){return new oi(e,t,s,i)}write(e,t,s,i,r){this.ensurePacked(t,s,i);const n=this.evaluatedMeshParams.sprite?.textureBinding;e.recordStart(this.instanceId,this.attributeLayout,n),this._write(e,s),e.recordEnd()}ensurePacked(e,t,s){super.ensurePacked(e,t,s),this._lineMeshWriter.ensurePacked(e,t,s)}enqueueRequest(e,t,s){super.enqueueRequest(e,t,s),this._lineMeshWriter.enqueueRequest(e,t,s)}async loadDependencies(){await Promise.all([super.loadDependencies(),this._lineMeshWriter.loadDependencies()])}}var ci=s(13337);var li=s(34727);class ui{constructor(e,t){this._size=e,this._sizeUnits=t,this._relativeSize=null}get relativeSize(){return this._relativeSize??=this.calculateRelativeSize(),this._relativeSize}calculateRelativeSize(){if(this._sizeUnits===ci.h.Relative){const e=Math.min(this._size/100,1);return[e,e]}return this.calculateRelativeSizeFromAbsolute()}}class hi extends ui{constructor(e,t,s,i){super(t,s),this.rotationMatrix00=1,this.rotationMatrix01=0,this.rotationMatrix10=0,this.rotationMatrix11=1,this.bounds={xmin:1/0,ymin:1/0,xmax:-1/0,ymax:-1/0},this.rotationMatrix00=Math.cos(i),this.rotationMatrix01=-Math.sin(i),this.rotationMatrix10=-this.rotationMatrix01,this.rotationMatrix11=this.rotationMatrix00;const{bounds:r,rotationMatrix00:n,rotationMatrix01:o,rotationMatrix10:a,rotationMatrix11:c}=this;e.forEachVertex((e,t)=>{const s=e*n+t*o,i=e*a+t*c;r.xmin=Math.min(r.xmin,s),r.ymin=Math.min(r.ymin,i),r.xmax=Math.max(r.xmax,s),r.ymax=Math.max(r.ymax,i)}),this.center=[(r.xmin+r.xmax)/2,(r.ymin+r.ymax)/2]}}class di extends hi{constructor(e,t,s,i){super(e,t,s,i),this.method="linear"}getRelativePosition(e,t){const{rotationMatrix00:s,rotationMatrix01:i,bounds:r}=this,{xmin:n,xmax:o}=r;return[(e*s+t*i-n)/(o-n),0]}calculateRelativeSizeFromAbsolute(){const{_size:e,bounds:t}=this,{xmin:s,xmax:i}=t;return[(0,u.Lz)(e)/(i-s),0]}}class pi extends hi{constructor(e,t,s,i){super(e,t,s,i),this.method="rectangular"}getRelativePosition(e,t){const{bounds:s,center:i,rotationMatrix00:r,rotationMatrix01:n,rotationMatrix10:o,rotationMatrix11:a}=this,c=e*o+t*a,l=e*r+t*n-i[0],u=c-i[1];return[l*(2/(s.xmax-s.xmin)),-u*(2/(s.ymax-s.ymin))]}calculateRelativeSizeFromAbsolute(){const{_size:e,bounds:t}=this,{xmin:s,ymin:i,xmax:r,ymax:n}=t;return[(0,u.Lz)(2*e)/(r-s),(0,u.Lz)(2*e)/(n-i)]}}class fi extends hi{constructor(e,t,s){super(e,t,s,0),this.method="circular";const{xmin:i,xmax:r,ymin:n,ymax:o}=this.bounds,a=r-i,c=o-n;this.radius=Math.sqrt(a*a+c*c)/2}getRelativePosition(e,t){const{center:s,radius:i}=this;return[(e-s[0])/i,-(t-s[1])/i]}calculateRelativeSizeFromAbsolute(){const{_size:e}=this;return[(0,u.Lz)(e)/this.radius,0]}}function _i(e,t){if(null==e)return null;const s=(0,li.kU)(t.angle),i=t.gradientSize,r=t.gradientSizeUnits;switch(t.gradientMethod.toLowerCase()){case"linear":return new di(e,i,r,s);case"rectangular":return new pi(e,i,r,s);case"circular":return new fi(e,i,r);default:return Ie.A.getLogger("esri.views.2d.engine.webgl.shaderGraph.techniques.fill.GradientSizeHelper").errorOnce(`Gradient fill method "${t.gradientMethod}" currently unsupported.`),null}}const mi={createComputedParams:e=>e,optionalAttributes:Ws.optionalAttributes,attributes:{...Ws.attributes,bitset:{type:Ye.pe.UNSIGNED_BYTE,count:1,pack:({gradientSizeUnits:e,gradientType:t})=>{let s=0;return e===ci.h.Absolute&&(s|=ke(0)),"discrete"===t.toLowerCase()&&(s|=ke(1)),s}},tlbr:{count:4,type:Ye.pe.UNSIGNED_SHORT,pack:({sprite:e})=>{const{rect:t,width:s,height:i}=e,r=t.x+p.hM+p.MZ,n=t.y+p.hM;return[r,n,r+s-2*p.MZ,n+i]}},relativePosition:{count:2,type:Ye.pe.HALF_FLOAT,packTessellation:({gradientStats:e},t,s,i)=>e?.getRelativePosition(s,i)??[0,0]},relativeGradientSize:{count:2,type:Ye.pe.HALF_FLOAT,packTessellation:({gradientStats:e})=>e?.relativeSize??[1,1]},gradientMethod:{count:1,type:Ye.pe.UNSIGNED_BYTE,pack:({gradientMethod:e})=>{switch(e.toLowerCase()){case"rectangular":return 1;case"circular":return 2;default:return 0}}}}};class yi extends Gs{constructor(){super(...arguments),this.vertexSpec=mi}get _preventEffectClipping(){return!0}createTesselationParams(e){return{gradientStats:_i(this._unclippedGeometry,this.evaluatedMeshParams)}}_write(e,t,s){const i=s?.asOptimized()??t.readGeometryForDisplay();this._unclippedGeometry=i;const r=this._clip(i);if(!r)return void(this._unclippedGeometry=null);const n=this.evaluatedMeshParams.sprite?.textureBinding;e.recordStart(this.instanceId,this.attributeLayout,n),this._writeGeometry(e,t,r),this._unclippedGeometry=null,e.recordEnd()}}const gi={optionalAttributes:Ys.optionalAttributes,createComputedParams:e=>e,attributes:{...Ys.attributes,...Ks.attributes}},xi={optionalAttributes:Ys.optionalAttributes,createComputedParams:e=>e,attributes:{...Ys.attributes,...Js.attributes}};class wi extends ei{constructor(){super(...arguments),this.vertexSpec=xi}}class bi extends ti{constructor(){super(...arguments),this.vertexSpec=gi}_createOutlineWriter(e,t,s,i){return new wi(e,t,s,i)}write(e,t,s,i,r){this.ensurePacked(t,s,i);const n=this.evaluatedMeshParams.sprite?.textureBinding;e.recordStart(this.instanceId,this.attributeLayout,n),this._write(e,s),e.recordEnd()}ensurePacked(e,t,s){super.ensurePacked(e,t,s),this._lineMeshWriter.ensurePacked(e,t,s)}enqueueRequest(e,t,s){super.enqueueRequest(e,t,s),this._lineMeshWriter.enqueueRequest(e,t,s)}async loadDependencies(){await Promise.all([super.loadDependencies(),this._lineMeshWriter.loadDependencies()])}}const vi={createComputedParams:e=>e,optionalAttributes:{},attributes:{pos:{type:Ye.pe.SHORT,count:2,pack:"position",packPrecisionFactor:10},id:{type:Ye.pe.UNSIGNED_BYTE,count:3,pack:"id"},bitset:{type:Ye.pe.UNSIGNED_BYTE,count:1},offset:{type:Ye.pe.BYTE,count:2,packAlternating:{count:4,pack:()=>[[-1,-1],[1,-1],[-1,1],[1,1]]}}}};class Si extends He{constructor(){super(...arguments),this.vertexSpec=vi}_write(e,t){e.recordStart(this.instanceId,this.attributeLayout);const s=t.getDisplayId();if("esriGeometryPoint"===t.geometryType){const i=t.readXForDisplay(),r=t.readYForDisplay();this._writeQuad(e,s,i,r)}else if("esriGeometryMultipoint"===t.geometryType){const i=t.readGeometryForDisplay();i?.forEachVertex((t,i)=>{t>=0&&t<=512&&i>=0&&i<=512&&this._writeQuad(e,s,t,i)})}e.recordEnd()}_writeQuad(e,t,s,i){const r=e.vertexCount();this._writeVertex(e,t,s,i),e.indexWrite(r+0),e.indexWrite(r+1),e.indexWrite(r+2),e.indexWrite(r+1),e.indexWrite(r+3),e.indexWrite(r+2)}}var Ii=s(16905),Ti=s(85560),ki=s(88340),Ai=s(48163),Mi=s(87992),Ci=s(32011),Fi=s(90708),Ei=s(93397),Pi=s(15660);class Ri{constructor(e,t,s,i,r,n,o,a,c,l,u,h=[],d=0,p=0){this.displayId=e,this.labelClassId=t,this.labelIdHash=s,this.hash=i,this.anchorX=r,this.anchorY=n,this.directionX=o,this.directionY=a,this.maxScale=c,this.minScale=l,this.referenceBounds=u,this.bounds=h,this.recordStart=d,this.recordCount=p,this.priority=0,this._colliders=null,this.uniqueSymbol=null,this.selectedForRendering=!1}get xTile(){return this.anchorX}get yTile(){return this.anchorY}colliders(e){if(!this._colliders){const t=e.attributeView,s=p.C2;let i=this.referenceBounds?.size??0;const r=e.labelingCollisionInfos[0].vvEvaluators[0];if(null!=r){const e=r(t.getVisualVariableData(this.displayId,0));i=isNaN(e)||null==e||e===1/0?i:e}const n=this.minScale?e.tilingScheme.scaleToZoom(this.minScale):0,o=this.maxScale?e.tilingScheme.scaleToZoom(this.maxScale):25,a=this.directionX*(s+i/2),c=this.directionY*(s+i/2);this._colliders=this.bounds.map(e=>({labelId:this.labelIdHash,xTile:this.anchorX,yTile:this.anchorY,dxPixels:e.x-e.halfWidth+a,dyPixels:e.y-e.halfHeight+c,hard:!0,partIndex:1,width:e.width+2,height:e.height+2,angle:0,xScreen:0,yScreen:0,dxScreen:0,dyScreen:0,enabled:!0,minLod:n,maxLod:o}))}return this._colliders}get id(){return this.displayId}serialize(e){e.push(this.displayId),e.push(this.labelClassId),e.push(this.labelIdHash),e.push(this.hash),e.push(this.recordStart),e.push(this.recordCount),e.writeF32(this.anchorX),e.writeF32(this.anchorY),e.writeF32(this.directionX),e.writeF32(this.directionY),e.writeF32(this.maxScale),e.writeF32(this.minScale),this.referenceBounds?(e.writeF32(this.referenceBounds.size),e.writeF32(this.referenceBounds.offsetX),e.writeF32(this.referenceBounds.offsetY)):(e.writeF32(0),e.writeF32(0),e.writeF32(0)),H(e,this.bounds)}static deserialize(e){const t=e.readInt32(),s=e.readInt32(),i=e.readInt32(),r=e.readInt32(),n=e.readInt32(),o=e.readInt32(),a=e.readF32(),c=e.readF32(),l=e.readF32(),u=e.readF32(),h=e.readF32(),d=e.readF32(),p=e.readF32(),f=e.readF32(),_=e.readF32(),m=Z(e,Pi.A)??[];return new Ri(t,s,i,r,a,c,l,u,h,d,{size:p,offsetX:f,offsetY:_},m,n,o)}}function Oi(e,t,s){return e[0]=t[0]-s[0],e[1]=t[1]-s[1],e}function zi(e,t){return Math.sqrt(e*e+t*t)}function Li(e){const t=zi(e[0],e[1]);e[0]/=t,e[1]/=t}function Di(e,t){return zi(e[0]-t[0],e[1]-t[1])}function Ni(e){return e.length-1}function qi(e,t,s=1){let[i,r]=function(e,t){return e[t+1]}(e,t);return[i,r]=[Math.round(i),Math.round(r)],Math.sqrt(i*i+r*r)*s}class Bi{constructor(e,t,s,i,r){this._segments=e,this._index=t,this._distance=s,this._xStart=i,this._yStart=r,this._done=!1}static create(e){return new Bi(e,0,0,e[0][0],e[0][1])}clone(){return new Bi(this._segments,this._index,this._distance,this.xStart,this.yStart)}equals(e){return this._index===e._index||e._index===this._index-1&&(0===this._distance||1===e._distance)||e._index===this._index+1&&(1===this._distance||0===e._distance)}leq(e){return this._index<e._index||this._index===e._index&&this._distance<=e._distance}geq(e){return this._index>e._index||this._index===e._index&&this._distance>=e._distance}get _segment(){return this._segments[this._index+1]}get angle(){const e=this.dy,t=(0*e+-1*-this.dx)/(1*this.length);let s=Math.acos(t);return e>0&&(s=2*Math.PI-s),s}get xStart(){return this._xStart}get yStart(){return this._yStart}get x(){return this.xStart+this.distance*this.dx}get y(){return this.yStart+this.distance*this.dy}get dx(){return this._segment[0]}get dy(){return this._segment[1]}get xMidpoint(){return this.xStart+.5*this.dx}get yMidpoint(){return this.yStart+.5*this.dy}get xEnd(){return this.xStart+this.dx}get yEnd(){return this.yStart+this.dy}get length(){const{dx:e,dy:t}=this;return Math.sqrt(e*e+t*t)}get remainingLength(){return this.length*(1-this._distance)}get backwardLength(){return this.length*this._distance}get distance(){return this._distance}get done(){return this._done}hasPrev(){return this._index-1>=0}hasNext(){return this._index+1<Ni(this._segments)}next(){return this.hasNext()?(this._xStart+=this.dx,this._yStart+=this.dy,this._distance=0,this._index+=1,this):null}prev(){return this.hasPrev()?(this._index-=1,this._xStart-=this.dx,this._yStart-=this.dy,this._distance=1,this):(this._done=!0,null)}_seekBackwards(e,t){const s=this.backwardLength;if(e<=s)return this._distance=(s-e)/this.length,this;let i=this.backwardLength;for(;this.prev();){if(i+this.length>e)return this._seekBackwards(e-i);i+=this.length}return this._distance=0,t?this:null}seek(e,t=!1){if(e<0)return this._seekBackwards(Math.abs(e),t);if(e<=this.remainingLength)return this._distance=(this.backwardLength+e)/this.length,this;let s=this.remainingLength;for(;this.next();){if(s+this.length>e)return this.seek(e-s,t);s+=this.length}return this._distance=1,t?this:null}}function Gi(e,t,s,i=!0){const r=function(e){let t=0;for(let s=0;s<Ni(e);s++)t+=qi(e,s);return t}(e),n=Bi.create(e),o=r/2;if(!i)return n.seek(o),void(n.x<p.CQ&&n.y<p.CQ&&n.x>=0&&n.y>=0&&s(n.clone(),0,o+0*t,r));const a=Math.max((r-t)/2,0),c=Math.floor(a/t),l=o-c*t;n.seek(l);for(let e=-c;e<=c;e++)n.x<p.CQ&&n.y<p.CQ&&n.x>=0&&n.y>=0&&s(n.clone(),e,o+e*t,r),n.seek(t)}function Ui(e,t){const s=t;for(let t=0;t<e.length;t++){let i=e[t];ji(i,s);const r=[];r.push(i[0]);for(let e=1;e<i.length;e++){const[t,s]=i[e-1],[n,o]=i[e],a=n-t,c=o-s;r.push([a,c])}e[t]=r,i=r}return e}function ji(e,t){const s=1e-6;if(t<=0)return;const i=e.length;if(i<3)return;const r=[];let n=0;r.push(0);for(let t=1;t<i;t++)n+=Di(e[t],e[t-1]),r.push(n);t=Math.min(t,.2*n);const o=[];o.push(e[0][0]),o.push(e[0][1]);const a=e[i-1][0],c=e[i-1][1],l=Oi([0,0],e[0],e[1]);Li(l),e[0][0]+=t*l[0],e[0][1]+=t*l[1],Oi(l,e[i-1],e[i-2]),Li(l),e[i-1][0]+=t*l[0],e[i-1][1]+=t*l[1];for(let e=1;e<i;e++)r[e]+=t;r[i-1]+=t;const u=.5*t;for(let n=1;n<i-1;n++){let a=0,c=0,l=0;for(let i=n-1;i>=0&&!(r[i+1]<r[n]-u);i--){const o=u+r[i+1]-r[n],h=r[i+1]-r[i],d=r[n]-r[i]<u?1:o/h;if(Math.abs(d)<s)break;const p=d*d,f=d*o-.5*p*h,_=d*h/t,m=e[i+1],y=e[i][0]-m[0],g=e[i][1]-m[1];a+=_/f*(m[0]*d*o+.5*p*(o*y-h*m[0])-p*d*h*y/3),c+=_/f*(m[1]*d*o+.5*p*(o*g-h*m[1])-p*d*h*g/3),l+=_}for(let o=n+1;o<i&&!(r[o-1]>r[n]+u);o++){const i=u-r[o-1]+r[n],h=r[o]-r[o-1],d=r[o]-r[n]<u?1:i/h;if(Math.abs(d)<s)break;const p=d*d,f=d*i-.5*p*h,_=d*h/t,m=e[o-1],y=e[o][0]-m[0],g=e[o][1]-m[1];a+=_/f*(m[0]*d*i+.5*p*(i*y-h*m[0])-p*d*h*y/3),c+=_/f*(m[1]*d*i+.5*p*(i*g-h*m[1])-p*d*h*g/3),l+=_}o.push(a/l),o.push(c/l)}o.push(a),o.push(c);for(let t=0,s=0;t<i;t++)e[t][0]=o[s++],e[t][1]=o[s++]}var Wi=s(63933),Vi=s(75434);class Yi{constructor(e){const{offsetX:t,offsetY:s,postAngle:i,fontSize:r,haloSize:n,outlineSize:o,scaleFactor:a,transforms:c}=e;if(this.offsetX=t,this.offsetY=s,this.postAngle=i,this.fontSize=Math.min(r,96),this.haloSize=n??0,this.outlineSize=o??0,this.transforms=c,c&&c.infos.length>1){const e=(0,Ei.zb)(r,i,!1,t,s,c,!1);this.fontSize=Math.min(e.size,96);const n=e.size/r;this.haloSize*=n,this.outlineSize*=n,this.postAngle=e.rotation,this.offsetX=e.offsetX,this.offsetY=e.offsetY}a&&(this.fontSize*=a,this.offsetX*=a,this.offsetY*=a)}}const $i=28,Hi=[4,4],Zi=[16,4],Qi={topLeft:Zi,topRight:Zi,bottomLeft:Zi,bottomRight:Zi},Xi=[4,2],Ki=[4,6],Ji={topLeft:Xi,topRight:Xi,bottomLeft:Ki,bottomRight:Ki},er={topLeft:Xi,topRight:Ki,bottomLeft:Xi,bottomRight:Ki},tr={topLeft:Ki,topRight:Ki,bottomLeft:Hi,bottomRight:Hi},sr={topLeft:Hi,topRight:Hi,bottomLeft:Ki,bottomRight:Ki},ir={topLeft:Ki,topRight:Hi,bottomLeft:Ki,bottomRight:Hi},rr={topLeft:Hi,topRight:Ki,bottomLeft:Hi,bottomRight:Ki},nr={createComputedParams:e=>e,optionalAttributes:{zoomRange:{type:Ye.pe.UNSIGNED_SHORT,count:2,packPrecisionFactor:p.fq,packTessellation:({minZoom:e,maxZoom:t})=>[e||0,t||$i]},clipAngle:{type:Ye.pe.UNSIGNED_BYTE,count:1,packTessellation:({clipAngle:e})=>ar(e||0)},referenceSymbol:{type:Ye.pe.BYTE,count:4,packTessellation:(e,t)=>{const s=e.isLineLabel||!e.referenceBounds,i=(0,Wi.iT)(s?"center":t.horizontalAlignment),r=(0,Wi.Dy)(s?"middle":t.verticalAlignment),{offsetX:n,offsetY:o,size:a}=s?{offsetX:0,offsetY:0,size:0}:e.referenceBounds;return[(0,u.Lz)(n),-(0,u.Lz)(o),Math.round((0,u.Lz)(a)),i+1<<2|r+1]}},visibility:{type:Ye.pe.FLOAT,count:1,otherSource:!0}},attributes:{pos:{type:Ye.pe.SHORT,count:2,pack:"position",packPrecisionFactor:10},id:{type:Ye.pe.UNSIGNED_BYTE,count:3,pack:"id"},bitset:{type:Ye.pe.UNSIGNED_BYTE,count:1,packTessellation:({isBackground:e,mapAligned:t})=>Ae([[0,e],[3,!!t]])},offset:{type:Ye.pe.SHORT,count:2,packPrecisionFactor:8,packAlternating:{count:4,packTessellation:({offsets:e})=>{const{bottomLeft:t,bottomRight:s,topLeft:i,topRight:r}=e;return[i,r,t,s]}}},textureUV:{type:Ye.pe.UNSIGNED_SHORT,count:2,packAlternating:{count:4,packTessellation:({texcoords:e})=>{const{bottomLeft:t,bottomRight:s,topLeft:i,topRight:r}=e;return[i,r,t,s]}}},color:{type:Ye.pe.UNSIGNED_BYTE,count:4,normalized:!0,packTessellation:({color:e})=>e},fontAndReferenceSize:{type:Ye.pe.UNSIGNED_SHORT,count:4,packPrecisionFactor:4,packTessellation:({fontSize:e,sdfSize:t,sdfRadius:s},{referenceSize:i})=>[Math.round((0,u.Lz)(e)),Math.round((0,u.Lz)(i??e)),t,s]},outlineColor:{type:Ye.pe.UNSIGNED_BYTE,count:4,normalized:!0,pack:({outlineColor:e})=>Me(e)},haloColor:{type:Ye.pe.UNSIGNED_BYTE,count:4,normalized:!0,pack:({haloColor:e})=>Me(e)},outlineAndHaloSize:{type:Ye.pe.UNSIGNED_SHORT,count:2,packPrecisionFactor:4,packTessellation:({outlineSize:e,haloSize:t})=>[Math.round((0,u.Lz)(e)),Math.round((0,u.Lz)(t))]}}};class or extends He{constructor(){super(...arguments),this.vertexSpec=nr,this._textMeshParamsPropsInitialized=!1}ensurePacked(e,t,s){super.ensurePacked(e,t,s),this._textMeshParamsPropsInitialized&&!this._evaluator.hasDynamicProperties||(this._textMeshTransformProps=new Yi(this.evaluatedMeshParams),this._textMeshParamsPropsInitialized=!0)}_write(e,t,s){const i=this._getShaping();if(!i)return;const r=1===this.evaluatedMeshParams.alignment,n=t.getDisplayId();if(null!=this.evaluatedMeshParams.placement)return this._writePlacedTextMarkers(e,t,i,s);if(s?.nextPath())return s.nextPoint(),this._writeGlyphs(e,n,s.x,s.y,i,0,void 0,{mapAligned:r});if("esriGeometryPolygon"===t.geometryType){const s=t.readCentroidForDisplay();if(!s)return;const[o,a]=s.coords;return this._writeGlyphs(e,n,o,a,i,0,void 0,{mapAligned:r})}if("esriGeometryMultipoint"===t.geometryType){const s=t.readGeometryForDisplay();return void s?.forEachVertex((t,s)=>this._writeGlyphs(e,n,t,s,i,0,void 0,{mapAligned:r}))}const o=t.readXForDisplay(),a=t.readYForDisplay();return this._writeGlyphs(e,n,o,a,i,0,void 0,{mapAligned:r})}_writePlacedTextMarkers(e,t,s,i){const r=i??xe.z.fromFeatureSetReaderCIM(t);if(!r)return;const n=ve.getPlacement(r,-1,this.evaluatedMeshParams.placement,(0,u.Lz)(1),e.id);if(!n)return;const o=t.getDisplayId();let a=n.next();for(;null!=a;){const t=a.tx,i=-a.ty,r=-a.getAngle();this._writeGlyphs(e,o,t,i,s,r,void 0,{mapAligned:1===this.evaluatedMeshParams.alignment}),a=n.next()}}_getShaping(e){const t=this._textMeshTransformProps,s=this.evaluatedMeshParams;if(!s.glyphs?.glyphs.length)return null;const i=(0,u.Lz)(t.fontSize),r=(0,u.Lz)(t.offsetX),n=(0,u.Lz)(t.offsetY),o=s.glyphs.sdfSize,a=(0,li.qE)((0,u.Lz)(s.lineWidth),p.GR,p.cp),c=o/24*p.DY*(0,li.qE)(s.lineHeightRatio,.25,4);return(0,Vi.Tl)(s.glyphs,{scale:i/o,angle:t.postAngle,xOffset:r,yOffset:n,horizontalAlignment:s.horizontalAlignment,verticalAlignment:e||s.verticalAlignment,maxLineWidth:a,lineHeight:c,decoration:s.decoration,borderLineSizePx:(0,u.Lz)(s.boxBorderLineSize),hasBackground:!!s.boxBackgroundColor,useCIMAngleBehavior:s.useCIMAngleBehavior})}_writeGlyphs(e,t,s,i,r,n,o,a,c=!0){const l=this.evaluatedMeshParams,h=this._textMeshTransformProps,d=(0,u.Lz)(h.fontSize),p=h.haloSize,f=h.outlineSize,_=(0,u.Lz)(h.offsetX),m=(0,u.Lz)(h.offsetY),{sdfSize:y,sdfRadius:g}=l.glyphs,[x,w]=Te(l.scaleInfo,this.getTileInfo());0!==n&&r.setRotation(n);const b=r.bounds,v=s+b.x+_,S=i+b.y-m,I=2*(l.minPixelBuffer?l.minPixelBuffer/d:1),T=Math.max(b.width,b.height)*I;r.textBox&&(e.recordStart(this.instanceId,this.attributeLayout,r.glyphs[0].textureBinding),c&&e.recordBounds(v,S,T,T),this._writeTextBox(e,t,s,i,r.textBox,o,a),e.recordEnd());for(const n of r.glyphs){e.recordStart(this.instanceId,this.attributeLayout,n.textureBinding),c&&e.recordBounds(v,S,T,T);const{texcoords:r,offsets:u}=n;this._writeQuad(e,t,s,i,{texcoords:r,offsets:u,fontSize:d,haloSize:p,outlineSize:f,sdfSize:y,sdfRadius:g,color:Me(l.color),isBackground:!1,referenceBounds:o,minZoom:x,maxZoom:w,...a}),e.recordEnd()}0!==n&&r.setRotation(-n)}_writeTextBox(e,t,s,i,r,n,o){const a=this.evaluatedMeshParams,{fontSize:c,haloSize:l,outlineSize:u}=this._textMeshTransformProps,{boxBackgroundColor:h,boxBorderLineColor:d,boxBorderLineSize:p}=a,{sdfSize:f,sdfRadius:_}=a.glyphs,m=!!d&&p>0,y={isBackground:!0,fontSize:c,haloSize:l,outlineSize:u,referenceBounds:n,sdfSize:f,sdfRadius:_,...o};h&&(this._writeQuad(e,t,s,i,{texcoords:Qi,offsets:r.main,color:Me(h),...y}),m||(this._writeQuad(e,t,s,i,{texcoords:tr,offsets:r.top,color:Me(h),...y}),this._writeQuad(e,t,s,i,{texcoords:sr,offsets:r.bot,color:Me(h),...y}),this._writeQuad(e,t,s,i,{texcoords:ir,offsets:r.left,color:Me(h),...y}),this._writeQuad(e,t,s,i,{texcoords:rr,offsets:r.right,color:Me(h),...y}))),m&&(this._writeQuad(e,t,s,i,{texcoords:Ji,offsets:r.top,color:Me(d),...y}),this._writeQuad(e,t,s,i,{texcoords:Ji,offsets:r.bot,color:Me(d),...y}),this._writeQuad(e,t,s,i,{texcoords:er,offsets:r.left,color:Me(d),...y}),this._writeQuad(e,t,s,i,{texcoords:er,offsets:r.right,color:Me(d),...y}))}_writeQuad(e,t,s,i,r){const n=e.vertexCount();this._writeVertex(e,t,s,i,r),e.indexWrite(n+0),e.indexWrite(n+1),e.indexWrite(n+2),e.indexWrite(n+1),e.indexWrite(n+3),e.indexWrite(n+2)}}const ar=e=>Math.round(e*(256/360)),cr=p.CQ*p.CQ/16,lr=(0,Ei.z9)(()=>Promise.all([s.e(3661),s.e(1878),s.e(8885),s.e(5756),s.e(3708)]).then(s.bind(s,33708))),ur=(0,Ei.z9)(()=>Promise.all([s.e(3661),s.e(1878),s.e(8885),s.e(4690)]).then(s.bind(s,14690))),hr=(0,O.Bj)(e=>{let t=0;if(0===e)return 1/0;for(;!(e%2);)t++,e/=2;return t});class dr extends or{constructor(){super(...arguments),this._zoomLevel=0}async loadDependencies(){await Promise.all([super.loadDependencies(),lr.getImportPromise(),ur.getImportPromise()])}_write(e,t,s,i,r){if(this._zoomLevel=i||0,null!=s)throw new Error("InternalError: EffectGeometry not support for LabelMeshWriter");switch(t.geometryType){case"esriGeometryPoint":{const s=t.readXForDisplay(),i=t.readYForDisplay();this._writePoint(e,s,i,0,t);break}case"esriGeometryEnvelope":case"esriGeometryPolygon":this._writePolygon(e,t,r);break;case"esriGeometryMultipoint":{let s=0;const i=xe.z.fromFeatureSetReader(t);if(i?.nextPath())for(;i.nextPoint();)this._writePoint(e,i.x,i.y,s++,t);break}case"esriGeometryPolyline":this._writeLines(e,t)}}_getMetricDir(){const{horizontalAlignment:e,verticalAlignment:t}=this.evaluatedMeshParams;return["center"===e?0:"right"===e?-1:1,"middle"===t?0:"bottom"===t?-1:1]}_createLineLabelMetric(e,t,s,i,r,n){const[o,a]=this._getMetricDir(),c=this.evaluatedMeshParams.scaleInfo?.maxScale??0,l=this.evaluatedMeshParams.scaleInfo?.minScale??0,u=this.evaluatedMeshParams.labelClassId;return new Ri(e,u,t,s,i,r,o,a,c,l,n)}_writePolygon(e,t,s){const i=lr.module,r=ur.module.constructFromFlatGeometry,n=t.readGeometryForDisplay(),o=t.readCentroidForDisplay()?.coords,a=n?.area()||0;if(!o)return;const c=a>=cr;e.requiresRefresh||=c;const l=r((0,Mi.ME)(s)),u=r((0,Mi.ME)({x:o[0],y:o[1]})),h=!!i.execute(u,l,null);if(!n||!c||!h)return void this._writePoint(e,o[0],o[1],0,t);const d=r((0,Mi.Nh)("polygon",n,null)),p=i.execute(d,l,null);if(!p)return void this._writePoint(e,o[0],o[1],0,t);const f=(0,Mi.JR)(new Mi.uX(p.toFlatGeometry())),_=xe.z.fromOptimized(f,"esriGeometryPolygon",1),m=(0,Ci.d)(_)??o;this._writePoint(e,m[0],m[1],0,t)}_writePoint(e,t,s,i,r){if(t<0||t>p.CQ||s<0||s>p.CQ)return;const n=this._getShaping();if(!n)return;const o=r.getDisplayId(),a=this.evaluatedMeshParams.labelClassId,c=function(e,t,s){return(0,me.Wm)(`${e}${t}${s}`)}(this.evaluatedMeshParams.layerId,r.getObjectId(),i),l=function(e,t,s){return(0,me.Wm)(`${e}${t}${s}`)}(r.getObjectId(),a,i),[u,h]=this._getMetricDir(),d=this.evaluatedMeshParams.scaleInfo?.maxScale??0,f=this.evaluatedMeshParams.scaleInfo?.minScale??0,_=this._getPointReferenceBounds()||{offsetX:0,offsetY:0,size:0};e.metricStart(new Ri(o,a,c,l,t,s,u,h,d,f,_)),this._writeGlyphs(e,o,t,s,n,0,_,void 0,!1),e.metricBoxWrite(n.boundsT),e.metricEnd()}_getPointReferenceBounds(){if(!this._references)return null;for(const e of this._references){const t=e.getBoundsInfo();if(t)return t}return null}_writeLines(e,t){const{scaleInfo:s,verticalAlignment:i}=this.evaluatedMeshParams,r=this.evaluatedMeshParams.repeatLabelDistance||128,n=this._getShaping("middle");if(!n)return;const o=(e,t,s,i)=>this._placeSubdivGlyphs(e,t,s,i),a=(n.bounds.width+r)/2;this._current={out:e,id:t.getDisplayId(),objId:t.getObjectId(),shaping:n,zoomRange:Te(s,this.getTileInfo()),referenceBounds:this._getPointReferenceBounds()||{offsetX:0,offsetY:0,size:0},offsetDirection:null,pathIndex:0},this._verticalPlacement="bottom"===i?"above":"top"===i?"below":null,this._verticalPlacement?this._writeAboveAndBelowAlong(t,o,a):this._writeCenterAlong(t,o,a)}_writeAboveAndBelowAlong(e,t,s){const{repeatLabel:i}=this.evaluatedMeshParams,{shaping:r}=this._current,n=r.bounds.halfHeight,o=e.readGeometryForDisplay();if(!o)return;const a=(0,Fi.kz)(o,"esriGeometryPolyline",1)??new Xt.A,c=pr(a,n),l=pr(a,-n),u=(0,Fi.zv)(l,"esriGeometryPolyline",!1,!1),h=Ui((0,Fi.zv)(c,"esriGeometryPolyline",!1,!1).paths,r.bounds.width),d=Ui(u.paths,r.bounds.width);this._current.offsetDirection="above";for(let e=0;e<h.length;e++)this._current.pathIndex=e,Gi(h[e],s,t,!!i);this._current.offsetDirection="below";for(let e=0;e<d.length;e++)this._current.pathIndex=e,Gi(d[e],s,t,!!i)}_writeCenterAlong(e,t,s){const{repeatLabel:i}=this.evaluatedMeshParams,{shaping:r}=this._current,n=Ui(e.readLegacyGeometryForDisplay().paths,r.bounds.width);for(let e=0;e<n.length;e++)this._current.pathIndex=e,Gi(n[e],s,t,!!i)}_placeSubdivGlyphs(e,t,s,i){const{allowOverrun:r,labelPosition:n,repeatLabelDistance:o,layerId:a,labelClassId:c}=this.evaluatedMeshParams,{objId:l,shaping:u,pathIndex:h}=this._current,d=this._current.zoomRange[0],p=hr(t),f=this._current.shaping.bounds.width/2,_=Math.sqrt(o||128)/2,m=Math.min(s,i-s),y=u.isMultiline?$i:Math.log2(m/(_+f/2)),g=0===t?y:Math.min(p,y),x=Math.max(d,this._zoomLevel+1-g),w=this._zoomLevel-x,b=u.bounds.width/2*2**w,v=function(e,t,s,i,r){return(0,me.Wm)(`${e}${t}${s}${i*2**($i-r)}`)}(a,l,h,t,this._zoomLevel),S=function(e,t,s,i,r){return(0,me.Wm)(`${e}${r}${t}${s*2**($i-i)}`)}(l,h,t,this._zoomLevel,c);this._current.shaping.isMultiline?0===t&&this._placeStraight(e,x,v,S):r&&w<0?this._placeStraightAlong(e,d,v,S):"parallel"===n?this._placeStraightAlong(e,x,v,S):"curved"===n&&this._placeCurved(e,x,b,v,S)}_placeStraight(e,t,s,i){const{out:r,id:n,shaping:o,referenceBounds:a}=this._current,{x:c,y:l}=e;r.metricStart(this._createLineLabelMetric(n,s,i,c,l)),r.metricBoxWrite(o.boundsT);const u=e.angle*(180/Math.PI)%360,h=(e.angle*(180/Math.PI)+180)%360;if(!this._verticalPlacement||this._verticalPlacement===this._current.offsetDirection){const e={clipAngle:u,mapAligned:!0,isLineLabel:!0,minZoom:t};this._writeGlyphs(r,n,c,l,o,0,a,e,!1)}if(!this._verticalPlacement||this._verticalPlacement!==this._current.offsetDirection){const e={clipAngle:h,mapAligned:!0,isLineLabel:!0,minZoom:t};this._writeGlyphs(r,n,c,l,o,0,a,e,!1)}r.metricEnd()}_placeCurved(e,t,s,i,r){const{out:n,id:o}=this._current;n.metricStart(this._createLineLabelMetric(o,i,r,e.x,e.y));const a=e.clone(),c=e.angle*(180/Math.PI)%360,l=(e.angle*(180/Math.PI)+180)%360;this._verticalPlacement&&this._verticalPlacement!==this._current.offsetDirection||(this._placeFirst(a,t,1,c),this._placeBack(e,a,t,s,1,c),this._placeForward(e,a,t,s,1,c)),this._verticalPlacement&&this._verticalPlacement===this._current.offsetDirection||(this._placeFirst(a,t,0,l),this._placeBack(e,a,t,s,0,l),this._placeForward(e,a,t,s,0,l)),n.metricEnd()}_placeStraightAlong(e,t,s,i){const{out:r,id:n,shaping:o,zoomRange:a,referenceBounds:c}=this._current,{boxBorderLineColor:l,boxBackgroundColor:h}=this.evaluatedMeshParams,d=e.clone(),p=e.angle*(180/Math.PI)%360,f=(e.angle*(180/Math.PI)+180)%360,_=o.glyphs.length>0&&!(!l&&!h);if(r.metricStart(this._createLineLabelMetric(n,s,i,e.x,e.y)),_){const s=Math.max(t,a[0],0),i=Math.min($i,a[1]),l=(0,Ii.$0)((0,Ti.vt)(),-e.angle),h={minZoom:s,maxZoom:i,clipAngle:p,mapAligned:!0,isLineLabel:!0},d=(0,u.Lz)(this.evaluatedMeshParams.offsetX),_=(0,u.Lz)(this.evaluatedMeshParams.offsetY);if(!this._verticalPlacement||this._verticalPlacement===this._current.offsetDirection){const t=(0,ki.fA)(d,-1*_),[s,i]=o.shapeBackground((0,Ii.Tl)((0,Ti.vt)(),l,t));r.recordStart(this.instanceId,this.attributeLayout,o.glyphs[0].textureBinding),this._writeTextBox(r,n,e.x,e.y,i,c,h),r.recordEnd()}if(!this._verticalPlacement||this._verticalPlacement!==this._current.offsetDirection){const t=(0,ki.fA)(d,_),[s,i]=o.shapeBackground((0,Ii.Tl)((0,Ti.vt)(),l,t));h.clipAngle=f,r.recordStart(this.instanceId,this.attributeLayout,o.glyphs[0].textureBinding),this._writeTextBox(r,n,e.x,e.y,i,c,h),r.recordEnd()}}this._verticalPlacement&&this._verticalPlacement!==this._current.offsetDirection||this._placeFirst(d,t,1,p,!0),this._verticalPlacement&&this._verticalPlacement===this._current.offsetDirection||this._placeFirst(d,t,0,f,!0),r.metricEnd()}_placeBack(e,t,s,i,r,n){const o=e.clone();let a=e.backwardLength+0;for(;o.prev()&&!(a>=i);)this._placeOnSegment(o,t,a,s,-1,r,n),a+=o.length+0}_placeForward(e,t,s,i,r,n){const o=e.clone();let a=e.remainingLength+0;for(;o.next()&&!(a>=i);)this._placeOnSegment(o,t,a,s,1,r,n),a+=o.length+0}_placeFirst(e,t,s,i,r=!1){const{out:n,id:o,shaping:a,zoomRange:c,referenceBounds:l}=this._current,u=a.glyphs,h=this._getBoundsOffset(e.angle);for(const d of u){const u=d.x>a.bounds.x?s:1-s,p=u*e.remainingLength+(1-u)*e.backwardLength,f=Math.abs(d.x+d.width/2-a.bounds.x),_=Math.max(0,this._zoomLevel+Math.log2(f/(p+0))),m=Math.max(t,r?0:_);d.angle=e.angle+(1-s)*Math.PI;const y=[Math.max(c[0],m),Math.min(c[1],$i)];this._writeLineGlyph(n,o,e.x,e.y,d,y,i,l),this._writeLineGlyphBox(n,d,s,y,h)}}_placeOnSegment(e,t,s,i,r,n,o){const{out:a,id:c,shaping:l,referenceBounds:u}=this._current,h=l.glyphs,d=e.dx/e.length,p=e.dy/e.length,f={x:e.x+s*-r*d,y:e.y+s*-r*p},_=this._getBoundsOffset(e.angle);for(const t of h){const h=t.x>l.bounds.x?n:1-n;if(!(h&&1===r||!h&&-1===r))continue;const d=Math.abs(t.x+t.width/2-l.bounds.x),p=Math.max(0,this._zoomLevel+Math.log2(d/s)-.1),m=Math.max(i,this._zoomLevel+Math.log2(d/(s+e.length+0)));if(0===p)continue;t.angle=e.angle+(1-n)*Math.PI;const y=[m,p];this._writeLineGlyph(a,c,f.x,f.y,t,y,o,u),this._writeLineGlyphBox(a,t,n,y,_)}}_getBoundsOffset(e){const t=(0,u.Lz)(this.evaluatedMeshParams.offsetX),s=(0,u.Lz)(this.evaluatedMeshParams.offsetY),i=(0,ki.fA)(t,s),r=(0,Ii.$0)((0,Ti.vt)(),-e);return(0,D.l0)(i,i,r)}_writeLineGlyph(e,t,s,i,r,n,o,a){if(s<0||s>p.CQ||i<0||i>p.CQ)return;e.recordStart(this.instanceId,this.attributeLayout,r.textureBinding);const{texcoords:c,offsets:l}=r,{fontSize:u,haloSize:h,outlineSize:d}=this._textMeshTransformProps,{sdfSize:f,sdfRadius:_}=this.evaluatedMeshParams.glyphs;this._writeQuad(e,t,s,i,{sdfSize:f,sdfRadius:_,texcoords:c,offsets:l,fontSize:u,haloSize:h,outlineSize:d,color:Me(this.evaluatedMeshParams.color),isBackground:!1,referenceBounds:a,minZoom:Math.max(this._current.zoomRange[0],n[0]),maxZoom:Math.min(this._current.zoomRange[1],n[1]),clipAngle:o,mapAligned:!0,isLineLabel:!0}),e.recordEnd()}_writeLineGlyphBox(e,t,s,i,r){if((s||this._current.offsetDirection)&&this._isVisible(i)&&t.bounds){const s=t.bounds,i=new Pi.A(s.x+r[0],s.y+r[1],s.width,s.height);e.metricBoxWrite(i)}}_packedZoom(e){return Math.floor(e*p.fq)/p.fq}_isVisible(e){let t=Math.max(this._current.zoomRange[0],e[0]),s=Math.min(this._current.zoomRange[1],e[1]);t=this._packedZoom(t),s=this._packedZoom(s);const i=this._packedZoom(this._zoomLevel);return t<=i&&i<=s}}function pr(e,t){const s=new Xt.A,{coords:i,lengths:r}=e,n=(0,Ai.vt)(),o=(0,Ai.vt)(),a=(0,Ai.vt)(),c=(0,Ai.vt)(),l=(0,Ai.vt)(),u=(0,Ai.vt)();let h=0;for(let e=0;e<r.length;e++){const d=r[e];for(let e=0;e<d;e++){const r=2*(e+h-1),p=2*(e+h),f=2*(e+h+1);e>0?(0,D.hZ)(n,i[r],i[r+1]):(0,D.hZ)(n,0,0),(0,D.hZ)(o,i[p],i[p+1]),e<d-1?(0,D.hZ)(a,i[f],i[f+1]):(0,D.hZ)(a,0,0),0===e?(0,D.hZ)(c,0,0):((0,D.jb)(c,o,n),(0,D.S8)(c,c),(0,D.hZ)(c,c[1],-c[0])),e===d-1?(0,D.hZ)(l,0,0):((0,D.jb)(l,a,o),(0,D.S8)(l,l),(0,D.hZ)(l,l[1],-l[0])),(0,D.WQ)(u,c,l),(0,D.S8)(u,u);const _=u[0]*l[0]+u[1]*l[1];0!==_&&(0,D.hs)(u,u,_),(0,D.hs)(u,u,t),s.coords.push(o[0]+u[0],o[1]+u[1])}s.lengths.push(d),h+=d}return s}const fr={createComputedParams:e=>e,optionalAttributes:Rs.optionalAttributes,attributes:{...Rs.attributes,bitset:{type:Ye.pe.UNSIGNED_BYTE,count:1,pack:({gradientMethod:e,gradientSizeUnits:t,gradientType:s})=>Ae([[0,"alongline"===e.toLowerCase()],[1,t===ci.h.Absolute],[2,"discrete"===s.toLowerCase()]])},tlbr:{type:Ye.pe.UNSIGNED_SHORT,count:4,pack:({sprite:e})=>{const{rect:t,width:s,height:i}=e,r=t.x+p.hM+p.MZ,n=t.y+p.hM;return[r,n,r+s-2*p.MZ,n+i]}},accumulatedDistance:{type:Ye.pe.HALF_FLOAT,count:1,packTessellation:({distance:e,pathLength:t,distanceOffset:s})=>(s+e)/t},gradientSize:{type:Ye.pe.HALF_FLOAT,count:1,pack:({gradientSize:e,gradientSizeUnits:t})=>t===ci.h.Relative?e/100:(0,u.Lz)(e)},totalLength:{type:Ye.pe.HALF_FLOAT,count:1,packTessellation:({pathLength:e})=>e},segmentDirection:{type:Ye.pe.BYTE,count:2,packPrecisionFactor:16,packTessellation:({directionX:e,directionY:t})=>[e,t]}}};class _r extends Ls{get _preventEffectClipping(){return!0}constructor(e,t,s,i){super(e,t,s,i),this.vertexSpec=fr,this._tessellationOptions.textured=!0}_write(e,t,s){const i=s??xe.z.fromFeatureSetReaderCIM(t);if(!i)return;const{sprite:r}=this.evaluatedMeshParams;this._writeGeometry(e,t,i,r?.textureBinding)}}const mr={createComputedParams:e=>e,optionalAttributes:Rs.optionalAttributes,attributes:{...Rs.attributes,bitset:{type:Ye.pe.UNSIGNED_BYTE,count:1,pack:({shouldSampleAlphaOnly:e,shouldScaleDash:t,isSDF:s})=>Ae([[4,e],[2,t],[3,s]])},tlbr:{type:Ye.pe.UNSIGNED_SHORT,count:4,pack:({sprite:e})=>{const{rect:t,width:s,height:i}=e,r=t.x+p.hM,n=t.y+p.hM;return[r,n,r+s,n+i]}},accumulatedDistance:{type:Ye.pe.UNSIGNED_SHORT,count:1,packTessellation:({distance:e})=>e},segmentDirection:{type:Ye.pe.BYTE,count:2,packPrecisionFactor:16,packTessellation:({directionX:e,directionY:t})=>[e,t]},offsetAlongLine:{type:Ye.pe.HALF_FLOAT,count:1,pack:({offsetAlongLine:e})=>(0,u.Lz)(e)},capType:{type:Ye.pe.UNSIGNED_BYTE,count:1,pack:({capType:e})=>{switch(e){case"Butt":case"butt":default:return 0;case"Square":case"square":return 1;case"Round":case"round":return 2}}}}};class yr extends Ls{constructor(e,t,s,i){super(e,t,s,i),this.vertexSpec=mr,this._tessellationOptions.textured=!0}_write(e,t,s){const i=s??xe.z.fromFeatureSetReaderCIM(t);if(!i)return;const{sprite:r}=this.evaluatedMeshParams;this._writeGeometry(e,t,i,r?.textureBinding)}}class gr{static from(e){return"width"in e?this.fromSimpleMeshParams(e):this.fromComplexMeshParams(e)}static fromSimpleMeshParams(e){const t=new gr(e.sprite,e.color,e.outlineColor,e.minPixelBuffer,e.placement,e.scaleInfo,e.effects),{type:s,width:i,height:r,angle:n,alignment:o,outlineSize:a,referenceSize:c,sprite:l,overrideOutlineColor:h}=e;return t.rawWidth=(0,u.Lz)(i),t.rawHeight=(0,u.Lz)(r),t.angle=n,t.alignment=o,t.outlineSize=(0,u.Lz)(a),t.referenceSize=(0,u.Lz)(c),t.overrideOutlineColor=h,t.offsetX=(0,u.Lz)(e.offsetX),t.offsetY=(0,u.Lz)(e.offsetY),"simple"!==s||l.sdf||(t.rawWidth=l.width,t.rawHeight=l.height),t._computeSize(e,!1),t}static fromComplexMeshParams(e){const t=new gr(e.sprite,e.color,e.outlineColor,e.minPixelBuffer,e.placement,e.scaleInfo,e.effects);let{alignment:s,transforms:i,size:r,scaleX:n,anchorX:o,anchorY:a,angle:c,colorLocked:l,frameHeight:h,widthRatio:d,offsetX:p,offsetY:f,outlineSize:_,referenceSize:m,scaleFactor:y,sizeRatio:g,isAbsoluteAnchorPoint:x,rotateClockwise:w,scaleSymbolsProportionally:b,sprite:v}=e;if(i&&i.infos.length>0){const e=(0,Ei.zb)(r,c,w,p,f,i);r=e.size,c=e.rotation,p=e.offsetX,f=e.offsetY,w=!1}y&&(r*=y,p*=y,f*=y);const S=n*(v.width/v.height);t.alignment=s,t.rawHeight=(0,u.Lz)(r),t.rawWidth=t.rawHeight*S,t.referenceSize=(0,u.Lz)(m),t.sizeRatio=g,t.sdfDecodeCoeff=(v.sdfDecodeCoeff??1)*g,t.angle=c,t.rotateClockwise=w,t.anchorX=o,t.anchorY=a,t.offsetX=(0,u.Lz)(p),t.offsetY=(0,u.Lz)(f),x&&r&&(v.sdf?t.anchorX=o/(r*d):t.anchorX=o/(r*S),t.anchorY=a/r);const I=b&&h?r/h:1;return t.outlineSize=0===_||isNaN(_)?0:(0,u.Lz)(_)*I,t.scaleSymbolsProportionally=b,t.colorLocked=l,t._computeSize(e,!0),t}constructor(e,t,s,i,r,n,o){this.sprite=e,this.color=t,this.outlineColor=s,this.minPixelBuffer=i,this.placement=r,this.scaleInfo=n,this.effects=o,this.rawWidth=0,this.rawHeight=0,this.angle=0,this.outlineSize=0,this.referenceSize=0,this.sizeRatio=1,this.sdfDecodeCoeff=1,this.alignment=0,this.scaleSymbolsProportionally=!1,this.overrideOutlineColor=!1,this.colorLocked=!1,this.anchorX=0,this.anchorY=0,this.computedWidth=0,this.computedHeight=0,this.texXmin=0,this.texYmin=0,this.texXmax=0,this.texYmax=0,this.offsetX=0,this.offsetY=0,this.rotateClockwise=!0}get boundsInfo(){return{size:Math.max(this.computedHeight,this.computedWidth),offsetX:this.offsetX,offsetY:this.offsetY}}_computeSize(e,t){const{sprite:s,hasSizeVV:i}=e,r=!!s.sdf,n=s.sdfPaddingRatio??.5,{rawWidth:o,rawHeight:a,sizeRatio:c,outlineSize:l}=this,u=s.rect;let h=o*c,d=a*c,f=0,_=0;if(r){const e=1/(1-n);if(h*=e,d*=e,i)this.computedWidth=h,this.computedHeight=d;else{const e=t&&o>a?h:o,i=a,r=l+2;this.computedWidth=Math.min(e+r,h),this.computedHeight=Math.min(i+r,d);const n=Math.max(s.width,s.height)/Math.max(h,d);f=(this.computedWidth-h)*n,_=(this.computedHeight-d)*n}}else this.computedWidth=h*(u.width/s.width),this.computedHeight=d*(u.height/s.height),f=2*p.hM,_=2*p.hM;const m=u.x+p.hM-f/2,y=u.y+p.hM-_/2,g=m+s.width+f,x=y+s.height+_;this.texXmin=xr(m),this.texYmin=xr(y),this.texXmax=wr(g),this.texYmax=wr(x),this.computedWidth*=(this.texXmax-this.texXmin)/(g-m),this.computedHeight*=(this.texYmax-this.texYmin)/(x-y),this.anchorX*=h/this.computedWidth,this.anchorY*=d/this.computedHeight}}function xr(e,t=1e-7){const s=Math.ceil(e);return s-e<t?s:Math.floor(e)}function wr(e,t=1e-7){const s=Math.floor(e);return e-s<t?s:Math.ceil(e)}const br=128/Math.PI;const vr={createComputedParams:e=>gr.from(e),optionalAttributes:{zoomRange:{type:Ye.pe.SHORT,count:2,packPrecisionFactor:p.fq,pack:({scaleInfo:e},{tileInfo:t})=>Te(e,t)}},attributes:{pos:{type:Ye.pe.SHORT,count:2,pack:"position",packPrecisionFactor:10},id:{type:Ye.pe.UNSIGNED_BYTE,count:3,pack:"id"},bitset:{type:Ye.pe.UNSIGNED_BYTE,count:1,pack:({sprite:e,alignment:t,scaleSymbolsProportionally:s,overrideOutlineColor:i,colorLocked:r})=>{let n=0;return e.sdf&&(n|=ke(Re)),1===t&&(n|=ke(Oe)),s&&(n|=ke(ze)),i&&(n|=ke(Le)),r&&(n|=ke(De)),n}},offset:{type:Ye.pe.HALF_FLOAT,count:2,packAlternating:{count:4,pack:({angle:e,computedWidth:t,computedHeight:s,anchorX:i,anchorY:r,offsetX:n,offsetY:o,rotateClockwise:a})=>{const c=function(e,t,s,i,r=!1){const n=(0,Ti.vt)(),o=r?1:-1;return(0,Ii.D_)(n),(t||s)&&(0,Ii.Tl)(n,n,[t,-s]),i&&(0,Ii.e$)(n,n,.017453292519944444*o*-i),n}(0,n,o,-e,a),l=-(.5+i)*t,u=-(.5-r)*s,h=[l,u],d=[l+t,u],p=[l,u+s],f=[l+t,u+s];return(0,D.l0)(h,h,c),(0,D.l0)(d,d,c),(0,D.l0)(p,p,c),(0,D.l0)(f,f,c),[h,d,p,f]}}},textureUV:{type:Ye.pe.SHORT,count:2,packPrecisionFactor:4,packAlternating:{count:4,pack:({texXmax:e,texXmin:t,texYmax:s,texYmin:i})=>[[t,i],[e,i],[t,s],[e,s]]}},color:{type:Ye.pe.UNSIGNED_BYTE,count:4,normalized:!0,pack:({color:e})=>Me(e)},outlineColor:{type:Ye.pe.UNSIGNED_BYTE,count:4,normalized:!0,pack:({outlineColor:e})=>Me(e)},sizing:{type:Ye.pe.UNSIGNED_BYTE,count:4,pack:({rawWidth:e,rawHeight:t,outlineSize:s,referenceSize:i})=>[Ee(Math.max(e,t),128),Ee(s,128),Ee(i,128),0]},placementAngle:{type:Ye.pe.UNSIGNED_BYTE,count:1,packTessellation:({placementAngle:e})=>function(e){return function(e){return e%=256,Math.abs(e>=0?e:e+256)}(e*br)}(e)},sdfDecodeCoeff:{type:Ye.pe.UNSIGNED_SHORT,count:1,packPrecisionFactor:64,pack:({sdfDecodeCoeff:e})=>e}}};class Sr extends He{constructor(){super(...arguments),this.vertexSpec=vr}getBoundsInfo(){return this.evaluatedMeshParams.boundsInfo}_write(e,t,s){const i=this.evaluatedMeshParams.sprite?.textureBinding,r=t.getDisplayId();e.recordStart(this.instanceId,this.attributeLayout,i);const n=this.evaluatedMeshParams.minPixelBuffer,o=Math.max(this.evaluatedMeshParams.computedWidth,n),a=Math.max(this.evaluatedMeshParams.computedHeight,n),c=-this.evaluatedMeshParams.anchorX*this.evaluatedMeshParams.computedWidth,l=this.evaluatedMeshParams.anchorY*this.evaluatedMeshParams.computedHeight,u=this.evaluatedMeshParams.offsetX+c,h=-this.evaluatedMeshParams.offsetY+l;if(null!=this.evaluatedMeshParams.placement){let i=null;if(null!=s){const e=Math.max(this.evaluatedMeshParams.computedWidth,this.evaluatedMeshParams.computedHeight);if(i=(0,qe.qc)(s,2*e,!1),null===i)return}this._writePlacedMarkers(e,t,i,o,a)}else if(s?.nextPath()){s.nextPoint();const t=s.x,i=s.y;e.recordBounds(t+u,i+h,o,a),this._writeQuad(e,r,t,i)}else if("esriGeometryPolygon"===t.geometryType){const s=t.readCentroidForDisplay();if(!s)return;const[i,n]=s.coords;e.recordBounds(i+u,n+h,o,a),this._writeQuad(e,r,i,n)}else if("esriGeometryPoint"===t.geometryType){const s=t.readXForDisplay(),i=t.readYForDisplay();e.recordBounds(s+u,i+h,o,a),this._writeQuad(e,r,s,i)}else{const s=t.readGeometryForDisplay();s?.forEachVertex((t,s)=>{e.recordBounds(t+u,s+h,o,a),Math.abs(t)>we.$u||Math.abs(s)>we.$u||this._writeQuad(e,r,t,s)})}e.recordEnd()}_writePlacedMarkers(e,t,s,i,r){const n=s??xe.z.fromFeatureSetReaderCIM(t);if(!n)return;const o=ve.getPlacement(n,-1,this.evaluatedMeshParams.placement,(0,u.Lz)(1),e.id);if(!o)return;const a=t.getDisplayId();let c=o.next();const l=this.evaluatedMeshParams.offsetX,h=-this.evaluatedMeshParams.offsetY;for(;null!=c;){const t=c.tx,s=-c.ty;if(Math.abs(t)>we.$u||Math.abs(s)>we.$u){c=o.next();continue}const n=-c.getAngle();e.recordBounds(t+l,s+h,i,r),this._writeQuad(e,a,t,s,n),c=o.next()}}_writeQuad(e,t,s,i,r){const n=e.vertexCount(),o=null==r?null:{placementAngle:r};this._writeVertex(e,t,s,i,o),e.indexWrite(n+0),e.indexWrite(n+1),e.indexWrite(n+2),e.indexWrite(n+1),e.indexWrite(n+3),e.indexWrite(n+2)}}var Ir=s(4576),Tr=s(4718),kr=s(55674);class Ar{destroy(){}}class Mr extends Ar{constructor(e){super(),this._value=e}resize(e){}read(e,t){return this._value}readWithDefault(e,t,s){return this._value}hasArcadeDependency(e){return!1}}const Cr=()=>Ie.A.getLogger("esri.views.2d.engine.webgl.shaderGraph.techniques.mesh.MeshWriterInputEvaluator");async function Fr(e,t,s,i){const{defaultValue:r,valueExpressionInfo:n,value:o}=t;if(n){if("dictionary-template"===n.type)return{...t,computed:e.createDictionaryTemplateField(n,s),defaultValue:r};const{expression:o}=n,a=await e.createComputedField({expression:o},i);return a?{...t,computed:a,defaultValue:r}:null}return{...t,computed:new Mr(o),defaultValue:r}}async function Er(e,t,s){const{valueExpressionInfo:i}=t,r="dictionary-template"===i.type?e.createDictionaryTemplateField(i,s):await e.createComputedField({expression:i.expression});return r?{...t,computed:r}:null}function Pr(e){return"object"==typeof e&&null!=e&&(!(!("valueExpressionInfo"in e)||!e.valueExpressionInfo)||"type"in e&&"Process"===e.type&&"op"in e&&"Random"===e.op)}function Rr(e){if(Array.isArray(e))for(const t of e)if(Rr(t))return!0;if("object"==typeof e){if(Pr(e))return!0;for(const t in e)if(Rr(e[t]))return!0}return!1}class Or{static async create(e,t,s,i){const r={},n=new Map,o=new Map,a=new Map,c=new Map,l=new Map,u=new Map;for(const h in s){const d=s[h];if(null!=d&&"object"==typeof d)if(Array.isArray(d)){if("object"==typeof d[0])throw new Error(`InternalError: Cannot handle ${h}. Nested array params are not supported`);r[h]=d}else{if("valueExpressionInfo"in d){if(d.value){r[h]=d.value;continue}const t=await Er(e,d,i);if(!t){r[h]=d.defaultValue;continue}n.set(h,t),r[h]=null;continue}switch(d.type){case"cim-effect-infos":if(d.effectInfos.some(e=>e.overrides.length)){o.set(h,{effects:await Promise.all(d.effectInfos.map(async t=>{const s=t.overrides.map(t=>Fr(e,t,i,!1));return{effect:t.effect,compiledOverrides:(await Promise.all(s)).filter(Ir.Ru)}}))});break}r[h]=d.effectInfos.map(e=>e.effect);break;case"cim-marker-placement-param":d.overrides.length&&a.set(h,{placementInfo:d,compiledOverrides:(await Promise.all(d.overrides.map(t=>Fr(e,t,i,!1)))).filter(Ir.Ru)}),r[h]=d.placement;break;case"text-rasterization-param":{if(d.overrides.length){const t=d.overrides.map(t=>Fr(e,t,i,d.useLegacyLabelEvaluationRules??!1));c.set(h,{compiledOverrides:(await Promise.all(t)).filter(Ir.Ru),rasterizationParam:d,objectIdToResourceId:new Map});continue}const s={type:"cim-rasterization-info",resource:d.resource};r[h]=await t.fetchResourceImmediate(s)??null;break}case"sprite-rasterization-param":{if(d.overrides.length){const t=d.overrides.map(t=>Fr(e,t,i,!1));c.set(h,{compiledOverrides:(await Promise.all(t)).filter(Ir.Ru),rasterizationParam:d,objectIdToResourceId:new Map});continue}if("animated"===d.resource.type){c.set(h,{compiledOverrides:[],rasterizationParam:d,objectIdToResourceId:new Map});continue}const s={type:"cim-rasterization-info",resource:d.resource};r[h]=await t.fetchResourceImmediate(s)??null;break}case"cim-marker-transform-param":{const{params:t}=d;if(Rr(t)){const s={compiledMarkerInfos:[]};await Promise.all(t.map(async t=>{const r={props:{}};for(const s in t)if(Pr(t[s])){const n=await Er(e,t[s],i);r.compiledExpressionMap||(r.compiledExpressionMap=new Map);const o=r.compiledExpressionMap;n&&o.set(s,n)}else r.props[s]=t[s];s.compiledMarkerInfos.push(r)})),l.set(h,s)}else r[h]={type:"cim-marker-transform-info",infos:t};break}case"animation-params":{const{params:s}=d,i=gt(s);if(Rr(i)){const t=await Promise.all(i.map(t=>wt(t,e)));u.set(h,{params:t,propertyIdToResourceId:new Map,key:h})}else{const e=yt(i),s=await t.fetchResourceImmediate({type:"animation-info",resource:e});null!=s&&"sprite"===s.type&&(r[h]={dataRow:s.rect.y,dataColumn:s.rect.x})}break}default:r[h]=d}}else r[h]=d}return new Or(s,r,n,o,a,c,l,u)}constructor(e,t,s,i,r,n,o,a){this.inputMeshParams=e,this._resolvedMeshParams=t,this._dynamicProperties=s,this._dynamicEffectProperties=i,this._dynamicPlacementProperties=r,this._dynamicAsyncProperties=n,this._dynamicTransformProperties=o,this._dynamicAsyncAnimations=a,this.evaluator=e=>e,this._arcadeDependencies=new Set;for(const e of this._expressions())(0,kr.QY)(this._arcadeDependencies,e)}get hasDynamicProperties(){return!!(this._dynamicProperties.size||this._dynamicAsyncProperties.size||this._dynamicEffectProperties.size||this._dynamicTransformProperties.size||this._dynamicPlacementProperties.size||this._dynamicAsyncAnimations.size)}get evaluatedMeshParams(){return this._evaluatedMeshParams||(this._evaluatedMeshParams=this.evaluator(this._resolvedMeshParams)),this._evaluatedMeshParams}enqueueRequest(e,t,s){for(const r of this._dynamicAsyncProperties.values()){const n=(0,Tr.o8)(r.rasterizationParam.resource);"animated"===r.rasterizationParam.resource.type&&r.rasterizationParam.resource.randomizeStartTime&&(n.primitiveName="__RESERVED__PRIMITIVE__NAME__",n.startGroup=Ke(t.getObjectId()||0));for(const{primitiveName:e,propertyName:o,computed:a,defaultValue:c,valueExpressionInfo:l}of r.compiledOverrides)try{const i="animated"===r.rasterizationParam.resource.type?n.primitiveName:e;(0,Es.Ph)(n,i,o,a,t,s,c)}catch(e){Cr().errorOnce(new i.A("invalid-arcade-expression","Encountered an error when evaluating the arcade expression",{error:e,valueExpressionInfo:l}))}const o=e.enqueueRequest({type:"cim-rasterization-info",resource:n});r.objectIdToResourceId.set(t.getObjectId(),o)}for(const i of this._dynamicAsyncAnimations.values()){const r=i.params.map(e=>bt(e,t,s)).map(ut).map(e=>e.simplify()),n=xt(r),o=e.enqueueRequest({type:"animation-info",resource:n});i.propertyIdToResourceId.set(t.getObjectId()+"."+i.key,o)}}evaluateMeshParams(e,t,s){for(const[e,i]of this._dynamicProperties.entries())this._resolvedMeshParams[e]=i.computed.readWithDefault(t,s,i.defaultValue);for(const[e,i]of this._dynamicPlacementProperties.entries())for(const{computed:r,defaultValue:n,propertyName:o}of i.compiledOverrides){const a=r.readWithDefault(t,s,n);i.placementInfo.placement[o]=a,this._resolvedMeshParams[e]=i.placementInfo.placement}for(const[e,i]of this._dynamicEffectProperties.entries())for(const r of i.effects){for(const{computed:e,defaultValue:i,propertyName:n}of r.compiledOverrides){const o=e.readWithDefault(t,s,i);r.effect[n]=o}this._resolvedMeshParams[e]=i.effects.map(e=>e.effect)}for(const[e,i]of this._dynamicTransformProperties.entries()){const r={type:"cim-marker-transform-info",infos:[]};for(const e of i.compiledMarkerInfos){const i={...e.props};if(e.compiledExpressionMap)for(const[r,n]of e.compiledExpressionMap){const e=n.computed.readWithDefault(t,s,n.defaultValue);i[r]="number"==typeof e||"boolean"==typeof e?e:n.defaultValue}r.infos.push(i)}this._resolvedMeshParams[e]=r}for(const[s,i]of this._dynamicAsyncProperties.entries()){const r=i.objectIdToResourceId.get(t.getObjectId());if(null==r)continue;const n=e.getResource(r);this._resolvedMeshParams[s]=n}for(const[s,i]of this._dynamicAsyncAnimations.entries()){const r=i.propertyIdToResourceId.get(t.getObjectId()+"."+s);if(null==r)continue;const n=e.getResource(r);this._resolvedMeshParams[s]={dataRow:n.rect.y,dataColumn:n.rect.x}}return this._evaluatedMeshParams=this.evaluator(this._resolvedMeshParams),this.evaluatedMeshParams}hasArcadeDependency(e){return this._arcadeDependencies.has(e)}*_expressions(){for(const e of this._dynamicProperties.values())yield e.computed;for(const e of this._dynamicEffectProperties.values())for(const t of e.effects)for(const e of t.compiledOverrides)yield e.computed;for(const e of this._dynamicPlacementProperties.values())for(const t of e.compiledOverrides)yield t.computed;for(const e of this._dynamicAsyncProperties.values())for(const t of e.compiledOverrides)yield t.computed;for(const e of this._dynamicTransformProperties.values())for(const t of e.compiledMarkerInfos)if(null!=t.compiledExpressionMap)for(const e of t.compiledExpressionMap.values())yield e.computed;for(const e of this._dynamicAsyncAnimations.values())for(const t of e.params)yield*vt(t)}}const zr={createComputedParams:e=>e,optionalAttributes:{},attributes:{pos:{type:Ye.pe.SHORT,count:2,packPrecisionFactor:10,pack:"position"},id:{type:Ye.pe.UNSIGNED_BYTE,count:3,pack:"id"},bitset:{type:Ye.pe.UNSIGNED_BYTE,count:1,pack:e=>0},offset:{type:Ye.pe.SHORT,count:2,packPrecisionFactor:16,packAlternating:{count:4,pack:({size:e})=>{const t=(0,u.Lz)(e),s=-t/2,i=-t/2;return[[s,i],[s+t,i],[s,i+t],[s+t,i+t]]}}},texCoords:{type:Ye.pe.SHORT,count:2,packPrecisionFactor:4,packAlternating:{count:4,pack:()=>[[0,1],[1,1],[0,0],[1,0]]}},size:{type:Ye.pe.UNSIGNED_BYTE,count:2,pack:({size:e})=>[e,e]},referenceSize:{type:Ye.pe.UNSIGNED_BYTE,count:1,pack:({size:e})=>(0,u.Lz)(e)},zoomRange:{type:Ye.pe.UNSIGNED_BYTE,count:2,pack:({scaleInfo:e},{tileInfo:t})=>Te(e,t)}}};class Lr extends He{constructor(){super(...arguments),this.vertexSpec=zr}_write(e,t){const s=t.getDisplayId(),i=this.evaluatedMeshParams.minPixelBuffer,r=Math.max((0,u.Lz)(this.evaluatedMeshParams.size),i);let n,o;if("esriGeometryPoint"===t.geometryType)n=t.readXForDisplay(),o=t.readYForDisplay();else{const e=t.readCentroidForDisplay();if(!e)return;n=e?.coords[0],o=e?.coords[1]}e.recordStart(this.instanceId,this.attributeLayout),e.recordBounds(n,o,r,r);const a=e.vertexCount();this._writeVertex(e,s,n,o),e.indexWrite(a+0),e.indexWrite(a+1),e.indexWrite(a+2),e.indexWrite(a+1),e.indexWrite(a+3),e.indexWrite(a+2),e.recordEnd()}}class Dr{async createMeshWriter(e,t,s,i,r){const n=this._getMeshWriter(i.techniqueType),o=await Or.create(e,t,i.inputParams,r),a=new n(i.id,o,i.optionalAttributes,s);return await a.loadDependencies(),a}_getMeshWriter(e){switch(e){case 15:return Vs;case 12:return js;case 10:return Xs;case 28:return $s;case 16:return yi;case 26:return ti;case 29:return bi;case 11:return ai;case 23:return Sr;case 30:return Lr;case 32:return or;case 21:return Ls;case 33:return yr;case 17:return _r;case 19:return Si;case 20:return dr;case 2:return Yt;case 3:return $t;case 0:return Ns;case 1:return Bs;default:throw new Error("Internal Error: Mesh writer not in the registry")}}}class Nr{constructor(e,t,s,i,r){this.storage=e,this.proxy=t,this.viewParams=s,this.registry=i,this.fieldsMap=r}async createMeshWriters(e){const t=e.map(e=>this.registry.createMeshWriter(this.storage,this.proxy,this.viewParams,e,this.fieldsMap));return Promise.all(t)}}var qr=s(563);class Br{constructor(e){this._outstandingMessages=[],this._queue=new qr.QueueProcessor({concurrency:e.concurrency,process:t=>e.process(t)})}async push(e){if(e.end)return await Promise.all(this._outstandingMessages),await this._queue.push(e),void(this._outstandingMessages=[]);const t=this._queue.push(e);return this._outstandingMessages.push(t),t}}var Gr=s(16930),Ur=s(43334),jr=s(31464),Wr=s(95466);class Vr{static async create(e,t){if("count"===t.statisticType){const e=new Mr(1);return new Vr(t.name,t.alias,t.type,t.statisticType,e)}const s=await e.createComputedField({expression:t.onStatisticExpression?.expression,field:t.onStatisticField});return new Vr(t.name,t.alias,t.type,t.statisticType,s)}constructor(e,t,s,i,r){this.name=e,this.alias=t,this.type=s,this.statisticType=i,this.computed=r}}var Yr=s(65529),$r=s(70328),Hr=s(37730),Zr=s(75752);class Qr{constructor(e){this.subscription=e,this.handledChunks=new Set}destroy(){}}class Xr{constructor(e,t,s){this._source=e,this._attributeStore=t,this._sqlOptions=s,this._sendStates=new Map}destroy(){}get enablePixelBuffering(){return!0}get isAggregate(){return!1}get usedMemory(){return 0}updateRequiredLevel(e,t){}onSubscribe(e){const t=this.createState(e);this._sendStates.set(e.key.id,t),this.updateChunks()}onUnsubscribe(e){this._sendStates.get(e.key.id)?.destroy(),this._sendStates.delete(e.key.id)}get hasSubscribers(){return this._sendStates.size>0}requiresInvalidation(){return!1}invalidate(){const e=Array.from(this._sendStates.values());this._sendStates.clear();for(const t of e)t.destroy(),this.onSubscribe(t.subscription)}invalidateAttributeData(e){}hasArcadeDependency(e){return!1}getFeatureObjectIdsForAggregate(e){throw new Error("InternalError: AggregateId lookup not supported")}getDisplayIds(e){return this.displayMap(e,e=>e,e=>e)}getDisplayAndObjectIds(e){return this.displayMap(e,e=>e,(e,t,s)=>[e,s])}afterUpdateChunks(){}}class Kr extends Xr{constructor(e,t,s,i,r){super(e,t,r),this.spatialReference=s,this.aggregateFields=i,this._arcadeDependencies=new Set,this.events=new Yr.bk,this.featureAdapter=Hr.T;for(const e of i)(0,kr.QY)(this._arcadeDependencies,e.computed)}get aggregateQueryEngine(){return this._aggregateQueryEngine||(this._aggregateQueryEngine=new Zr.do({featureStore:this,fieldsIndex:this._metadata.fieldsIndex,geometryType:this._metadata.geometryType,featureIdInfo:this._metadata.featureIdInfo,spatialReference:this.spatialReference})),this._aggregateQueryEngine}get isAggregate(){return!0}removeChunks(e){}hasArcadeDependency(e){return this._arcadeDependencies.has(e)}forEach(e){return this.forEachAggregateWorldSpace(e)}forEachInBounds(e,t){}forEachBounds(e,t){const s=(0,$r.vt)();for(const i of e){const e=(0,Fi.jQ)(s,i.geometry);e&&t(e)}}}class Jr{constructor(e,t,s,i,r){this.subscription=e,this.reader=t,this.clear=s,this.end=i,this.debugInfo=r,this.type="append"}get id(){return this.subscription.tile.id}createMessage(e,t,s){return{type:"append",clear:this.clear,id:this.id,append:e,end:this.end,debugInfo:this.debugInfo,subscriptionVesrion:this.subscription.version,version:t,attributeEpoch:s}}}class en{constructor(e,t,s,i,r){this.subscription=e,this.reader=t,this.remove=s,this.end=i,this.debugInfo=r,this.type="update"}get id(){return this.subscription.tile.id}createMessage(e,t,s){return{type:"update",id:this.id,modify:e,debugInfo:this.debugInfo,remove:this.remove,version:t,subscriptionVesrion:this.subscription.version,end:this.end,attributeEpoch:s}}}const tn=8388607,sn=e=>e&tn;class rn extends Ar{constructor(e){super(),this._field=e}resize(e){throw new Error("Method not implemented.")}read(e,t){return e.readAttribute(this._field)}readWithDefault(e,t){return e.readAttribute(this._field)}hasArcadeDependency(e){return!1}}var nn=s(50115);class on extends Ar{static async create(e,t){const s=await(0,kr.Ad)(e,t.spatialReference),i=(0,me.Wm)(e);return new on(s,i)}constructor(e,t){super(),this._compiled=e,this._cacheKey=t}resize(e){}read(e,t){return this.hasArcadeDependency("scale")||"system"!==t.$view.timeZone?(0,nn.V4)(this._compiled,e,t):this._readCached(e,t)}readWithDefault(e,t,s){return this.hasArcadeDependency("scale")||"system"!==t.$view.timeZone?(0,nn.OP)(this._compiled,e,t,s):this._readWithDefaultCached(e,t,s)}hasArcadeDependency(e){return this._compiled?.references(e)??!1}_getCacheKey(e){if(!this._compiled?.references("timeProperties"))return this._cacheKey;const{currentStart:t,currentEnd:s}=e.$view.timeProperties;return this._cacheKey+function(e,t){const s=43758.5453*Math.sin(12.9898*e+78.233*t);return s-Math.floor(s)}(t??1,s??1)}_readCached(e,t){if(e.setCache(this._getCacheKey(t)),e.hasCachedValue())return e.getCachedValue();const s=(0,nn.V4)(this._compiled,e,t);return e.setCachedValue(s),s}_readWithDefaultCached(e,t,s){if(e.setCache(this._getCacheKey(t)),e.hasCachedValue())return e.getCachedValue();const i=(0,nn.OP)(this._compiled,e,t,s);return e.setCachedValue(i),i}}var an=s(39516),cn=s(97770),ln=s(18047),un=s(68463),hn=s(30524),dn=s(32730);class pn extends Ar{static async create(e,t){const s=(0,dn.lc)(e);return new pn(e=>s.replaceAll(/{[^}]*}/g,t=>{const s=t.slice(1,-1),i=e.metadata.fieldsIndex.get(s);if(null==i)return t;const r=e.readAttribute(s);return null==r?"":function(e,t){if(null==e)return"";const s=t.domain;if(s)if("codedValue"===s.type||"coded-value"===s.type){const t=e;for(const e of s.codedValues)if(e.code===t)return e.name}else if("range"===s.type){const{max:i,min:r}=(0,un.A5)(t),n=+e;if(null!=r&&null!=i&&r<=n&&n<=i)return s.name}let i=e;return(0,hn.vE)(t)?i=(0,cn.Yq)(i,(0,cn.J2)("short-date")):(0,hn.WA)(t)&&(i=(0,ln.ZV)(+i)),i||""}(r,i)}))}constructor(e){super(),this._evaluator=e}resize(e){}read(e,t){return this._evaluator(e)}readWithDefault(e,t,s){const i=this._evaluator(e);return(0,nn.rZ)(i)?s:i}hasArcadeDependency(e){return!1}}class fn extends Ar{constructor(e,t){super(),this._template=e,this._parts=(0,Ei.gQ)(e.template,t)}resize(e){}read(e,t){return(0,Ei._h)(e,this._parts,this._template.textCase)}readWithDefault(e,t,s){return(0,Ei._h)(e,this._parts,this._template.textCase)}hasArcadeDependency(e){return!1}}class _n extends Ar{constructor(e,t){super(),this._field=e,this._normalizationInfo=t}resize(e){throw new Error("Method not implemented.")}read(e,t){return this._readNormalized(e)}readWithDefault(e,t){return this._readNormalized(e)}hasArcadeDependency(e){return!1}_readNormalized(e){const t=e.readAttribute(this._field);if(null==t)return null;const{normalizationField:s,normalizationTotal:i,normalizationType:r}=this._normalizationInfo,n=e.readAttribute(s);switch(r??"esriNormalizeByField"){case"esriNormalizeByField":return n?n?t/n:void 0:null;case"esriNormalizeByLog":return Math.log(t)*Math.LOG10E;case"esriNormalizeByPercentOfTotal":return i?t/i*100:null}}}var mn=s(73250);const yn=()=>Ie.A.getLogger("esri.views.2d.layers.FeatureLayerView2D"),gn={getAttribute:(e,t)=>e.readAttribute(t)};async function xn(e,t){try{const s=await(0,an.GP)(e,t);return s.isStandardized||yn().error(new i.A("sql-parse-error","expression is not standardized",{where:e})),(t,r)=>{const n=t.readArcadeFeature();try{return s.testFeatureCompiled(n,gn,r.currentUser)}catch(t){return yn().warn(new i.A("sql-runtime-error","Encountered an error when evaluating where clause",{where:e,error:t})),!0}}}catch(t){return yn().warn(new i.A("sql-runtime-error","Encountered an error when evaluating where clause",{where:e,error:t})),e=>!0}}const wn=()=>Ie.A.getLogger("esri.views.2d.layers.features.support.ComputedAttributeStorage"),bn=4294967295;function vn(e,t,s){if(!(e.length>t))for(;e.length<=t;)e.push(s)}class Sn{constructor(e){this._numerics=[],this._strings=[],this._allocatedSize=256,this._bitsets=[],this._instanceIds=[],this._bounds=[],this._dirtyBitset=this.getBitset(this.createBitset()),this.compilationOptions=e}createBitset(){const e=this._bitsets.length;return this._bitsets.push(mn.y.create(this._allocatedSize,tn)),e+1}createDictionaryTemplateField(e,t){return new fn(e,t)}async createComputedField(e,t=!1){if(e.expression)try{if(!this.compilationOptions)throw new Error("InternalError: Compilation options not defined");return t?await pn.create(e.expression,this.compilationOptions):await on.create(e.expression,this.compilationOptions)}catch(t){const s=new i.A("featurelayer","Failed to compile arcade expression",{error:t,expression:e.expression});return wn().error(s),null}if(e.normalizationType||e.normalizationField)return new _n(e.field,e);if(e.field)return new rn(e.field);const s=new i.A("featurelayer","Unable to create computed field. No expression or field found",{info:e});return wn().error(s),null}async createWhereClause(e){return e?xn(e,this.compilationOptions.fields):null}getBitset(e){return this._bitsets[e-1]}getComputedNumeric(e,t){return this.getComputedNumericAtIndex(e&tn,0)}setComputedNumeric(e,t,s){return this.setComputedNumericAtIndex(e&tn,s,0)}getComputedString(e,t){return this.getComputedStringAtIndex(e&tn,0)}setComputedString(e,t,s){return this.setComputedStringAtIndex(e&tn,0,s)}getComputedNumericAtIndex(e,t){const s=e&tn;return this._ensureNumeric(t,s),this._numerics[t][s]}setComputedNumericAtIndex(e,t,s){const i=e&tn;this._ensureNumeric(t,i),this._numerics[t][i]=s}getPackedChunkId(e){const t=e&tn;return this._ensureInstanceId(t),this._instanceIds[t]}setPackedChunkId(e,t){const s=e&tn;this._ensureInstanceId(s),this._instanceIds[s]=t}getComputedStringAtIndex(e,t){const s=e&tn;return this._ensureString(t,s),this._strings[t][s]}setComputedStringAtIndex(e,t,s){const i=e&tn;this._ensureString(t,i),this._strings[t][i]=s}getXMin(e){return this._bounds[4*(e&tn)]}getYMin(e){return this._bounds[4*(e&tn)+1]}getXMax(e){return this._bounds[4*(e&tn)+2]}getYMax(e){return this._bounds[4*(e&tn)+3]}setBounds(e,t,s=!1){const i=e&tn;if(!s&&!this._dirtyBitset.has(e))return this._bounds[4*i]!==bn;this._dirtyBitset.unset(e);const r=t.readGeometryWorldSpace();if(vn(this._bounds,4*i+4,0),!r||!r.coords.length)return this._bounds[4*i]=bn,this._bounds[4*i+1]=bn,this._bounds[4*i+2]=bn,this._bounds[4*i+3]=bn,!1;let n=1/0,o=1/0,a=-1/0,c=-1/0;return r.forEachVertex((e,t)=>{n=Math.min(n,e),o=Math.min(o,t),a=Math.max(a,e),c=Math.max(c,t)}),this._bounds[4*i]=n,this._bounds[4*i+1]=o,this._bounds[4*i+2]=a,this._bounds[4*i+3]=c,!0}getBounds(e,t){const s=this.getXMin(t),i=this.getYMin(t),r=this.getXMax(t),n=this.getYMax(t);return(0,$r.BI)(e,s,i,r,n),s!==bn}_ensureNumeric(e,t){this._numerics[e]||(this._numerics[e]=[]),vn(this._numerics[e],t,0)}_ensureInstanceId(e){vn(this._instanceIds,e,0)}_ensureString(e,t){this._strings[e]||(this._strings[e]=[]),vn(this._strings[e],t,null)}}var In=s(537),Tn=s(58727),kn=s(62660),An=s(86420),Mn=s(61956),Cn=s(30661);class Fn{constructor(e){this._geometryBounds=(0,Y.vt)(),this._idToVisibility=new Map,this._serviceInfo=e}static async create(e){const t=new Fn(e);return await t.update(e.filterJSON,e.spatialReference),t}get hash(){return this._hash}check(e,t){return this._applyFilter(e,t)}invalidate(){this._idToVisibility.forEach((e,t)=>{this._idToVisibility.set(t,0)})}setKnownIds(e){for(const t of e)this._idToVisibility.set(t,1)}setTrue(e){const t=[],s=[],i=new Set(e);return this._idToVisibility.forEach((e,r)=>{const n=!!(1&this._idToVisibility.get(r)),o=i.has(r);!n&&o?t.push(r):n&&!o&&s.push(r),this._idToVisibility.set(r,o?3:0)}),{show:t,hide:s}}createQuery(){const{geometry:e,spatialRel:t,where:s,timeExtent:i,objectIds:r}=this;return Mn.A.fromJSON({geometry:e,spatialRel:t,where:s,timeExtent:i,objectIds:r})}async update(e,t){this._hash=JSON.stringify(e);const s=await(0,Tn.T2)(e,null,t);await Promise.all([this._setGeometryFilter(s),this._setIdFilter(s),this._setAttributeFilter(s),this._setTimeFilter(s)])}async _setAttributeFilter(e){if(!e?.where)return this._clause=null,void(this.where=null);this._clause=await xn(e.where,this._serviceInfo.fieldsIndex),this.where=e.where}_setIdFilter(e){this._idsToShow=e?.objectIds&&new Set(e.objectIds),this._idsToHide=e?.hiddenIds&&new Set(e.hiddenIds),this.objectIds=e?.objectIds}async _setGeometryFilter(e){if(!e?.geometry)return this._spatialQueryOperator=null,this.geometry=null,void(this.spatialRel=null);const t=e.geometry,s=e.spatialRel??"esriSpatialRelIntersects",i=await(0,kn.xt)(s,t,this._serviceInfo.geometryType);(0,In.Rg)(this._geometryBounds,t),this._spatialQueryOperator=i,this.geometry=t,this.spatialRel=s}_setTimeFilter(e){if(this.timeExtent=this._timeOperator=null,e?.timeExtent){if(!this._serviceInfo.timeInfo){const t=new i.A("feature-layer-view:time-filter-not-available","Unable to apply time filter, as layer doesn't have time metadata.",e.timeExtent);return void Ie.A.getLogger("esri.views.2d.layers.features.controllers.FeatureFilter").error(t)}this.timeExtent=e.timeExtent,this._timeOperator=(0,An.I)(this._serviceInfo.timeInfo,e.timeExtent,Cn.Z.Shared)}}_applyFilter(e,t){return this._filterByGeometry(e)&&this._filterById(e)&&this._filterByTime(e)&&this._filterByExpression(e,t)}_filterByExpression(e,t){return!this.where||this._clause(e,t)}_filterById(e){return(!this._idsToHide?.size||!this._idsToHide.has(e.getObjectId()))&&(!this._idsToShow?.size||this._idsToShow.has(e.getObjectId()))}_filterByGeometry(e){if(!this.geometry)return!0;const t=e.readGeometryWorldSpace();return!!t&&this._spatialQueryOperator(t)}_filterByTime(e){return null==this._timeOperator||this._timeOperator(e)}}var En=s(35258),Pn=s(8446);class Rn extends Qr{constructor(e,t){super(e),this.bins=new Map,this.featureCache=new Map,this.done=!1,this._store=t}reset(){this.destroy(),this.done=!1}destroy(){const e=this.subscription.tile.key.level;for(const t of this.featureCache.keys())this._store.releaseDisplayIdForObjectId(`${t}.${e}`);this.bins.clear(),this.featureCache.clear(),this.handledChunks.clear()}get tile(){return this.subscription.tile}*featuresWorldSpace(){for(const e of this.featureCache.values()){const t=e.clone();t.geometry&&(0,Fi.aQ)(t.geometry,this.subscription.tile.transform),yield t}}}class On extends Kr{static async create(e,t,s,i,r){const n=t.metadata.outSpatialReference,o=new Sn({spatialReference:n}),a=await Promise.all(e.fields.map(async e=>Vr.create(o,e))),c=e.featureFilter?await Fn.create({geometryType:t.metadata.geometryType,hasM:!1,hasZ:!1,timeInfo:t.metadata.timeInfo,fieldsIndex:t.metadata.fieldsIndex,spatialReference:n,filterJSON:e.featureFilter}):null;return"geohash"===e.index.type&&await(0,jr.Nk)(n,Gr.A.WGS84),new On(e,c,i,a,n,t,s,r)}constructor(e,t,s,i,r,n,o,a){super(n,o,r,i,a),this._schema=e,this._featureFilter=t,this._arcadeContextInfo=s,this._metadata=En.i.createFeature({geometryType:"esriGeometryPolygon",hasZ:!1,hasM:!1,featureIdInfo:{type:"object-id",fieldName:"aggregateId"},fieldsIndex:new Wr.A(e.fields).toJSON(),globalIdField:null,spatialReference:n.metadata.spatialReference,outSpatialReference:n.metadata.outSpatialReference,subtypeField:null,subtypes:null,timeInfo:null,timeReferenceUnknownClient:null,dateFieldsTimeZone:null,typeIdField:null,types:null})}createState(e){return new Rn(e,this._attributeStore)}async*applyOverrideUpdate(e){for(const e of this._sendStates.values()){e.reset();const t=new Jr(e.subscription,Pn.K.empty(this._source.metadata),!0,!1,{});yield t}}displayMap(e,t,s){const i=new Map(e.map(e=>[t(e),e])),r=[];for(const e of this._sendStates.values())for(const t of e.featuresWorldSpace()){const{objectId:e,displayId:n}=t,o=i.get(e);if(null!=o){const t=s(n,o,e);r.push(t),i.delete(e)}}return r}getDisplayFeatures(e){const t=new Set(e),s=new Set,i=[];for(const e of this._sendStates.values())for(const r of e.featuresWorldSpace())t.has(r.displayId)&&!s.has(r.objectId)&&(r.geometry&&i.push({...(0,Fi.oN)(r,this._metadata.geometryType,!1,!1),displayId:r.displayId}),s.add(r.objectId));return{features:[],aggregates:i,tracks:[]}}getFeatureObjectIdsForAggregate(e){for(const t of this._sendStates.values())for(const s of t.bins.values())if(s.id===e)return Array.from(s.containedObjectIds);return[]}async*updateChunks(){for(const e of this._sendStates.values())yield*this._update(e,this._source)}forEachAggregateWorldSpace(e){const t=new Set;for(const s of this._sendStates.values())for(const i of s.featuresWorldSpace())t.has(i.objectId)||(e(i),t.add(i.objectId))}_createIndexOptions(e){switch(this._schema.index.type){case"geohash":return{type:"geohash",fields:this.aggregateFields,featureFilter:this._featureFilter,geohashLevel:this._schema.index.fixBinLevel,spatialReference:this.spatialReference,arcadeContextInfo:this._arcadeContextInfo,scale:e.scale,sqlOptions:this._sqlOptions};case"grid":{const t=this._schema.index.fixedBinLevel,s=null!=t?e.tileInfoView.getLODInfoAt(t).scale:e.scale;return{type:"grid",fields:this.aggregateFields,cellSize:this._schema.index.size,featureFilter:this._featureFilter,spatialReference:this.spatialReference,arcadeContextInfo:this._arcadeContextInfo,scale:s,sqlOptions:this._sqlOptions}}}}async*_update(e,t){const{handledChunks:s,subscription:i,bins:r,featureCache:n}=e,o=i.tile;if(e.done)return;for(const i of t.chunks()){if(s.has(i.chunkId))continue;s.add(i.chunkId);const t=i.queryInfo;if("tileId"in t){const e=new w.A(t.tileId);if(e.level!==o.level||e.world!==o.key.world)continue}i.getAggregateIndex(this._createIndexOptions(e.tile)).putBounded(r,e.tile.extent,e.tile.resolution)}const a=[],c=i.tile.transform,l=i.tile.key.level;for(const e of r.values()){let t=n.get(e.id);if(t)t.attributes=e.getAttributes();else{const s=e.getGeometry(this.spatialReference,c);t=new Ur.Om(s,e.getAttributes(),null,e.id),s||(t.centroid=e.getGeometricCentroid(this.spatialReference,c)),t.displayId=this._attributeStore.createDisplayIdForObjectId(`${t.objectId}.${l}`),n.set(e.id,t)}a.push(t)}this.events.emit("changed"),e.done=!t.updateTracking.updating;const u=Pn.K.fromOptimizedFeatures(a,this._metadata,c),h=u.getCursor(),d=e.subscription.tile.createArcadeEvaluationOptions(this._arcadeContextInfo);for(;h.next();)this._attributeStore.setAttributeData(h.getDisplayId(),h,d,this._sqlOptions);const p=new en(e.subscription,u,[],e.done,{});yield p}}var zn=s(75538),Ln=s(68974);class Dn{constructor(e,t){this.inner=e,this.displayId=t}}class Nn extends Qr{constructor(e){super(e),this.didSend=!1,this.done=!1}}class qn{constructor(e,t,s,i,r){this._level=e,this._scale=t,this._indexOptions=s,this._clusterRadius=i,this._store=r,this._cells=new Map,this._handledChunks=new Set,this._statistics=new Map,this._clusters=new Map}destroy(){this._clearClusters()}_clearClusters(){for(const e of this._clusters.values())this._store.releaseDisplayIdForObjectId(e.inner.id);this._clusters.clear()}*aggregatesWorldSpace(){for(const e of this._clusters.values()){const t=e.inner.getCentroid(null),s=new Ur.Om(t,e.inner.getAttributes(),null,e.inner.id,e.displayId);yield s}}clusters(){return this._clusters.values()}updateChunks(e,t){let s=!1;for(const t of e){const e=t.queryInfo;"tileId"in e&&new w.A(e.tileId).level!==this._level||this._handledChunks.has(t.normalizedChunkId)||(this._handledChunks.add(t.normalizedChunkId),s=!0,t.getAggregateIndex({...this._indexOptions,scale:this._scale}).put(this._cells))}const i={xMin:1/0,yMin:1/0,xMax:-1/0,yMax:-1/0},r=(0,Ln.p)(this._indexOptions.spatialReference,this._scale),n=this._indexOptions.cellSize;for(const{subscription:e}of t){const t=e.tile.bounds,s=Math.floor(t[0]*r/n),o=Math.floor(t[1]*r/n),a=Math.ceil(t[2]*r/n),c=Math.ceil(t[3]*r/n);i.xMin=Math.min(i.xMin,s),i.yMin=Math.min(i.yMin,o),i.xMax=Math.max(i.xMax,a),i.yMax=Math.max(i.yMax,c)}return null!=this._lastCellBounds&&i.xMin===this._lastCellBounds.xMin&&i.yMin===this._lastCellBounds.yMin&&i.yMin===this._lastCellBounds.yMin&&i.yMax===this._lastCellBounds.yMax||(s=!0,this._lastCellBounds=i),s&&this._clusterCells(i),s}async updateStatistics(e){let t=!1;for(const e of this._clusters.values())e.inner.count>1&&(t=this._updateAggregateStatistics(this._statistics,e.inner)||t);if(t){const t=Array.from(this._statistics.entries()).map(([e,t])=>({fieldName:e,minValue:t.minValue,maxValue:t.maxValue}));await e.container.updateStatistics(this._level,t)}}createAggregateFeatures(e,t){const s=e.subscription,i=[],r=s.tile.transform;for(const e of this._clusters.values()){let t=e.inner.getCentroidX(r);const n=e.inner.getCentroidY(r),o=s.tile.lod,a=o.wrap?o.worldSize[0]:null,c=1===e.inner.count?e.inner.firstObjectId:e.inner.id,l=e.displayId;if(null!=a)if(1===a){const s=new Xt.A([],[t,n]),r=new Ur.Om(s,e.inner.getAttributes(),null,c,l);r.geometry.coords[0]-=p.CQ,i.push(r);const o=new Xt.A([],[t,n]),a=new Ur.Om(o,e.inner.getAttributes(),null,c,l);a.geometry.coords[0]+=p.CQ,i.push(a)}else t>p.CQ+p.CQ/2?t-=a*p.CQ:t<-256&&(t+=a*p.CQ);if(t<p.CQ+128&&t>=-128&&n<p.CQ+128&&n>=-128){const s=new Xt.A([],[t,n]),r=new Ur.Om(s,e.inner.getAttributes(),null,c,l);i.push(r)}}return Pn.K.fromOptimizedFeatures(i,t,s.tile.transform)}_clusterCells(e){let t=Array.from(this._cells.values());t=t.sort((e,t)=>t.count-e.count);const s=[];for(const e of this._clusters.values())s.push(e.inner.id);this._clusters.clear();const i=this._clusterRadius*(1/(0,Ln.p)(this._indexOptions.spatialReference,this._scale)),r=1+this._clusterRadius/this._indexOptions.cellSize,n=new Set;for(const s of t){if(n.has(s.id))continue;if(s.gridX<e.xMin||s.gridX>e.xMax||s.gridY<e.yMin||s.gridY>e.yMax)continue;const t=this._store.createDisplayIdForObjectId(s.id),o=new Dn(s.clone(),t);n.add(s.id),this._clusters.set(s.id,o);const a=s.centroidXWorld,c=s.centroidYWorld;for(let e=s.gridY-r;e<=s.gridY+r;e++)for(let t=s.gridX-r;t<=s.gridX+r;t++){if(e===s.gridY&&t===s.gridX)continue;const r=this._cells.get(zn.L.createId(t,e));if(!r||n.has(r.id))continue;const l=Math.abs(r.centroidXWorld-a),u=Math.abs(r.centroidYWorld-c);l<i&&u<i&&(o.inner.merge(r),n.add(r.id))}}for(const e of s)this._store.releaseDisplayIdForObjectId(e)}_updateAggregateStatistics(e,t){let s=!1;for(const i of t.statistics.values()){if("esriFieldTypeString"===i.field.type)continue;const t=i.value,r=i.field,n=e.get(r.name);if(n){const{minValue:e,maxValue:i}=n,r=Math.min(n.minValue,t),o=Math.max(n.maxValue,t);e===r&&i===o||(n.minValue=r,n.maxValue=o,s=!0);continue}e.set(r.name,{minValue:t,maxValue:t}),s=!0}return s}}class Bn extends Kr{static async create(e,t,s,i,r,n,o,a){const c=s.metadata.outSpatialReference,l=new Sn({spatialReference:c}),u={type:"grid",fields:await Promise.all(t.fields.map(async e=>Vr.create(l,e))),spatialReference:c,featureFilter:t.featureFilter?await Fn.create({geometryType:s.metadata.geometryType,hasM:!1,hasZ:!1,timeInfo:s.metadata.timeInfo,fieldsIndex:s.metadata.fieldsIndex,spatialReference:c,filterJSON:t.featureFilter}):null,cellSize:t.clusterRadius/4,arcadeContextInfo:r,sqlOptions:n};return new Bn(e,t.clusterRadius,u,t.fields,s,i,n,o,a)}constructor(e,t,s,i,r,n,o,a,c){super(r,n,s.spatialReference,s.fields,o),this._connection=e,this._clusterRadius=t,this._indexOptions=s,this._requiredLevel=a,this._requiredScale=c,this._cellsPerScale=new Map,this._metadata=En.i.createFeature({geometryType:"esriGeometryPoint",hasZ:!1,hasM:!1,featureIdInfo:{type:"object-id",fieldName:"aggregateId"},fieldsIndex:new Wr.A([...i,...this._source.metadata.fieldsIndex.fields,{name:"aggregateId",alias:"aggregateId",type:"esriFieldTypeOID"}]).toJSON(),globalIdField:null,spatialReference:r.metadata.spatialReference,outSpatialReference:r.metadata.outSpatialReference,subtypeField:null,subtypes:null,timeInfo:null,timeReferenceUnknownClient:null,dateFieldsTimeZone:null,typeIdField:null,types:null})}get enablePixelBuffering(){return!1}invalidate(){super.invalidate();for(const e of this._cellsPerScale.values())e.destroy();this._cellsPerScale.clear()}updateRequiredLevel(e,t){this._requiredLevel=e,this._requiredScale=t}createState(e){return new Nn(e)}async*applyOverrideUpdate(e){for(const e of this._cellsPerScale.values())e.destroy();this._cellsPerScale.clear();for(const e of this._sendStates.values())e.done=!1}displayMap(e,t,s){const i=new Map(e.map(e=>[t(e),e])),r=[],n=this._getClusterState(this._requiredLevel,this._requiredScale);for(const e of n.clusters()){const t=i.get(e.inner.id);if(null!=t){const n=s(e.displayId,t,e.inner.id);r.push(n),i.delete(e.inner.id);continue}if(1===e.inner.count){const{firstObjectId:t}=e.inner,n=t?i.get(t):null;if(null!=n){const o=s(e.displayId,n,t);r.push(o),i.delete(t)}}}return r}getDisplayFeatures(e){const t=new Set(e),s=new Set,i=[],r=[],n=this._getClusterState(this._requiredLevel,this._requiredScale);for(const e of n.aggregatesWorldSpace())if(t.has(e.displayId)&&!s.has(e.displayId)){const t=(0,Fi.oN)(e,this._metadata.geometryType,!1,!1);if(s.add(e.displayId),1===t.attributes.cluster_count){i.push({...t,displayId:e.displayId});continue}r.push({...t,displayId:e.displayId})}return{features:i,aggregates:r,tracks:[]}}getFeatureObjectIdsForAggregate(e){const t=this._getClusterState(this._requiredLevel,this._requiredScale);for(const s of t.clusters())if(s.inner.id===e)return Array.from(s.inner.containedObjectIds);return[]}async*updateChunks(){const e=this._source.chunks();if(!e.length)return;const t=this._getClusterState(this._requiredLevel,this._requiredScale),s=Array.from(this._sendStates.values()).filter(e=>e.subscription.tile.level===this._requiredLevel);if(t.updateChunks(e,s)||!this._source.updateTracking.updating)for(const e of s)e.subscription.tile.level===this._requiredLevel&&(e.didSend=!1,e.done=!1);const i=Array.from(this._sendStates.values()).filter(e=>e.done).map(e=>e.subscription.tile.key),r=new Set(i);for(const e of this._sendStates.values()){if(this._source.updateTracking.updating){if(i.some(t=>t.containsChild(e.subscription.tile.key)))continue;if(e.subscription.tile.key.getChildKeys().every(e=>r.has(e)))continue}e.didSend||e.subscription.tile.level!==this._requiredLevel||(e.didSend=!0,yield*this._update(e,t,this._source))}await t.updateStatistics(this._connection)}forEachAggregateWorldSpace(e){if(null==this._requiredLevel||null==this._requiredScale)return;const t=this._getClusterState(this._requiredLevel,this._requiredScale);for(const s of t.aggregatesWorldSpace())e(s)}_getClusterState(e,t){if(null==e||null==t)throw new Error("InternalError: Level and scale must be defined");let s=this._cellsPerScale.get(t);return s||(s=new qn(e,t,this._indexOptions,this._clusterRadius,this._attributeStore),this._cellsPerScale.set(t,s)),s}async*_update(e,t,s){if(e.done)return;const i=t.createAggregateFeatures(e,this._metadata);this.events.emit("changed"),e.done=!s.updateTracking.updating;const r=i.getCursor(),n=e.subscription.tile.createArcadeEvaluationOptions(this._indexOptions.arcadeContextInfo);for(;r.next();)this._attributeStore.setAttributeData(r.getDisplayId(),r,n,this._sqlOptions);const o=new Jr(e.subscription,i,!0,e.done,{});yield o}}var Gn=s(5162),Un=s(9012);class jn extends Qr{}class Wn extends Xr{constructor(e,t,s,i){super(e,t,i),this._arcadeContextInfo=s,this.handledChunks=new Set,this.handledChunksForIdCreation=new Set,this.handledChunksForAttributeData=new Set,this._streamLayerDeferredObjectIdsToRemove=[]}destroy(){super.destroy();for(const e of this._source.chunks())this._cleanupChunkIds(e)}invalidateAttributeData(e){this.handledChunksForAttributeData.clear(),this._arcadeContextInfo=e,null!=this._evalOptions&&(this._evalOptions=(0,Un.N)(this._evalOptions.$view.scale,e))}onSubscribe(e){super.onSubscribe(e),this._evalOptions=e.tile.createArcadeEvaluationOptions(this._arcadeContextInfo)}createState(e){return new jn(e)}get aggregateQueryEngine(){return null}displayMap(e,t,s){const i=new Map(e.map(e=>[t(e),e])),r=[];for(const e of this._source.chunks()){const t=e.reader.getCursor();for(;t.next();){const e=t.getObjectId(),n=t.getDisplayId(),o=i.get(e);if(null!=o){const t=s(n,o,e);r.push(t),i.delete(e)}}}return r}getDisplayFeatures(e){const t=new Set(e),s=new Set,i=[];for(const e of this._source.chunks()){const r=e.reader.getCursor();for(;r.next();){const e=r.getObjectId(),n=r.getDisplayId();t.has(n)&&!s.has(e)&&(i.push({...r.readLegacyFeatureWorldSpace(),displayId:n}),s.add(e))}}return{features:i,aggregates:[],tracks:[]}}async*applyOverrideUpdate(e){const t=[];for(const s of e.modified.values()){const e=this._attributeStore.createDisplayIdForObjectId(s.objectId);s.displayId=e,t.push(e)}const s=Pn.K.fromOptimizedFeatures(Array.from(e.modified.values()),this._source.metadata).getCursor();for(;s.next();)this._attributeStore.setAttributeData(s.getDisplayId(),s,this._evalOptions,this._sqlOptions);const i=[];for(const t of e.removed){const e=this._attributeStore.getDisplayIdForObjectId(t);null!=e&&i.push(e)}(0,n.A)("esri-2d-update-debug")&&console.debug("FeatureUpdateStrategy.applyLocalEdit",{message:e,modifiedDisplayIds:t,removedDisplayIds:i});const r=Gn.KN.fromFeatures(Array.from(e.modified.values()),this._source.metadata);this.handledChunks.add(r.chunkId),this.handledChunksForAttributeData.add(r.chunkId),this.handledChunksForIdCreation.add(r.chunkId);for(const e of this._sendStates.values())e.handledChunks.add(r.chunkId),yield new en(e.subscription,null,t,!1,r.queryInfo);for(const e of this._sendStates.values()){const t=r.getTileReader(e.subscription.tile);yield new en(e.subscription,t,i,!1,r.queryInfo)}for(const t of e.removed)this._attributeStore.releaseDisplayIdForObjectId(t)}async*updateChunks(){if(this._source.chunks().length){this._updateAttributeData();for(const e of this._sendStates.values())yield*this._update(e)}}removeChunks(e){for(const t of e)this.handledChunks.delete(t.chunkId),this.handledChunksForAttributeData.delete(t.chunkId),this._cleanupChunkIds(t)}afterUpdateChunks(){for(const e of this._streamLayerDeferredObjectIdsToRemove)this._attributeStore.releaseDisplayIdForObjectId(e);this._streamLayerDeferredObjectIdsToRemove=[]}_cleanupChunkIds(e){if(this.handledChunksForIdCreation.has(e.chunkId)){const t=e.reader.getCursor();for(;t.next();){const e=t.getObjectId();this._source.isStream?this._streamLayerDeferredObjectIdsToRemove.push(e):this._attributeStore.releaseDisplayIdForObjectId(e)}this.handledChunksForIdCreation.delete(e.chunkId)}}_updateAttributeData(){for(const e of this._source.chunks()){const{chunkId:t,reader:s}=e;if(!this.handledChunksForIdCreation.has(t)){this.handledChunksForIdCreation.add(t);const e=s.getCursor();for(;e.next();){const t=this._attributeStore.createDisplayIdForObjectId(e.getObjectId());e.setDisplayId(t)}}}for(const e of this._source.chunks())if(this._attributeStore.referencesScale()||!this.handledChunksForAttributeData.has(e.chunkId)){this.handledChunksForAttributeData.add(e.chunkId);const t=e.reader.getCursor();for(;t.next();){const e=t.getDisplayId();this._attributeStore.setAttributeData(e,t,this._evalOptions,this._sqlOptions)}}}*_update(e){const{subscription:t,handledChunks:s}=e;for(const i of this._source.chunks()){const{chunkId:r}=i;if(s.has(r)||!this.handledChunksForIdCreation.has(r)||!this.handledChunksForAttributeData.has(r))continue;s.add(r);const n=i.getTileReader(t.tile);n&&(yield new Jr(e.subscription,n,!1,i.end,i.queryInfo))}}}var Vn=s(77085),Yn=s(5808),$n=s(17136),Hn=s(89056),Zn=s(92029),Qn=s(52350);let Xn;class Kn{constructor(e,t,s,i,r){this.chunkIndex=e,this.featureIndex=t,this.objectId=s,this.displayId=i,this.time=r}}class Jn{static getOid(e){return re.xq+e}constructor(e,t,s,i,r,n,o,a){this._schema=e,this.trackId=t,this.objectId=s,this.displayId=i,this._fields=r,this._spatialReference=n,this._metadata=o,this._isStream=a,this._maxDisplayDuration=this._schema.maxDisplayDuration>0?this._schema.maxDisplayDuration:1/0,this._maxDisplayObservationsPerTrack=this._schema.maxDisplayObservationsPerTrack>=1?this._schema.maxDisplayObservationsPerTrack:1/0,this._observationRecords=[],this._nextObservationRecords=[],this._trackLinePath=[],this._bounds=[],this._trackLineGeometry=new Xt.A}get _trackLineAttributes(){const e={...this._latestObservationFeature?.attributes,aggregateId:this.objectId,[re.EA]:0};if(null!=this._statistics)for(const t of this._statistics.values())e[t.field.name]=t.value;return e}get _startTimeField(){return this._metadata.timeInfo?.startTimeField}get length(){return this._observationRecords.length}*observations(){yield*this._observationRecords}*previousObservations(){for(let e=0;e<this._observationRecords.length-1;e++)yield this._observationRecords[e]}get latestObservationFeature(){return this._latestObservationFeature}get latestObservationRecord(){return this._latestObservationRecord}stageObservation(e,t){this._nextObservationRecords.push(new Kn(e,t.getIndex(),t.getObjectId(),t.getDisplayId(),null!=this._startTimeField?t.readAttributeAsTimestamp(this._startTimeField):null))}commitObservations(e,t,s){const i=new Set(this._nextObservationRecords.map(e=>e.objectId)),r=this._observationRecords.filter(e=>!i.has(e.objectId)).map(e=>e.objectId);let n,o;switch(this._observationRecords=[],this._trackLinePath=[],this._isStream||null==this._startTimeField||this._nextObservationRecords.sort((e,t)=>{const s=e.time,i=t.time;return null!=s&&null!=i?s-i:0}),this._schema.timeField){case"startTimeField":n=this._metadata.timeInfo?.startTimeField;break;case"endTimeField":n=this._metadata.timeInfo?.endTimeField;break;case"timeReceived":n=this._isStream?re.Aw:null}o=this._isStream?s?.end??Date.now():s?.end??-1/0;const a=t.map(e=>e.reader.getCursor());let c;for(let e=this._nextObservationRecords.length-1;e>=0&&!(this._observationRecords.length>=this._maxDisplayObservationsPerTrack);e--){const t=this._nextObservationRecords[e],s=a[t.chunkIndex];(0,_.Lw)(s),s.setIndex(t.featureIndex);const i=null!=n?s.readAttributeAsTimestamp(n):null;(null!=i?o-i:0)>=this._maxDisplayDuration||(this._commitObservation(t,s),c??=t)}if(null!=c){const{chunkIndex:t,featureIndex:s}=c,i=`${c.objectId}.latest`,n=e.createDisplayIdForObjectId(i),o=a[t];(0,_.Lw)(o),o.setIndex(s);const l=new Ur.Om(o.readGeometryWorldSpace(),{...o.readAttributes(),[re.EA]:1},null,i,n);this._latestObservationFeature&&r.push(this._latestObservationFeature.objectId),this._latestObservationFeature=l,this._latestObservationRecord=c}else this._latestObservationFeature=null;return this._trackLineGeometry=function(e,t){if(e.length<2)return(0,Fi.Ap)({paths:[e]},!1,!1);if(t.isWrappable){let s=!1;for(let i=1;i<e.length;i++){const r=e[i][0],n=(0,$n.O7)(r,e[i-1][0],t);r!==n&&(e[i][0]=n,s=!0)}if(s){const s=(0,Hn.b3)({paths:[e],spatialReference:t});if(null!=s)return(0,Fi.Ap)({paths:s.paths},!1,!1)}return(0,Fi.Ap)({paths:[e]},!1,!1)}const s=Xn.fromGeometryToGXGeometry({hasM:!1,hasZ:!1,paths:[e]}),i=Xn.fromSpatialReference(t);if(null!=i){const e=(0,Vn.g7)(s,1e6,i,Yn.O.geodesic);if(null!=e){const t=Xn.toGeometry(e,i);if(null!=t&&"paths"in t)return(0,Fi.Ap)({paths:t.paths},!1,!1)}}return(0,Fi.Ap)({paths:[e]},!1,!1)}(this._trackLinePath,this._spatialReference),this._bounds=function(e){const{lengths:t,coords:s}=e;if(!t.length)return[(0,Y.Ie)()];const i=[];let r=0;for(let e=0;e<t.length;e++){const n=t[e],o=(0,Y.Ie)();i.push(o);for(let e=0;e<n;e++){const t=s[2*(e+r)],i=s[2*(e+r)+1];(0,Y.tK)(o,[t,i])}r+=n}return i}(this._trackLineGeometry),this._nextObservationRecords=[],r}updateStatistics(e,t){this._statistics=Zn.o.create(this._fields);const s=e.map(e=>e.reader.getCursor());for(const{chunkIndex:e,featureIndex:i}of this._observationRecords){const r=s[e];(0,_.Lw)(r),r.setIndex(i),this._statistics.insert(r,t)}}overlapsTile(e){for(const t of this._bounds)if((0,Y.$9)(t,e.bounds,32))return!0;return!1}getLatestObservationFeatureForTile(e){if(null==this._latestObservationFeature)return null;const{objectId:t,displayId:s,geometry:i,attributes:r}=this._latestObservationFeature,n=(0,Fi.Nl)(i,this._metadata.geometryType,e.subscription.tile.transform)??new Xt.A,o=(0,Y.fA)(1/0,1/0,-1/0,-1/0);return function(e,t){const{coords:s,lengths:i}=e;if(!i.length)return void t(s[0],s[1]);let r=0;for(let e=0;e<i.length;e++){const n=i[e];let o=0,a=0;for(let e=0;e<n;e++)o+=s[2*(e+r)],a+=s[2*(e+r)+1],t(o,a);r+=n}}(n,(e,t)=>(0,Y.tK)(o,[e,t])),(0,Y.HY)(o,(0,Y.fA)(0,0,p.CQ,p.CQ))?new Ur.Om(n,r,null,t,s):null}getTrackLineFeatureForTile(e){const t=(0,Fi.Nl)(this._trackLineGeometry,"esriGeometryPolyline",e.subscription.tile.transform)??new Xt.A;return new Ur.Om(t,this._trackLineAttributes,null,this.objectId,this.displayId)}getTrackLineOptimizedFeature(){return new Ur.Om(this._trackLineGeometry,this._trackLineAttributes,null,this.objectId,this.displayId)}getTrackLineDisplayFeature(){const{_trackLineGeometry:e,_trackLineAttributes:t,displayId:s}=this;return{geometry:(0,Fi.zv)(e,"esriGeometryPolyline",!1,!1),attributes:t,displayId:s}}_commitObservation(e,t){const s=t.readCentroidWorldSpace();let i=s?.coords[0],r=s?.coords[1];null==s&&(i=t.readXWorldSpace(),r=t.readYWorldSpace()),null!=i&&null!=r&&(this._observationRecords.unshift(e),this._trackLinePath.unshift([i,r]))}}class eo extends Qr{constructor(e){super(e),this.done=!1}}class to extends Kr{static async create(e,t,i,r,n){const o=t.metadata.outSpatialReference,a=new Sn({spatialReference:o}),c=await Promise.all(e.fields.map(async e=>Vr.create(a,e))),l=e.featureFilter?await Fn.create({geometryType:t.metadata.geometryType,hasM:!1,hasZ:!1,timeInfo:t.metadata.timeInfo,fieldsIndex:t.metadata.fieldsIndex,spatialReference:o,filterJSON:e.featureFilter}):null;return o.isWrappable||(0,Vn.s1)()||await Promise.all([Promise.all([s.e(3661),s.e(1878),s.e(8885),s.e(5756),s.e(3299),s.e(8125)]).then(s.bind(s,78125)),Promise.all([s.e(3661),s.e(1878),s.e(8885),s.e(5756),s.e(3299)]).then(s.bind(s,83299)),(0,Vn.Hh)()]).then(([e,t,s])=>{Xn={fromGeometryToGXGeometry:t.fromGeometryToGXGeometry,toGeometry:t.toGeometry,fromSpatialReference:e.fromSpatialReference}}),new to(e,t,i,o,c,l,r,n)}constructor(e,t,s,i,r,n,o,a){super(t,s,i,r,a),this._schema=e,this._featureFilter=n,this._arcadeContextInfo=o,this._tracks=new Map,this._handledChunks=new Set,this._metadata=t.metadata.weakCloneWithAdditionalFields([{name:re.EA,alias:"trackPart",type:"esriFieldTypeSmallInteger"}]),this._trackLineMetadata=En.i.createFeature({geometryType:"esriGeometryPolyline",featureIdInfo:{type:"object-id",fieldName:"aggregateId"},fieldsIndex:{fields:[...this._source.metadata.fieldsIndex.fields,...this.aggregateFields,{name:re.EA,alias:"trackPart",type:"esriFieldTypeSmallInteger"},{name:"aggregateId",alias:"aggregateId",type:"esriFieldTypeOID"}],timeZoneByFieldName:null},globalIdField:null,spatialReference:t.metadata.spatialReference,outSpatialReference:t.metadata.outSpatialReference,subtypeField:null,subtypes:null,timeInfo:t.metadata.timeInfo,timeReferenceUnknownClient:null,dateFieldsTimeZone:null,typeIdField:null,types:null,hasZ:!1,hasM:!1})}destroy(){super.destroy(),this._clear()}get _isStream(){return this._source.isStream}get enablePixelBuffering(){return!0}get isAggregate(){return!1}requiresInvalidation(){return!0}invalidate(){super.invalidate(),this._clear()}createState(e){return new eo(e)}async*applyOverrideUpdate(e){Ie.A.getLogger("esri.views.2d.layers.features.processor.TrackStrategy").error("Applying override to tracks is not supported")}displayMap(e,t,s){const i=new Map(e.map(e=>[t(e),e])),r=[];for(const e of this._tracks.values()){const t=i.get(e.objectId);if(null!=t){const n=s(e.displayId,t,e.objectId);r.push(n),i.delete(e.objectId);continue}const n=e.latestObservationFeature;if(n?.objectId){const e=i.get(n.objectId);if(null!=e){const t=s(n.displayId,e,n.objectId);r.push(t),i.delete(n.objectId);continue}}for(const t of e.observations()){const e=i.get(t.objectId);if(null!=e){const n=s(t.displayId,e,t.objectId);r.push(n),i.delete(t.objectId)}}}return r}getDisplayFeatures(e){const t=new Set(e),s=[],i=[],r=this._source.chunks().map(e=>e.reader.getCursor());for(const e of this._tracks.values()){if(t.has(e.displayId)&&i.push(e.getTrackLineDisplayFeature()),null!=e.latestObservationFeature&&t.has(e.latestObservationFeature.displayId)){const{displayId:t,chunkIndex:i,featureIndex:n}=e.latestObservationRecord,o=r[i];o.setIndex(n),s.push({displayId:t,...o.readLegacyFeatureWorldSpace()})}for(const{displayId:i,chunkIndex:n,featureIndex:o}of e.observations())if(t.has(i)){const e=r[n];e.setIndex(o),s.push({displayId:i,...e.readLegacyFeatureWorldSpace()})}}return{features:s,aggregates:[],tracks:i}}getFeatureObjectIdsForAggregate(e){for(const t of this._tracks.values())if(t.objectId===e)return Array.from(t.observations(),e=>e.objectId);return[]}async*updateChunks(){0===this._handledChunks.size&&this._rebuildTracks();for(const e of this._sendStates.values())yield*this._update(e)}forEachAggregateWorldSpace(e){for(const t of this._tracks.values())e(t.getTrackLineOptimizedFeature())}_clear(){for(const e of this._source.chunks())if(this._handledChunks.has(e.chunkId)){const t=e.reader.getCursor();for(;t.next();){const e=t.getObjectId();this._attributeStore.releaseDisplayIdForObjectId(e)}}this._handledChunks.clear();for(const e of this._tracks.values())this._removeTrack(e);this._tracks.clear()}_rebuildTracks(){const e=this._source.chunks();if(!e.length)return;const t=this._metadata.timeInfo?.trackIdField;if(null==t)return;const s=new Set;for(let i=0;i<e.length;i++){const r=e[i];if(this._handledChunks.has(r.chunkId))continue;this._handledChunks.add(r.chunkId);const n=r.reader.getCursor();for(;n.next();){const e=n.getObjectId();n.setDisplayId(this._attributeStore.createDisplayIdForObjectId(e));const r=n.readAttribute(t);if(null!=r&&null!=e&&(null===this._featureFilter||this._featureFilter.check(n,this._sqlOptions))){if(!this._tracks.has(r)){const e=Jn.getOid(r),t=this._attributeStore.createDisplayIdForObjectId(e),s=new Jn(this._schema,r,e,t,this.aggregateFields,this.spatialReference,this._source.metadata,this._isStream);this._tracks.set(r,s)}this._tracks.get(r).stageObservation(i,n),s.add(r)}}}for(const t of this._tracks.values())if(s.has(t.trackId)){const s=t.commitObservations(this._attributeStore,e,this._featureFilter?.timeExtent);for(const e of s)this._attributeStore.releaseDisplayIdForObjectId(e);t.updateStatistics(e,(0,Un.N)(1,this._arcadeContextInfo))}else this._removeTrack(t)}_removeTrack(e){this._tracks.delete(e.trackId),this._attributeStore.releaseDisplayIdForObjectId(e.objectId),null!=e.latestObservationFeature&&this._attributeStore.releaseDisplayIdForObjectId(e.latestObservationFeature.objectId)}*_update(e){if(e.done)return;e.done=!this._source.updateTracking.updating;const t=[],s=[];for(const i of this._tracks.values())if(i.length>0){if(this._schema.showLatestObservation){const s=i.getLatestObservationFeatureForTile(e);null!=s&&t.push(s)}this._schema.showTrackLine&&i.overlapsTile(e.subscription.tile)&&s.push(i.getTrackLineFeatureForTile(e))}const i=Pn.K.fromOptimizedFeatures(t,this._metadata,e.subscription.tile.transform),r=Pn.K.fromOptimizedFeatures(s,this._trackLineMetadata,e.subscription.tile.transform);let n=[];if(this._schema.showPreviousObservations){const t=this._source.chunks().map(()=>[]);for(const e of this._tracks.values())for(const{chunkIndex:s,featureIndex:i}of e.previousObservations())t[s].push(i);n=this._source.chunks().map((s,i)=>{const r=s.getTileReader(e.subscription.tile);if(null==r)return null;const n=Qn.e.from(r,t[i]);return n.setProcessorAttributes({[re.EA]:2}),"esriGeometryPoint"!==n.geometryType&&null!=n.getInTransform()||n.setTransformForDisplay(e.subscription.tile.transform),n}).filter(Ir.Ru)}this.events.emit("changed");const o=e.subscription.tile.createArcadeEvaluationOptions(this._arcadeContextInfo),a=r.getCursor();for(;a.next();)this._attributeStore.setAttributeData(a.getDisplayId(),a,o,this._sqlOptions);for(const e of n){const t=e.getCursor();for(;t.next();)this._attributeStore.setAttributeData(t.getDisplayId(),t,o,this._sqlOptions)}const c=i.getCursor();for(;c.next();)this._attributeStore.setAttributeData(c.getDisplayId(),c,o,this._sqlOptions);yield new Jr(e.subscription,r,!1,!1,{});for(const t of n)yield new Jr(e.subscription,t,!1,!1,{});yield new Jr(e.subscription,i,!1,e.done,{})}}new Map;var so=s(69397);class io{constructor(e){this.data=e,this._referenceCount=0}static{this.estimatedMemory=20}increment(){this._referenceCount+=1}decrement(){this._referenceCount-=1}empty(){return 0===this._referenceCount}}class ro{constructor(){this._freeIdsGenerationA=[],this._freeIdsGenerationB=[],this._idCounter=1,this._freeIds=this._freeIdsGenerationA,this._objectIdToDisplayId=new Map}get usedMemory(){let e=0;return e+=(0,so.Qf)(this._freeIdsGenerationA),e+=(0,so.Qf)(this._freeIdsGenerationB),e+=this._objectIdToDisplayId.size*(io.estimatedMemory+8),e}createIdForObjectId(e){let t=this._objectIdToDisplayId.get(e);return t?t.increment():(t=new io(function(e){return(0|e)>>>0}(this._getFreeId())),t.increment(),this._objectIdToDisplayId.set(e,t)),t.data}releaseIdForObjectId(e){const t=this._objectIdToDisplayId.get(e);t&&(t.decrement(),t.empty()&&(this._objectIdToDisplayId.delete(e),this._freeIds.push(t.data)))}getDisplayIdForObjectId(e){const t=this._objectIdToDisplayId.get(e);return null!=t?t.data:null}releaseAll(){for(const e of this._objectIdToDisplayId.values())this._freeIds.push(e.data);this._objectIdToDisplayId.clear()}incrementGeneration(){this._freeIds=this._freeIds===this._freeIdsGenerationA?this._freeIdsGenerationB:this._freeIdsGenerationA}_getFreeId(){return this._freeIds.length?this._freeIds.pop():this._idCounter++}}const no=()=>Ie.A.getLogger("esri.views.layers.2d.features.support.AttributeStore"),oo=(no(),()=>null),ao=(0,n.A)("esri-shared-array-buffer");(0,n.A)("esri-atomics");class co{constructor(e,t,s){this.size=0,this.texelSize=4,this.dirtyStart=0,this.dirtyEnd=0;const{pixelType:i,layout:r,textureOnly:n}=t;this.textureOnly=n||!1,this.pixelType=i,this.layout=r,this._resetRange(),this.size=e,this.isLocal=s,n||(this.data=this._initData(i,e))}get usedMemory(){return this.data?.byteLength??0}get buffer(){return this.data?.buffer}unsetComponentAllTexels(e,t){const s=this.data;for(let i=0;i<this.size*this.size;i++)s[i*this.texelSize+e]&=~t;this.dirtyStart=0,this.dirtyEnd=this.size*this.size-1}setComponentAllTexels(e,t){const s=this.data;for(let i=0;i<this.size*this.size;i++)s[i*this.texelSize+e]|=255&t;this.dirtyStart=0,this.dirtyEnd=this.size*this.size-1}setComponent(e,t,s){const i=this.data;for(const r of s)i[r*this.texelSize+e]|=t,this.dirtyStart=Math.min(this.dirtyStart,r),this.dirtyEnd=Math.max(this.dirtyEnd,r)}setComponentTexel(e,t,s){this.data[s*this.texelSize+e]|=t,this.dirtyStart=Math.min(this.dirtyStart,s),this.dirtyEnd=Math.max(this.dirtyEnd,s)}unsetComponentTexel(e,t,s){this.data[s*this.texelSize+e]&=~t,this.dirtyStart=Math.min(this.dirtyStart,s),this.dirtyEnd=Math.max(this.dirtyEnd,s)}getData(e,t){const s=sn(e);return this.data[s*this.texelSize+t]}setData(e,t,s){const i=sn(e),r=1<<t;0!==(this.layout&r)?null!=this.data&&(this.data[i*this.texelSize+t]=s,this.dirtyStart=Math.min(this.dirtyStart,i),this.dirtyEnd=Math.max(this.dirtyEnd,i)):no().error("mapview-attributes-store","Tried to set a value for a texel's readonly component")}expand(e){if(this.size=e,!this.textureOnly){const t=this._initData(this.pixelType,e),s=this.data;t.set(s),this.data=t}}toMessage(){const e=this.dirtyStart,t=this.dirtyEnd,s=this.texelSize;if(e>t)return null;this._resetRange();const i=!this.isLocal,r=this.pixelType,n=this.layout,o=this.data;return{start:e,end:t,data:i&&o.slice(e*s,(t+1)*s)||null,pixelType:r,layout:n}}_initData(e,t){const s=ArrayBuffer,r=function(e){switch(e){case Ye.ld.UNSIGNED_BYTE:return Uint8Array;case Ye.ld.UNSIGNED_SHORT_4_4_4_4:return Uint16Array;case Ye.ld.FLOAT:return Float32Array;default:return void Ie.A.getLogger("esri.views.2d.engine.webgl.Utils").error(new i.A("webgl-utils",`Unable to handle type ${e}`))}}(e),n=new r(new s(t*t*4*r.BYTES_PER_ELEMENT));for(let e=0;e<n.length;e+=4)n[e+1]=255;return n}_resetRange(){this.dirtyStart=2147483647,this.dirtyEnd=0}}class lo{constructor(e){this._client=e,this._filters=[],this._blocks=new Array,this._attributeComputeInfo=null,this._abortController=new AbortController,this._size=p.TB,this._idsToHighlight=new Map,this._arcadeDependencies=new Set,this._initialized=!1,this.version=0,this._idGenerator=new ro,this._epoch=1}destroy(){this._abortController.abort()}_initialize(){if(null!=this._blockDescriptors)return;const e=Ye.ld.FLOAT;oo(`Creating AttributeStore ${ao?"with":"without"} shared memory`),this._blockDescriptors=[{pixelType:Ye.ld.UNSIGNED_BYTE,layout:1},{pixelType:Ye.ld.UNSIGNED_BYTE,layout:15,textureOnly:!0},{pixelType:Ye.ld.UNSIGNED_BYTE,layout:15,textureOnly:!0},{pixelType:e,layout:15},{pixelType:e,layout:15},{pixelType:e,layout:15},{pixelType:e,layout:15},{pixelType:Ye.ld.FLOAT,layout:15}],this._blocks=this._blockDescriptors.map(()=>null)}get usedMemory(){let e=0;for(const t of this._blocks)t&&(e+=t.usedMemory);return e+=this._idGenerator.usedMemory,e}get hasHighlight(){return this._idsToHighlight.size>0}createDisplayIdForObjectId(e){return this._idGenerator.createIdForObjectId(e)}releaseDisplayIdForObjectId(e){return this._idGenerator.releaseIdForObjectId(e)}getDisplayIdForObjectId(e){return this._idGenerator.getDisplayIdForObjectId(e)}incrementDisplayIdGeneration(){this._idGenerator.incrementGeneration()}hasArcadeDependency(e){return this._arcadeDependencies.has(e)}releaseAllIds(){this._idGenerator.releaseAll()}async update(e,t,s,i=0){const r=(0,y.Ui)(this._schema,e);if(this.version=i,r&&((0,n.A)("esri-2d-update-debug")&&console.debug(`Version[${i}] AttributeStore.update`,{changed:r}),this._schema=e,this._attributeComputeInfo=null,this._initialize(),null!=e))if(s&&(this._filters=await Promise.all(e.filters.map(e=>e?Fn.create({geometryType:s.geometryType,hasM:!1,hasZ:!1,timeInfo:s.timeInfo,fieldsIndex:s.fieldsIndex,spatialReference:s.outSpatialReference,filterJSON:e}):null))),"multi"!==e.type)this._attributeComputeInfo={type:"feature",map:new Map},await Promise.all(e.bindings.map(async e=>{const s=await this._bind(t,e);this._updateReferences(s)}));else{this._attributeComputeInfo={type:"multi",keyField:e.keyField,map:new Map};for(const s in e.bindings){const i=e.bindings[s];await Promise.all(i.map(async e=>{const i=await this._bind(t,e,parseInt(s,10));this._updateReferences(i)}))}}}setHighlight(e,t){let s=null;0===e.length&&0===t.length&&(s=this._getBlock(0),s.unsetComponentAllTexels(0,(1<<p.U5)-1));for(const{displayId:t,highlightFlags:i}of e){if(null==t||-1===t)continue;s||(s=this._getBlock(0),s.unsetComponentAllTexels(0,(1<<p.U5)-1));const e=sn(t);s.setComponent(0,i,[e])}this._idsToHighlight.clear();for(const{objectId:t,highlightFlags:s}of e)this._idsToHighlight.set(t,s);for(const{objectId:e,highlightFlags:s}of t)this._idsToHighlight.set(e,s)}setData(e,t,s,i){const r=sn(e);this._ensureSizeForTexel(r),this._getBlock(t).setData(e,s,i)}getData(e,t,s){return this._getBlock(t).getData(e,s)}getHighlightFlags(e){return this._idsToHighlight.get(e)||0}unsetAttributeData(e){const t=sn(e);this._getBlock(0).setData(t,0,0)}referencesScale(){const e=this._attributeComputeInfo;if(!e)return!1;if("multi"===e.type){for(const t of e.map.values())for(const{field:e}of t.values())if(e?.hasArcadeDependency("scale"))return!0}else for(const{field:t}of e.map.values())if(t?.hasArcadeDependency("scale"))return!0;return!1}setAttributeData(e,t,s,i){const r=sn(e);this._ensureSizeForTexel(r),this._getBlock(0).setData(r,0,this.getFilterFlags(t,i));const n=this._attributeComputeInfo;let o=null;n&&(o="multi"===n.type?n.map.get(t.readAttribute(n.keyField)):n.map,o?.size&&o.forEach((e,i)=>{const n=1*i%4,o=Math.floor(1*i/4),a=this._getBlock(o+3);let c=e.field?.read(t,s);e.valueRepresentation&&(c=function(e,t){if(!e||!t)return e;switch(t){case"radius":case"distance":return 2*e;case"diameter":case"width":return e;case"area":return Math.sqrt(e)}return e}(c,e.valueRepresentation)),(null===c||isNaN(c)||c===1/0||c===-1/0)&&(c=1e-30),a.setData(r,n,c)}))}get epoch(){return this._epoch}sendUpdates(){const e=this._blocks.map(e=>null!=e?e.toMessage():null),t=this._getInitArgs();(0,n.A)("esri-2d-log-updating")&&console.log("AttributeStore: _doSendUpdate.start"),this._client.update({initArgs:t,blockData:e,version:this.version,sendUpdateEpoch:this._epoch}),this._epoch+=1,(0,n.A)("esri-2d-log-updating")&&console.log("AttributeStore: _doSendUpdate.end")}_ensureSizeForTexel(e){for(;e>=this._size*this._size;)if(this._expand())return}async _bind(e,t,s){const i=await e.createComputedField(t),{valueRepresentation:r}=t,n=this._attributeComputeInfo;if("multi"===n.type){const e=n.map.get(s)??new Map;e.set(t.binding,{field:i,valueRepresentation:r}),n.map.set(s,e)}else n.map.set(t.binding,{field:i,valueRepresentation:r});return i}_getInitArgs(){return this._initialized?null:(this._initialized=!0,this._getBlock(1),this._getBlock(2),this._getBlock(7),{blockSize:this._size,blockDescriptors:this._blocks.map(e=>null!=e?{textureOnly:e.textureOnly,buffer:e.buffer,pixelType:e.pixelType}:null)})}_getBlock(e){const t=this._blocks[e];if(null!=t)return t;oo(`Initializing AttributeBlock at index ${e}`);const s=new co(this._size,this._blockDescriptors[e],this._client.isLocal);return this._blocks[e]=s,this._initialized=!1,s}_expand(){if(this._size<this._schema.capabilities.maxTextureSize){const e=this._size<<=1;oo("Expanding block size to",e,this._blocks);for(const t of this._blocks)t?.expand(e);return this._initialized=!1,this._size=e,0}return no().error(new i.A("mapview-limitations","Maximum number of onscreen features exceeded.")),-1}_updateReferences(e){(0,kr.QY)(this._arcadeDependencies,e)}isVisible(e){return!!(this._getBlock(0).getData(e,0)&1<<p.U5)}getFilterFlags(e,t){let s=0;for(let i=0;i<this._filters.length;i++){const r=!!(1<<i),n=this._filters[i];s|=(!r||null==n||n.check(e,t)?1:0)<<i}let i=0;if(this._idsToHighlight.size){const t=e.getObjectId();i=this.getHighlightFlags(t)}return s<<p.U5|i}}class uo{constructor(e,t,s,i){this._connection=e,this._source=t,this._requiredLevel=s,this._requiredScale=i,this._version=1,this._registry=new Dr,this._proxy=new ge({fetch:(e,t)=>this._connection.layerView.fetch(e,t),fetchDictionary:(e,t)=>this._connection.layerView.fetchDictionary(e,t)}),this._attributeStore=new lo({isLocal:!1,update:e=>(0,h.oV)(this._connection.container.updateAttributeView(e))})}destroy(){this._proxy.destroy(),this._strategy?.destroy(),this._attributeStore.destroy()}get hasClusters(){return"cluster"===this._schema?.mesh.strategy.type}get aggregateQueryEngine(){return this._strategy?.aggregateQueryEngine}get usedMemory(){let e=0;return e+=this._attributeStore.usedMemory,this._strategy&&(e+=this._strategy.usedMemory),e}get version(){return this._version}getDisplayFeatures(e){return this._strategy?this._strategy.getDisplayFeatures(e):{features:[],aggregates:[],tracks:[]}}getDisplayIds(e){const t={};return this._strategy?(this._strategy.displayMap(e,e=>e,(e,s,i)=>{t[i]=e}),t):t}getFeatureObjectIdsForAggregate(e){return this._strategy?this._strategy.getFeatureObjectIdsForAggregate(e):[]}onSubscribe(e){this._strategy?.onSubscribe(e)}onUnsubscribe(e){this._strategy?.onUnsubscribe(e)}requiresInvalidation(){return this._strategy?.requiresInvalidation()??!1}updateRequiredLevel(e,t){this._strategy?.updateRequiredLevel(e,t),this._requiredLevel=e,this._requiredScale=t}async update(e,t,s,i,r){const o=e.processor,a=(0,m.i8)(this._schema?.storage,o.storage),c=(0,m.i8)(this._schema?.mesh.properties,o.mesh.properties),l=(0,m.i8)(this._schema?.mesh.factory,o.mesh.factory),u=(0,m.i8)(this._schema?.mesh.strategy,o.mesh.strategy),h=function(e,t){const s=[];return e?.timeExtent?.start===t.timeExtent?.start&&e?.timeExtent?.end===t.timeExtent?.end||s.push("timeProperties"),s}(this._schema?.expressionProperties,o.expressionProperties),d=h.some(e=>this._attributeStore.hasArcadeDependency(e)),p=h.some(e=>this._factory?.hasArcadeDependency(e)??!1),f=h.some(e=>this._strategy?.hasArcadeDependency(e))||this._strategy?.isAggregate&&d,_=p||f,g=c||l||u;if(!(a||g||p||d||f||i))return!1;(0,n.A)("esri-2d-update-debug")&&console.debug(`Version[${this._version}] SymbolProcessor.update`,{changes:(0,y.Ui)(this._schema,o),schema:o}),this._schema=o;const x=new Sn({fields:this._source.metadata.fieldsIndex,spatialReference:this._source.metadata.outSpatialReference}),w={currentUser:o.mesh.properties.currentUser};if((a||g||d)&&(await this._attributeStore.update(o.storage,x,this._source.metadata,t),this._strategy?.invalidateAttributeData(ho(o))),!i&&!g&&!_)return!1;(u||c||_)&&await this._updateStrategy(o.mesh.strategy,r,ho(o),w),this._updateSortKey(x,"sortKey"in o.mesh.properties?o.mesh.properties.sortKey:null);const b="dictionary"===o.mesh.factory.symbology.type?o.mesh.factory.symbology.fieldMap:null,v=new Nr(x,this._proxy,s,this._registry,b);return(l||"dictionary"===o.mesh.factory.symbology.type)&&(this._factory=await _e.create(v,o.mesh.factory)),this._version=t,!0}async applyOverrideUpdate(e,t){if(!this._strategy)return;const s=this._strategy.applyOverrideUpdate(e);for await(const e of s)try{await this._process(e,t)}catch(e){}}async updateChunks(e){await this._doUpdateChunks(e),this._strategy?.afterUpdateChunks()}async removeChunks(e){this._strategy?.removeChunks(e),this._attributeStore.incrementDisplayIdGeneration()}updateHighlight({highlights:e}){if(!this._strategy||!this._strategy.hasSubscribers)return void this._attributeStore.setHighlight(e.map(({objectId:e,highlightFlags:t})=>({objectId:e,highlightFlags:t,displayId:-1})),e);const t=this._strategy.displayMap(e,({objectId:e})=>e,(e,{highlightFlags:t},s)=>({objectId:s,displayId:e,highlightFlags:t}));this._attributeStore.setHighlight(t,e)}invalidate(){this._strategy&&this._strategy.invalidate()}async _doUpdateChunks(e){if(!this._strategy)return;const t=this._strategy.updateChunks(),s=[],i=new Map;for await(const r of t){let t=i.get(r.id);null==t&&(t=new Br({concurrency:16,process:t=>this._process(t,e)}),i.set(r.id,t));const n=t.push(r).catch(e=>(0,a.jH)(e));s.push(n)}try{await Promise.all(s)}catch(e){}(0,n.A)("esri-2d-update-debug")&&console.log("SendUpdates"),this._attributeStore.sendUpdates(),(0,n.A)("esri-2d-update-debug")&&console.log("SendUpdates.await")}async _updateStrategy(e,t,s,i){switch(this._strategy?.destroy(),e.type){case"feature":this._strategy=new Wn(this._source,this._attributeStore,s,i);break;case"binning":this._strategy=await On.create(e,this._source,this._attributeStore,s,i);break;case"cluster":this._strategy=await Bn.create(this._connection,e,this._source,this._attributeStore,s,i,this._requiredLevel,this._requiredScale);break;case"track":this._strategy=await to.create(e,this._source,this._attributeStore,s,i)}for(const e of t)this._strategy.onSubscribe(e)}async _updateSortKey(e,t){if(this._sortInfo=(0,_.pR)(this._sortInfo?.computed),null!=t){const s=t.byRenderer?null:await e.createComputedField(t);this._sortInfo={...t,computed:s}}}async _process(e,t){const s=e.subscription;if((0,n.A)("esri-2d-update-debug")){const t=s.tile;console.debug(`Version[${this._version}] Tile[${t.key.id}, end=${e.end}] Processor._process`)}const i={currentUser:this._schema?.mesh.properties.currentUser};await this._fetchResources(e,i),(0,a.Te)(s.signal);const r=await this._write(e,s.tile.createArcadeEvaluationOptions(ho(this._schema)),i,t),o=s.tile.tileInfoView.getLODInfoAt(s.tile.key);(0,a.Te)(s.signal);const{message:c,transferList:l}=r.serialize(o),u={objectIdMap:null,inner:e.createMessage(c,this._version,this._attributeStore.epoch)};if(this._schema?.mesh.properties.returnMeshObjectId){u.objectIdMap={};const t=e.reader?.getCursor();if(t)for(;t.next();)u.objectIdMap[t.getDisplayId()]=t.getObjectId()}if((0,a.Te)(s.signal),await this._connection.container.onMessage(u,{signal:s.signal,transferList:l}),this._attributeStore.sendUpdates(),(0,n.A)("esri-2d-update-debug")){const t=s.tile;console.debug(`Version[${this._version}] Tile[${t.key.id}, end=${e.end}] Processor._process.await`)}}async _fetchResources(e,t){await this._fetchMatcherResources(e),await this._fetchWriterResources(e,t)}async _fetchMatcherResources(e){if(e.reader)return this._factory.enqueueMatcherRequests(this._proxy,e.reader)}async _fetchWriterResources(e,t){if(!e.reader)return;const s=e.reader.getCursor(),i=e.subscription.tile.createArcadeEvaluationOptions(ho(this._schema));for(;s.next();)this._factory.enqueueWriterRequests(this._proxy,s,i,t);await this._proxy.fetchEnqueuedResources()}async _write(e,t,s,i){const r=e.subscription.tile,n=e.reader?.getCursor(),o=n?.getSize()??0,c=r.tileInfoView.tileInfo.isWrappable,l=r.tileInfoView.spatialReference.isWGS84,u=new se(r.key,this._strategy.enablePixelBuffering,c,l,o);if(!n)return u;const h=function(e,t){const s=(0,g.Q1)(e),i=[];for(const e of t.rings){const t=[];for(const i of e)t.push([(0,g.IE)(s,i[0]),(0,g.B2)(s,i[1])]);i.push(t)}return{rings:i}}(r.transform,i),d=r.createArcadeEvaluationOptions(ho(this._schema));let p=0;for(;n.next();){++p%1e3||(await(0,a.Pl)(0),(0,a.Te)(e.subscription));const i=this._getSortKeyValue(n,t);u.entityStart(n.getDisplayId(),i);try{this._factory.write(u,this._proxy,n,d,s,r.level,h)}catch(e){}u.entityEnd()}return u}_getSortKeyValue(e,t){if(!this._sortInfo)return 0;const{computed:s,order:i,byRenderer:r}=this._sortInfo,n=r?this._factory.getSortKey(e,t):s?.read(e,t);return null==n||isNaN(n)?0:n*("asc"===i?-1:1)}}function ho(e){const{timeZone:t}=e?.mesh.properties??{},{timeExtent:s}=e?.expressionProperties??{};return{timeZone:t,timeExtent:s}}class po{static from(e){let t=0,s=0,i=0;return e.forEach(e=>{const r=e._readGeometry();r&&(s+=r.isPoint?1:r.lengths.reduce((e,t)=>e+t,0),i+=r.isPoint?1:r.lengths.length,t+=1)}),new po(t,s,i)}constructor(e,t,s){this.featureCount=e,this.vertexCount=t,this.ringCount=s}toJSON(){return{featureCount:this.featureCount,ringCount:this.featureCount,vertexCount:this.featureCount}}}let fo=class extends R.A{constructor(e){super(),this._connection=e,this._enabledEventTypes=new Set,this._updateInfo={websocket:0,client:0},this._lastTime=performance.now(),this._queuedCommands=[],this.addHandles([(0,l.wB)(()=>this._strategy?.connectionStatus??"disconnected",e=>{this._layerView.setProperty({propertyName:"pipelineConnectionStatus",value:e})},{initial:!0}),(0,l.wB)(()=>this._strategy?.errorString||null,e=>this._layerView.setProperty({propertyName:"pipelineErrorString",value:e}),{initial:!0})])}destroy(){this._strategy=null,this.removeAllHandles()}get _layerView(){return this._connection.layerView}set strategy(e){null==this._strategy&&this._resetUpdateInfo(performance.now());const t="event-handles";this.removeHandles(t),null!=e&&(this.addHandles([e.events.on("data-received",e=>this._onFeature(e)),e.events.on("message-received",e=>this._onWebSocketMessage(e)),e.events.on("features-updated",e=>this._onUpdate(e)),e.events.on("tick",()=>this._onTick())],t),this._queuedCommands.forEach(t=>t(e)),this._queuedCommands=[]),this._strategy=e}updateCustomParameters(e){null!=e&&this._callOrEnqueue(t=>t.updateCustomParameters(e))}sendMessageToSocket(e){this._callOrEnqueue(t=>t.sendMessageToSocket(e))}sendMessageToClient(e){this._callOrEnqueue(t=>t.sendMessageToClient(e))}enableEvent(e,t){t?this._enabledEventTypes.add(e):this._enabledEventTypes.delete(e)}disconnect(){this._strategy?.disconnect()}connect(){this._strategy?.connect()}clear(){this._strategy?.clear()}_onWebSocketMessage(e){this._enabledEventTypes.has("message-received")&&this._layerView.emitEvent({name:"message-received",event:e})}_onFeature(e){this._updateInfo.websocket++,this._enabledEventTypes.has("data-received")&&this._layerView.emitEvent({name:"data-received",event:{attributes:e.attributes,centroid:e.centroid,geometry:e.geometry}})}_onUpdate(e){this._updateInfo.client+=e}_onTick(){const e=performance.now(),t=e-this._lastTime;if(t>2500){const s=Math.round(this._updateInfo.client/(t/1e3)),i=Math.round(this._updateInfo.websocket/(t/1e3));this._resetUpdateInfo(e),this._layerView.emitEvent({name:"update-rate",event:{client:s,websocket:i}})}}_resetUpdateInfo(e){this._lastTime=e,this._updateInfo.client=0,this._updateInfo.websocket=0}_callOrEnqueue(e){null!=this._strategy?e(this._strategy):this._queuedCommands.push(e)}};(0,P.Cg)([(0,L.MZ)()],fo.prototype,"_strategy",void 0),fo=(0,P.Cg)([(0,L.$K)("esri.views.2d.layers.features.sources.StreamMessenger")],fo);class _o{constructor(){this._requiresInvalidation=!1}get requiresInvalidation(){return this._requiresInvalidation}requireInvalidation(){this._requiresInvalidation=!0}}class mo{constructor(e,t,s){this._context=s,this._controller=new AbortController,this.metadata=En.i.createFeature(e),this._schema=t}destroy(){this._controller.abort(),this.store.destroy()}get store(){return this._context.store}get _connection(){return this._context.connection}get _options(){return{signal:this._controller.signal}}get _signal(){return this._controller.signal}async applyOverride(e){this._onOverride(),await this.store.applyOverride(e)}takeOverrideUpdate(){return this.store.takeOverrideUpdate()}unsafeSetQueryHistoricMoment(e){throw new Error("InternalError: LoadStrategy does not support query info")}async queryByObjectId(e,t){throw new Error("InternalError: LoadStrategy does not support fetching")}prepareCacheUpdate(e,t){}applyCacheUpdate(){return null}}var yo=s(13069),go=s(28923);class xo{constructor(e,t,s,r){this.store=e,this.queryInfo=t,this._options=s,this._fetch=r,this._nextBatch=new Set,this._fetchFeatures=(0,a.sg)(async()=>{if(0===this._nextBatch.size||this._options.signal?.aborted)return;const e=Array.from(this._nextBatch);this._nextBatch.clear(),e.length>8e3&&Ie.A.getLogger("esri.views.2d.layers.FeatureLayerView2D").warn(new i.A("highlight-too-many-features","highlight is limited to 8000 features on large layers configured with a display filter to avoid performance issues"));const t=this.queryInfo.objectIdsQueryPageSize,s=Math.ceil(8e3/t),r=Math.min(s,Math.ceil(e.length/t)),n=Array.from({length:r},(s,i)=>{const r=i*t,n=Math.min(r+t,e.length);return{num:i,query:this.queryInfo.createObjectIdsQuery(e.slice(r,n))}});try{await async function(e,t,s,r={}){const n=(await Promise.allSettled(s.map(s=>async function(e,t,s,i={}){const r=`${e.chunkPrefix??""}${s.num}`,n=await e.fetch(s.query,i,{chunkId:r}),o=new go.j(n,s.query.inner.toJSON(),s.num,!1);o.chunkId=o.normalizedChunkId=r,(0,a.Te)(i),t.insert(o)}(e,t,s,r)))).filter(e=>"rejected"===e.status).map(e=>e.reason);if(n.length)throw new i.A("featurelayer-query","Encountered errors when downloading data",{errors:n})}({chunkPrefix:"cache."+(0,yo.lk)(),fetch:this._fetch},this.store,n,this._options)}catch(e){}})}prepareCacheUpdate(e,t){if(t)for(const e of t)this._nextBatch.delete(e);for(const t of e)this._nextBatch.add(t)}applyCacheUpdate(){return 0===this._nextBatch.size||this._options.signal?.aborted?null:this._fetchFeatures().catch(()=>{})}}var wo=s(11254),bo=s(41560),vo=s(79677);class So{static create(e,t,s){const i=t.queryScaleRanges,r=t.displayFilterInfo;return new So(function(e,t,s){const i=function(e){switch(e.type){case"object-id":case"unique-id-simple":return`${e.fieldName} ASC`;case"unique-id-composite":return`${e.fieldNames.join(",")} ASC`}}(s.featureIdInfo);return{returnCentroid:"esriGeometryPolygon"===s.serviceGeometryType&&!e.queryMetadata.supportsCentroidOnDegeneratedQuantizedGeometry&&!e.queryMetadata.supportsDegeneratedQuantizedGeometry,returnGeometry:!0,returnZ:t.returnZ,returnM:t.returnM,timeReferenceUnknownClient:s.timeReferenceUnknownClient??void 0,outSpatialReference:Gr.A.fromJSON(e.outSpatialReference),orderByFields:"memory"===e.type?[]:[i],where:t.definitionExpression??"1=1",outFields:t.availableFields,multipatchOption:"esriGeometryMultiPatch"===s.serviceGeometryType?"xyFootprint":null,gdbVersion:t.gdbVersion,historicMoment:t.historicMoment?new Date(t.historicMoment):null,timeExtent:t.timeExtent?vo.A.fromJSON(t.timeExtent):null}}(e,t,s),r,i,s.subtypeField,t.customParameters,s.geometryType,e.queryMetadata)}constructor(e,t,s,i,r,n,o){this._queryParams=e,this._displayFilter=t,this._queryScaleRanges=s,this._subtypeField=i,this._customParameters=r,this._geometryType=n,this._queryMetadata=o}getPageSize(e){if(null==this._queryMetadata)throw new Error("InternalError: Service does not support paged queries");const t=this._queryMetadata.supportsMaxRecordCountFactor?4:null,s=((e?this._queryMetadata.tileMaxRecordCount:this._queryMetadata.maxRecordCount)??this._queryMetadata.maxRecordCount??2e3)*(t??1),i=(0,n.A)("featurelayer-query-max-page-size")??8e3;return Math.min(i,s)}get objectIdsQueryPageSize(){return this._queryMetadata?.maxRecordCount??2e3}updateHistoricMoment(e){this._queryParams.historicMoment=e}updateFields(e){this._queryParams.outFields=e}createPatchFieldsQuery(e,t,s){if(!t.getSize())return null;const i=e.clone();if("*"===this._queryParams.outFields[0]){if("*"===(i.outFields??[])[0])return null;i.outFields=this._queryParams.outFields}else{const e=new Set(this._queryParams.outFields),s=[];for(const i of e)t.hasField(i)||s.push(i);if(0===s.length)return null;i.outFields=s}i.returnGeometry=!1,i.returnCentroid=!1,i.quantizationParameters=null,i.cacheHint=!0;const r={inner:i,customParameters:this._customParameters};if((0,n.A)("esri-tiles-debug")&&null!=s){const e=s.chunkId.toString().replaceAll("/",".");r.customParameters=r.customParameters?{...r.customParameters,chunkId:e}:{chunkId:e}}return r}createQuery(e={}){if(!this._queryParams)throw new Error("InternalError: queryInfo should be defined");return{inner:new Mn.A({...this._queryParams,...e}),customParameters:this._customParameters}}createTileQuery(e,t){if(null==this._queryMetadata)throw new Error("InternalError: Service does not support tile queries");const s=this.createQuery(t),i=s.inner;if(this._queryScaleRanges?.length){const t=this._queryScaleRanges.filter(t=>(!t.minScale||t.minScale>=e.maxScale)&&(!t.maxScale||t.maxScale<=e.minScale)).map(e=>e.subtypeCode);if(t.length){const e=`${this._subtypeField} IN (${t})`;i.where=(0,an.mA)(i.where,e)}}if(this._displayFilter&&(i.where=(0,an.mA)(i.where,(0,bo.Ch)(this._displayFilter,e.minScale,e.maxScale))),i.quantizationParameters=t.quantizationParameters??e.getQuantizationParameters(),i.resultType="tile",i.geometry=e.hydratedExtent,this._queryMetadata.supportsQuantization?"esriGeometryPolyline"===this._geometryType&&(i.maxAllowableOffset=e.resolution*(0,n.A)("feature-polyline-generalization-factor")):"esriGeometryPolyline"!==this._geometryType&&"esriGeometryPolygon"!==this._geometryType||(i.maxAllowableOffset=e.resolution,"esriGeometryPolyline"===this._geometryType&&(i.maxAllowableOffset*=(0,n.A)("feature-polyline-generalization-factor"))),i.defaultSpatialReferenceEnabled=this._queryMetadata.supportsDefaultSpatialReference,i.compactGeometryEnabled=this._queryMetadata.supportsCompactGeometry,this._queryMetadata.supportsMaxRecordCountFactor&&(i.maxRecordCountFactor=4),(0,n.A)("esri-tiles-debug")){const t=e.id.replaceAll("/",".");s.customParameters=s.customParameters?{...s.customParameters,tileId:t}:{tileId:t}}return s}createPagedTileQuery(e,t){const s=this.getPageSize(!0);return this.createTileQuery(e,{start:s*t,num:s,returnExceededLimitFeatures:!0})}createPagedQuery(e,t){const s=this.getPageSize(!1);return this.createQuery({start:s*e,num:s,returnExceededLimitFeatures:!0,maxRecordCountFactor:4,quantizationParameters:t,cacheHint:!0})}createObjectIdsQuery(e){return this.createQuery({objectIds:e,outFields:["*"]})}}var Io=s(10382),To=s(75321),ko=s(80893),Ao=s(51624),Mo=s(97633),Co=s(99996),Fo=s(53655);const Eo=268435455;class Po{constructor(){this.hasFeatures=!1,this.exceededTransferLimit=!1,this.hasZ=!1,this.hasM=!1,this.fieldCount=0,this.featureCount=0,this.idFieldIndices=[],this.transform=null,this.vertexCount=0,this.offsets={attributes:new Array,geometry:new Array},this.centroid=new Array}get usedMemory(){let e=0;return e+=(0,so.Qf)(this.idFieldIndices),e+=(0,so.Qf)(this.offsets.attributes),e+=(0,so.Qf)(this.offsets.geometry),e+=(0,so.Qf)(this.centroid),this.displayIds&&(e+=(0,so.Qf)(this.displayIds)),this.groupIds&&(e+=(0,so.Qf)(this.groupIds)),e}get stride(){return 2+Number(this.hasZ)+Number(this.hasM)}}const Ro=128e3,Oo={small:{delta:new Int32Array(128),decoded:new Int32Array(128)},small64:{delta:new Float64Array(0),decoded:new Float64Array(0)},large:{delta:new Int32Array(Ro),decoded:new Int32Array(Ro)},large64:{delta:new Float64Array(0),decoded:new Float64Array(0)}};function zo(e,t){return t?e<=Oo.small64.delta.length?Oo.small64:(e<=Oo.large64.delta.length||(Oo.large64.delta=new Float64Array(Math.round(1.25*e)),Oo.large64.decoded=new Float64Array(Math.round(1.25*e))),Oo.large64):e<=Oo.small.delta.length?Oo.small:(e<=Oo.large.delta.length||(Oo.large.delta=new Int32Array(Math.round(1.25*e)),Oo.large.decoded=new Int32Array(Math.round(1.25*e))),Oo.large)}function Lo(e){for(;e.next();){if(1===e.tag())return e.getMessage();e.skip()}return null}function Do(e,t,s,i,r){return!!e&&0===t*r-i*s&&t*i+s*r>0}class No extends Co.Y{static fromBuffer(e,t,s=!1){const r=t.geometryType,n=function(e){try{const t=new Ao.A(new Uint8Array(e),new DataView(e));for(;t.next();){if(2===t.tag())return Lo(t.getMessage());t.skip()}}catch(e){throw new i.A("query:parsing-pbf","Error while parsing FeatureSet PBF payload",{error:e})}return null}(e),o=function(e,t,s){const i=e.asUnsafe(),r=i.pos(),n=new Po;let o=0,a=0,c=null;const l=[];for(;i.next();)switch(i.tag()){case 12:c=i.processMessage(Fo.ae);break;case 9:n.exceededTransferLimit=i.getBool();break;case 10:n.hasZ=i.getBool();break;case 11:n.hasM=i.getBool();break;case 13:{const e=i.processMessage(Fo.cn);e.index=o++,l.push(e);break}case 15:{const e=i.getPackedEnd(),s=n.offsets.geometry,r=n.centroid;s.push(0);const{stride:o}=n;for(r.push(Eo),r.push(Eo);i.pos()<e&&i.next();)switch(i.tag()){case 1:{n.offsets.attributes.push(i.pos());const e=i.getLength();i.skipLen(e);break}case 2:if(t){const e=i.getPackedEnd();for(;i.pos()<e&&i.next();)switch(i.tag()){case 3:{const e=i.getPackedEnd();let t=a*o;for(;i.pos()<e;)n.centroid[t++]=i.getSInt64();break}default:i.skip()}}else{n.offsets.geometry[a]=i.pos();const e=i.getLength();n.vertexCount+=e,i.skipLen(e)}break;case 4:{const e=i.getLength(),t=i.pos()+e;for(;i.pos()<t&&i.next();)switch(i.tag()){case 3:{const e=i.getPackedEnd();let t=a*o;for(;i.pos()<e;)n.centroid[t++]=i.getSInt64();break}default:i.skip()}break}default:i.skip()}a++,n.hasFeatures=!0;break}default:i.skip()}n.fields=new Wr.A(l),n.featureCount=a,n.fieldCount=o;const u=function*(e){switch(e.type){case"object-id":case"unique-id-simple":return void(yield e.fieldName);case"unique-id-composite":return void(yield*e.fieldNames)}}(s);return n.idFieldIndices=Array.from(u,e=>n.fields.get(e)?.index),n.transform=c,n.displayIds=new Uint32Array(n.featureCount),n.groupIds=new Uint16Array(n.featureCount),i.move(r),n}(n,"esriGeometryPoint"===r,t.featureIdInfo);return new No(n,o,t,s)}constructor(e,t,s,i){super(s),this._use64Bit=i,this._hasNext=!1,this._isPoints=!1,this._featureIndex=-1,this._featureOffset=0,this._cache={area:0,unquantGeometry:void 0,geometry:void 0},this._parseCaches=new Array,this._geometryType=s.geometryType,this._reader=e,this._header=t,this._hasNext=t.hasFeatures,this._isPoints="esriGeometryPoint"===s.geometryType}get _size(){return this._header.featureCount}get fields(){return this._header.fields}get geometryType(){return this._geometryType}get hasZ(){return this._header.hasZ}get hasM(){return this._header.hasM}get hasFeatures(){return this._header.hasFeatures}get hasNext(){return this._hasNext}get exceededTransferLimit(){return this._header.exceededTransferLimit}getSize(){return this._size}getInTransform(){return this._header.transform}getCursor(){return this.copy()}getIndex(){return this._featureIndex}setIndex(e){this._cache.area=0,this._cache.unquantGeometry=void 0,this._cache.geometry=void 0,this._featureIndex=e}getAttributeHash(){let e="";for(const t of this._header.fields.fields)e+=this._readAttributeAtIndex(t.index)+".";return e}getObjectId(){if(1===this._header.idFieldIndices.length)return this._readAttributeAtIndex(this._header.idFieldIndices[0]);const e=this._header.idFieldIndices.map(e=>this._readAttributeAtIndex(e));return JSON.stringify(e)}getDisplayId(){return this._header.displayIds[this._featureIndex]}setDisplayId(e){this._header.displayIds[this._featureIndex]=e}readGeometryArea(){return this._cache.area||this._readGeometry(!0),this._cache.area}copy(){const e=this._reader.clone(),t=new No(e,this._header,this.metadata,this._use64Bit);return this.copyInto(t),t}next(){for(this._cache.area=0,this._cache.unquantGeometry=void 0,this._cache.geometry=void 0;++this._featureIndex<this._size&&!this._getExists(););return this._featureIndex<this._size}get usedMemory(){return so.qK+(this._cache.geometry?.usedMemory??0)}get underlyingMemory(){return super.underlyingMemory+this._reader.usedMemory+this._header.usedMemory}_readX(){return this._header.centroid[this._featureIndex*this._header.stride]}_readY(){return this._header.centroid[this._featureIndex*this._header.stride+1]}_readServerCentroid(){const e=new Xt.A([],[],this.hasZ,this.hasM),{coords:t,stride:s}=e;for(let e=this._featureIndex*s,i=e+s;e<i;++e)t.push(this._header.centroid[e]);return 268435455===t[0]?null:e}_readGeometry(e=!1){if((this.hasZ||this.hasM)&&(e=!1),void 0===this._cache.geometry){let t=null;if(this._isPoints)t=this._readServerCentroid();else{const s=this._header.offsets.geometry[this._featureIndex],i=this._reader;if(0===s)return null;i.move(s);try{t=e?this._parseGeometryForDisplay(i):this._parseGeometry(i)}catch(e){return null}}return 0===t?.coords.length&&(t=null),this._cache.geometry=t,t}return this._cache.geometry}_readAttribute(e,t){const s=this._header.fields.get(e);if(null==s)return;const i=this._readAttributeAtIndex(s.index),r=this._header.fields.isDateField(s.name);return t?null==i?i:r?new Date(i):i:i}_readAttributes(){const e={};for(const t of this._header.fields.fields)e[t.name]=this._readAttributeAtIndex(t.index);return e}copyInto(e){super.copyInto(e),e._featureIndex=this._featureIndex,e._featureOffset=this._featureOffset,e._hasNext=this._hasNext,e._parseCaches=this._parseCaches}_readAttributeAtIndex(e){let t=this._parseCaches[e];if(t||(t=new Mo.P(this.getSize()),this._parseCaches[e]=t),t.has(this._featureIndex))return t.get(this._featureIndex);const s=this._header.offsets.attributes[this._featureIndex*this._header.fieldCount+e],i=this._reader;i.move(s);const r=function(e){const t=e.getLength(),s=e.pos()+t;for(;e.pos()<s&&e.next();)switch(e.tag()){case 1:return e.getString();case 2:return e.getFloat();case 3:return e.getDouble();case 4:return e.getSInt32();case 5:return e.getUInt32();case 6:return e.getInt64();case 7:return e.getUInt64();case 8:return e.getSInt64();case 9:return e.getBool();default:return e.skip(),null}return null}(i);return t.set(this._featureIndex,r),r}_readGeometryDeltaDecoded(e){if(void 0===this._cache.unquantGeometry){const t=this._readGeometry(e);if(!t)return this._cache.unquantGeometry=void 0,null;const s=this.getInTransform();if(!s)return this._cache.unquantGeometry=t,t;const i=s.scale[2]??1,r=s.translate[2]??1,n=s.scale[3]??1,o=s.translate[3]??1,a=zo(t.coords.length,this._use64Bit).decoded,c=t.clone(a);this._cache.unquantGeometry=c;const{lengths:l,coords:u,hasZ:h,hasM:d}=c,p=h&&(1!==i||0!==r),f=d&&(1!==n||0!==o);let _=0;for(const e of l){let t=u[_++],s=u[_++];if(p){const e=u[_];u[_++]=i*e+r}if(f){const e=u[_];u[_++]=n*e+o}for(let a=1;a<e;++a){if(t=u[_++]+=t,s=u[_++]+=s,p){const e=u[_];u[_++]=i*e+r}if(f){const e=u[_];u[_++]=n*e+o}}}return c}return this._cache.unquantGeometry}_parseGeometry(e){const t=e.asUnsafe(),s=t.getPackedEnd(),i=[],r=[];for(;t.pos()<s&&t.next();)switch(t.tag()){case 2:{const e=t.getPackedEnd();for(;t.pos()<e;)r.push(t.getUInt32());break}case 3:{const e=t.getPackedEnd();for(;t.pos()<e;)i.push(t.getSInt64());break}default:t.skip()}return new Xt.A(r,i,this.hasZ,this.hasM)}_parseGeometryForDisplay(e){const t=e.asUnsafe(),s=t.getLength(),i=t.pos()+s,r=[],n=[];let o=0,a=0,c=null,l=0;const u="esriGeometryPolygon"===this.geometryType,h="esriGeometryPolyline"===this.geometryType,d=u?3:h?2:1,p=u||h;for(;t.pos()<i&&t.next();)switch(t.tag()){case 2:{const e=t.getUInt32(),s=t.pos()+e;for(;t.pos()<s;){const e=t.getUInt32();r.push(e),o+=e}c=zo(2*o,this._use64Bit).delta;break}case 3:{t.getUInt32();const e=2+(this.hasZ?1:0)+(this.hasM?1:0);(0,_.Lw)(c);for(const s of r){if(a+e*s>c.length){for(let e=0;e<s;e++)t.getSInt64(),t.getSInt64(),this.hasZ&&t.getSInt64(),this.hasM&&t.getSInt64();continue}let i=t.getSInt64(),r=t.getSInt64();this.hasZ&&t.getSInt64(),this.hasM&&t.getSInt64(),c[a++]=i,c[a++]=r;let o=1;for(let e=1;e<s;e++){const e=t.getSInt64(),s=t.getSInt64();this.hasZ&&t.getSInt64(),this.hasM&&t.getSInt64();const n=i+e,u=r+s;l+=-.5*(n-i)*(u+r),i=n,r=u,0===e&&0===s||Do(p,c[a-2],c[a-1],e,s)?(c[a-2]+=e,c[a-1]+=s):(c[a++]=e,c[a++]=s,o+=1)}o>=d?n.push(o):a-=o*e}break}default:t.skip()}return this._cache.area=l,n.length?new Xt.A(n,c):null!=c?this._createDeltaQuantizedExtrudedGeometry(c[0],c[1]):null}}class qo{constructor(e,t){this.service=e,this._metadata=t}destroy(){}}class Bo extends qo{constructor(e,t,s){super(e,t),this._ports=[],this._loaded=this._load(s)}destroy(){this._loaded.finally(()=>{this._client.close(),this._client=null;for(const e of this._ports)e.close()}).catch(()=>{})}async _load(e){this._ports=await e.layerView.openMemoryPorts(),this._client=await async function(e){const t=new Io.A;return await t.open(e,{}),t}(this._ports)}async executeQuery(e,t){await this._loaded;const s=await this._client.invoke("queryFeatures",e.toJSON(),t);return Pn.K.fromFeatureSet(s,this._metadata)}}class Go extends qo{async executeQuery(e,t){const s=await(0,ko.kS)(this.service.source,e,t),r=!e.quantizationParameters;try{return No.fromBuffer(s,this._metadata,r)}catch(s){const r=await(0,ko.LT)(this.service.source,e,"pbf",t??{}),{data:{url:n}}=await(0,wo.A)(r.url,{responseType:"native-request-init",...r.options});throw new i.A("featurelayer:query","Failed to parse response",{url:n,error:s,query:e.toJSON()})}}}class Uo extends qo{async executeQuery(e,t){const{source:s,queryMetadata:i}=this.service;if(null!=e.quantizationParameters&&!i.supportsQuantization){const i=e.clone(),r=(0,g.VV)(i.quantizationParameters);i.quantizationParameters=null;const n=await(0,ko.eW)(s,i,this._metadata.spatialReference,t),o=(0,Fi.q3)(n,this._metadata.featureIdInfo);return(0,Fi.jH)(r,o),Pn.K.fromOptimizedFeatureSet(o,this._metadata)}const r=await(0,ko.eW)(s,e,this._metadata.spatialReference,t);return"esriGeometryPoint"===this._metadata.geometryType&&(r.features=r.features?.filter(e=>{if(null!=e.geometry){const t=e.geometry;return Number.isFinite(t.x)&&Number.isFinite(t.y)}return!0})),Pn.K.fromFeatureSet(r,this._metadata)}}class jo extends qo{async executeQuery(e,t){if(e.quantizationParameters&&!this.service.queryMetadata.supportsQuantization){const s=e.clone(),i=(0,g.VV)(s.quantizationParameters);s.quantizationParameters=null;const r=await(0,To.I)(this.service.source,e,t);return(0,Fi.jH)(i,r),Pn.K.fromOptimizedFeatureSet(r,this._metadata)}const s=await(0,To.I)(this.service.source,e,t);return Pn.K.fromOptimizedFeatureSet(s,this._metadata)}}class Wo extends mo{constructor(e,t,s){super(e.metadata,t,s),this._service=e,this._didApplyOverride=!1,this._queue=new qr.QueueProcessor({concurrency:32,process:async e=>{const t={signal:e.options?.signal,query:e.query.customParameters,useQueue:!0};return this._adapter.executeQuery(e.query.inner,t)}}),this._queryInfo=So.create(e,{...t.full,...t.partial},this.metadata),this._adapter=function(e,t,s){switch(e.type){case"memory":return new Bo(e,t,s);case"ogc":return new jo(e,t);case"feature-service":return e.queryMetadata.supportsFormatPBF&&(0,n.A)("featurelayer-pbf")?new Go(e,t):new Uo(e,t)}}(e,this.metadata,s.connection),this._lastEditDate=e.queryMetadata.lastEditDate}destroy(){super.destroy(),this._adapter.destroy()}unsafeSetQueryHistoricMoment(e){this._queryInfo.updateHistoricMoment(e)}async tryUpdate(e,t){if((0,m.i8)(this.availableFields,t.availableFields)){if(this._didApplyOverride||await this._queryLastEditDateChanged())return!1;await this._updateFields(t.availableFields)}return this._schema.partial=t,!0}async queryByObjectId(e,t){if(0===e.length)return Pn.K.empty(this.metadata);const s=this._queryInfo.createQuery({objectIds:e});return s.inner.outFields=t,this._fetch(s,null,null)}get availableFields(){return this._schema.partial.availableFields}get definitionExpression(){return this._schema.full.definitionExpression}_onOverride(){this._didApplyOverride=!0}async _updateFields(e){this._queryInfo.updateFields(e);const t=Array.from(this.store.chunks()).map(async e=>{const t=Mn.A.fromJSON(e.queryInfo.queryJSON);if(t)try{return await this._tryUpdateFields(e.reader,t,{chunkId:e.chunkId}),null}catch(e){return e}}),s=(await Promise.all(t)).filter(e=>e);if(s.length)throw new i.A("featurelayer-query","Encountered errors when downloading fields",{errors:s})}async _fetch(e,t,s){const i=await this._enqueue(e,t);return await this._tryUpdateFields(i,e.inner,s),i}async _queryLastEditDateChanged(){if(null==this._lastEditDate)return!1;if(!("source"in this._service))return!1;const e=this._service.source,t={...e.query,f:"json"},s=(await(0,wo.A)(e.path,{query:t,responseType:"json"})).data.editingInfo.lastEditDate;return s!==this._lastEditDate&&(this._lastEditDate=s,!0)}async _tryUpdateFields(e,t,s){const r=this._queryInfo.createPatchFieldsQuery(t,e,s);if(!r)return;const n=await this._enqueue(r,this._options);n.getSize()===e.getSize()?e.joinAttributes(n):Ie.A.getLogger("esri.views.2d.layers.features.sources.strategies.AFetchLoadStrategy").error(new i.A("featurelayer-query",`Failed to join features. Expected a count of ${e.getSize()} features, but got ${n.getSize()}`,{query:r.inner.toJSON(),debugInfo:s}))}async _enqueue(e,t){return this._connection.onEvent({type:"fetchStart"}),this._queue.push({query:e,options:t}).finally(()=>{this._connection.onEvent({type:"fetchEnd",done:0===this._queue.length})})}}class Vo extends Wo{constructor(e,t,s){super(e,t,s),this._chunksById=new Map,this._featureCache=new xo(this.store,this._queryInfo,this._options,this._fetch.bind(this))}prepareCacheUpdate(e,t){return this._featureCache.prepareCacheUpdate(e,t)}applyCacheUpdate(){return this._featureCache.applyCacheUpdate()}unload(e){this._removeChunks(e.tile)}_addChunk(e){const t=e.tile.id;this._chunksById.has(t)||this._chunksById.set(t,[]);const s=e.size();(s||e.first||e.end)&&((0,n.A)("esri-2d-update-debug")&&console.debug(`Chunk[${e.chunkId}] ATileLoadStrategy.addChunk [count=${s}]`),this._chunksById.get(t).push(e),this.store.insert(e))}_removeChunks(e){const t=this._chunksById.get(e.key.id)??[];for(const s of t)(0,n.A)("esri-2d-update-debug")&&console.debug(`Tile[${e.key.id}] Chunk[${s.chunkId}] ATileLoadStrategy.removeChunk`),this.store.remove(s);this._chunksById.delete(e.key.id)}}var Yo=s(70300);class $o extends Yo.K{constructor(e,t,s,i,r,n){super(),this._reader=e,this._queryJSON=t,this._tile=s,this._sourceTile=i,this._sourceTileDepth=r,this._end=n,this.chunkId=`${this._tile.key.id}.${this._sourceTile?.key.id}${this._end?"e":""}`,this.normalizedChunkId=`${this._tile.key.normalizedId}.${this._sourceTile?.key.normalizedId}${this._end?"e":""}`}get queryInfo(){return{type:"drill-down-tile",chunkId:this.chunkId,tileId:this._tile.key.id,queryJSON:this._queryJSON,sourceTileDepth:this._sourceTileDepth,sourceTileId:this._sourceTile?.key.id,size:this.size(),end:this.end}}get first(){return 0===this._sourceTileDepth}get reader(){return this._reader}get end(){return this._end}get tile(){return this._tile}get isTiled(){return!0}getTileReader(e){return this._tile.key.id===e.key.id?this.reader:null}}const Ho=(0,n.A)("featurelayer-query-max-depth");class Zo{constructor(e,t){this.subscription=e,this._tileIdToResult=new Map,this._controller=new AbortController,this._handles=(0,r.vE)([(0,a.u7)(e.signal,()=>this._controller.abort()),(0,a.u7)(t,()=>this._controller.abort())])}destroy(){this._controller.abort(),this._handles.remove()}get(e){return this._tileIdToResult.get(e)}set(e,t){this._tileIdToResult.set(e,t)}get options(){return{signal:this._controller.signal}}}class Qo extends Vo{constructor(){super(...arguments),this._loadStates=new Map}destroy(){super.destroy();for(const e of this._loadStates.values())e.destroy();this._loadStates.clear()}get about(){return{willQueryAllFeatures:!1,willQueryFullResolutionGeometry:!1}}async load(e){this._loadStates.has(e.key.id)||this._loadStates.set(e.key.id,new Zo(e,this._options));const t=this._loadStates.get(e.key.id);let s;try{for await(const s of this._fetchChunkInfos(t,e.tile,0)){const{queryJSON:e,reader:i,sourceTile:r,sourceTileDepth:n,tile:o}=s,c=new $o(i,e,o,r,n,!1);(0,a.Te)(t.options),this._addChunk(c)}}catch(e){s=e}(0,a.Te)(t.options);const i=new $o(Pn.K.empty(this.metadata),null,e.tile,null,-1,!0);if(this._addChunk(i),s)throw s}unload(e){super.unload(e),this._loadStates.get(e.key.id)?.destroy(),this._loadStates.delete(e.key.id)}async*_fetchChunkInfos(e,t,s){let i=e.get(t.id);const r=!!i;if(i||(i=await this._fetchChunkInfo(e,t,s),e.set(t.id,i)),i.reader.exceededTransferLimit&&s<(0,n.A)("featurelayer-query-max-depth"))for(const i of t.createChildTiles())yield*this._fetchChunkInfos(e,i,s+1);else r||(yield i)}async _fetchChunkInfo(e,t,s){const i=e.subscription.tile.getQuantizationParameters(),r=this._queryInfo.createTileQuery(t,{returnExceededLimitFeatures:s===Ho,quantizationParameters:i});return{reader:await this._fetch(r,e.options,{chunkId:t.id}),queryJSON:r.inner.toJSON(),tile:e.subscription.tile,sourceTile:t,sourceTileDepth:s}}}class Xo extends Yo.K{constructor(e,t,s,i,r){super(),this._reader=e,this._queryJSON=t,this._tile=s,this._page=i,this._end=r,this.chunkId=`${this._tile.key.id}.${this._page}${this.end?"e":""}`,this.normalizedChunkId=`${this._tile.key.normalizedId}.${this._page}${this.end?"e":""}`}get queryInfo(){return{type:"paged-tile",chunkId:this.chunkId,tileId:this._tile.key.id,queryJSON:this._queryJSON,page:this._page,size:this.size(),end:this.end}}get reader(){return this._reader}get first(){return 0===this._page}get end(){return this._end}get page(){return this._page}get tile(){return this._tile}get isTiled(){return!0}getTileReader(e){return this._tile.key.id===e.key.id?this.reader:null}}class Ko{constructor(e,t){this.subscription=e,this._pages=new Set,this._controller=new AbortController,this._done=!1,this._handles=(0,r.vE)([(0,a.u7)(e.signal,()=>this._controller.abort()),(0,a.u7)(t,()=>this._controller.abort())])}destroy(){this._controller.abort(),this._handles.remove()}get pageStart(){let e=-1;for(const t of this._pages.values())e=Math.max(e,t);return e+1}get done(){return this._done}get options(){return{signal:this._controller.signal}}add(e,t){this._pages.add(e),this._done=this._done||t}}class Jo extends Vo{constructor(){super(...arguments),this._loadStates=new Map}destroy(){super.destroy();for(const e of this._loadStates.values())e.destroy();this._loadStates.clear()}get about(){return{willQueryAllFeatures:!1,willQueryFullResolutionGeometry:!1}}async load(e){const t=(0,O.tE)(this._loadStates,e.key.id,()=>new Ko(e,this._options));for await(const e of this._fetchPages(t))this._addChunk(e)}unload(e){super.unload(e),this._loadStates.get(e.key.id)?.destroy(),this._loadStates.delete(e.key.id)}async*_fetchPages(e){let t;try{for await(const t of this._concurrentPageStream(e))(0,a.Te)(e.options),0!==t.size()&&(yield t)}catch(e){t=e}if(t&&(0,a.zf)(t)||(yield new Xo(Pn.K.empty(this.metadata),null,e.subscription.tile,-1,!0)),t)throw t}async*_concurrentPageStream(e){const t=(0,n.A)("featurelayer-query-tile-concurrency"),s=this._pageStreamAll(e),i=[];let r=!1,o=1;for(;!r;){const e=[];for(;!r&&i.length<o;){const t=s.next();if(!t.value){r=!0;break}const n=t.value;n.then(e=>{e.reader.exceededTransferLimit||(r=!0)}).catch(e=>{r=!0}).finally(()=>{i.splice(i.indexOf(n),1)}),i.push(n),e.push(n)}for(const t of e)yield t;i.length&&await Promise.race(i),o<t&&(o+=1)}}*_pageStreamAll(e){const t=Math.ceil((0,n.A)("featurelayer-query-tile-max-features")/this._queryInfo.getPageSize(!0));for(let s=0;s<t;s++)yield this._downloadPage(s,e)}async _downloadPage(e,t){(0,a.Te)(t.options);const s=t.subscription.tile,i=this._queryInfo.createPagedTileQuery(s,e),r=await this._fetch(i,t.options,{chunkId:`${s.id}-${e}`});return(0,a.Te)(t.options),new Xo(r,i.inner.toJSON(),s,e,!1)}}var ea=s(27348);class ta extends Wo{constructor(e,t,s){super(e,t,s)}get about(){return{willQueryAllFeatures:!0,willQueryFullResolutionGeometry:!0}}load(e){return null==this._promise&&(this._promise=this._download()),this._promise}unload(e){}async _download(){const e=this._schema.snapshotInfo.initialTolerance,t=e?new ea.A({mode:"view",originPosition:"upper-left",tolerance:e}):null;await this._downloadStreaming(t),null!=t&&await this._downloadRefresh()}async _downloadStreaming(e){try{for await(const t of this._fetchPages(e))this.store.insert(t)}catch(e){throw new i.A("featurelayer-query","Encountered error when downloading data",{error:e})}}async _downloadRefresh(){try{const e=[];for await(const t of this._fetchPages(null))e.push(t);this.store.clear();for(const t of e)this.store.insert(t);this.store.refresh()}catch(e){throw new i.A("featurelayer-query","Encountered error when downloading data",{error:e})}}async*_fetchPages(e){let t;try{for await(const t of this._concurrentPageStream(e))0!==t.size()&&(yield t)}catch(e){t=e}if(t&&(0,a.zf)(t)||(yield new go.j(Pn.K.empty(this.metadata),null,-1,!0)),t)throw t}async*_concurrentPageStream(e){const t=(0,n.A)("featurelayer-snapshot-concurrency"),s=this._pageStreamAll(e),i=[];let r=!1,o=1;for(;!r;){const e=[];for(;!r&&i.length<o;){const t=s.next();if(!t.value){r=!0;break}const n=t.value;n.then(e=>{e.reader.exceededTransferLimit||(r=!0)}).catch(e=>{r=!0}).finally(()=>{i.splice(i.indexOf(n),1)}),i.push(n),e.push(n)}for(const t of e)yield t;i.length&&await Promise.race(i),o<t&&(o+=1)}}*_pageStreamAll(e){const t=Math.ceil(this._schema.snapshotInfo.maxFeatureCount/this._queryInfo.getPageSize(!1));for(let s=0;s<t;s++)yield this._downloadPage(s,e)}async _downloadPage(e,t){(0,a.Te)(this._options);const s=this._queryInfo.createPagedQuery(e,t),i=await this._fetch(s,this._options,{chunkId:e.toString()}),r=new go.j(i,s.inner.toJSON(),e,!1);return(0,a.Te)(this._options),r}}var sa=s(29953),ia=s(39412);class ra extends Yo.K{constructor(e,t,s,i,r,n){super(),this._metadata=e,this._reader=t,this._page=s,this._end=i,this._fileIndex=r,this._fileUrl=n,this.chunkId=`${this._fileIndex}.${this._page}${this.end?"e":""}`,this.normalizedChunkId=this.chunkId}get reader(){return this._reader??Pn.K.empty(this._metadata)}get first(){return 0===this._page}get end(){return this._end}get queryInfo(){return{type:"snapshot",chunkId:this.chunkId,page:this._page,size:this.size(),end:this.end}}get isTiled(){return!1}async updateFields(e,t,s){return this._reader?.updateFields(e,this._fileUrl,t,s)}getTileReader(e){const t=this.queryFeaturesInBounds(e.bounds);return t.setTransformForDisplay(e.transform),t}}var na=s(16630);class oa extends mo{constructor(e,t,s,i){super(e.metadata,t,s),this._service=e,this._files=new Map,this._loaded=this._load(i)}destroy(){super.destroy(),this._loaded.finally(()=>{this._client.close(),this._client=null;for(const e of this._ports)e.close()}).catch(()=>{})}get about(){return{willQueryAllFeatures:!0,willQueryFullResolutionGeometry:!0}}get availableFields(){return this._schema.partial.availableFields}get definitionExpression(){return this._schema.full.definitionExpression}async tryUpdate(e,t){if(await this._loaded,(0,m.i8)(this.availableFields,t.availableFields)&&await this._updateFields(t.availableFields),(0,m.i8)(this._schema.partial.urls,t.urls)){for(const e of t.urls)this._files.has(e)||await this._loadFile(e);for(const e of this._files.keys())if(!t.urls.includes(e))throw new i.A("unsupported","Removing parquet files is not supported",{previous:this._schema.partial.urls,next:t.urls})}return this._schema.partial=t,!0}async load(e){return this._loaded}unload(e){}_onOverride(){}async _load(e){this._ports=await e.layerView.openMemoryPorts(),this._client=await(0,sa.N1)(this._ports,{maxNumberOfConcurrentJobs:20}),this._proxy=this._client.createInvokeProxy(),this._indexMap=await this._proxy.getIndexMap(),await this._download()}async _updateFields(e){const t=new Set(e),s=(0,z.iv)(t,new Set(this.availableFields));if(null!=this._service.metadata.fieldsIndex&&s.size){const e=Array.from(this.store.insertedChunks()).map(e=>e.updateFields(this._proxy,Array.from(s),this._options));await Promise.all(e)}}async _loadFile(e){const t=await(0,ia.N)(),s=await this._proxy.getFileId(e);this._files.set(e,s),(0,a.Te)(this._options);const i=await this._proxy.queryStream(e,{type:"snapshot",outFields:Array.from(this.availableFields),returnGeometry:!0,outSpatialReference:this.metadata.outSpatialReference.toJSON(),where:this.definitionExpression},this._options);let r=0;const n=[],o=async(n=0)=>{const c=await this._proxy.getStreamNext(e,i,this._options);if((0,a.Te)(this._options),null==c)return;const l=t.ParquetChunk.deserialize(new Uint8Array(c)),u=new na.s(this.metadata,this._indexMap,l,s),h=new ra(this.metadata,u,r++,!1,s,e);return this.store.insert(h),o(n+1)};for(let e=0;e<8;e++)n.push(o());await Promise.all(n)}async _download(){try{await Promise.all(this._schema.partial.urls.map(e=>this._loadFile(e)));const e=new ra(this.metadata,null,-1,!0,0,"");this.store.insert(e)}catch(e){throw console.error(e),e}}}class aa extends Yo.K{constructor(e,t,s,i,r,n,o){super(),this._metadata=e,this._reader=t,this._tile=s,this._fileId=i,this._fileUrl=r,this._page=n,this._end=o,this.chunkId=`${this._tile.key.id}.${this._fileId}.${this._page}${this.end?"e":""}`,this.normalizedChunkId=`${this._tile.key.normalizedId}.${this._fileId}.${this._page}${this.end?"e":""}`}get reader(){return this._reader??Pn.K.empty(this._metadata)}get first(){return 0===this._page}get end(){return this._end}get tile(){return this._tile}get queryInfo(){return{type:"parquet",chunkId:this.chunkId,queryJSON:null,page:this._page,size:this.size(),tileId:this._tile.id,end:this.end}}get isTiled(){return!0}async updateFields(e,t,s){return this._reader?.updateFields(e,this._fileUrl,t,s)}getTileReader(e){return this._tile.key.id===e.key.id?this.reader:null}}class ca{constructor(e,t){this.subscription=e,this.chunks=[],this.ids=[],this._controller=new AbortController,this._handles=(0,r.vE)([(0,a.u7)(e.signal,()=>this._controller.abort()),(0,a.u7)(t,()=>this._controller.abort())])}destroy(){this._controller.abort(),this._handles.remove()}get options(){return{signal:this._controller.signal}}addBinaryData(e){this.chunks.push(e)}addSourceChunkId(e){this.ids.push(e)}}class la extends mo{constructor(e,t,s,i){if(super(e.metadata,t,s),this._service=e,this._loadStates=new Map,this._files=new Map,this._queue=new qr.QueueProcessor({concurrency:32,process:e=>this._loadTile(e)}),!e.geometryInfo.displayOptimization)throw new Error("InternalError: ParquetTileLoadStrategy only supports XZ-enabled parquet files");this._loaded=this._load(i)}destroy(){super.destroy(),this._loaded.finally(()=>{this._client.close(),this._client=null;for(const e of this._ports)e.close()}).catch(()=>{})}get about(){return{willQueryAllFeatures:!0,willQueryFullResolutionGeometry:!0}}get availableFields(){return this._schema.partial.availableFields}get definitionExpression(){return this._schema.full.definitionExpression}async tryUpdate(e,t){await this._loaded;let s=!0;if((0,m.i8)(this.availableFields,t.availableFields)&&await this._updateFields(t.availableFields),(0,m.i8)(this._schema.partial.urls,t.urls)){for(const e of t.urls)this._files.has(e)||(s=!1,await this._insert(e));for(const e of this._files.keys())if(!t.urls.includes(e))throw new i.A("unsupported","Removing parquet files is not supported",{previous:this._schema.partial.urls,next:t.urls})}return this._schema.partial=t,s}async load(e){return await this._loaded,(0,O.tE)(this._loadStates,e.key.id,()=>new ca(e,this._options)),this._queue.push(e)}unload(e){const t=this._loadStates.get(e.tile.id);if(null!=t){for(const e of t.ids)this.store.removeById(e);t.destroy(),this._loadStates.delete(e.tile.id)}}async _load(e){const t=this._schema.partial.urls;this._ports=await e.layerView.openMemoryPorts(),this._client=await(0,sa.N1)(this._ports,{maxNumberOfConcurrentJobs:20}),this._proxy=this._client.createInvokeProxy(),this._indexMap=await this._proxy.getIndexMap(),await Promise.all(t.map(e=>this._insert(e)))}async _insert(e){this._files.set(e,this._files.size)}_onOverride(){}async _updateFields(e){const t=new Set(e),s=(0,z.iv)(t,new Set(this.availableFields));if(null!=this._service.metadata.fieldsIndex&&s.size){const e=Array.from(this.store.insertedChunks()).map(e=>e.updateFields(this._proxy,Array.from(s),this._options));await Promise.all(e)}}async _loadTile(e){const t=e.tile,s=e.signal,i=this._loadStates.get(t.id),r=new qr.QueueProcessor({process:async t=>{const s=await this._proxy.getFileId(t);return this._downloadFileData(e,t,s)},concurrency:2});await Promise.allSettled(Array.from(this._files.keys()).map(e=>r.push(e))),(0,a.Te)(s);const n=new aa(this.metadata,null,t,null,null,0,!0);i.addSourceChunkId(n.chunkId),this.store.insert(n)}async _downloadFileData(e,t,s){const i=await(0,ia.N)(),r=e.tile,n=e.signal,o=this._loadStates.get(r.id),c=await this._proxy.queryStream(t,{type:"tile",extent:r.extent,transform:r.normalizedTransform,outFields:Array.from(this.availableFields),returnGeometry:!0,outSpatialReference:this.metadata.outSpatialReference.toJSON(),scale:r.scale,where:this.definitionExpression},{signal:n});let l=0;const u=[],h=async(e=0)=>{const u=await this._proxy.getStreamNext(t,c,{signal:n});if((0,a.Te)(n),null==u)return;const d=i.ParquetChunk.deserialize(new Uint8Array(u)),p=new na.s(this.metadata,this._indexMap,d,s),f=new aa(this.metadata,p,r,s,t,l++,!1);return o.addBinaryData({data:d,fileUrl:t}),o.addSourceChunkId(f.chunkId),this.store.insert(f),h(e+1)};for(let e=0;e<4;e++)u.push(h());await Promise.all(u)}}class ua{constructor(e){this.size=0,this._start=0,this.maxSize=e,this._buffer=new Array(e)}get entries(){return this._buffer}enqueue(e){if(this.size===this.maxSize){const t=this._buffer[this._start];return this._buffer[this._start]=e,this._start=(this._start+1)%this.maxSize,t}return this._buffer[(this._start+this.size++)%this.maxSize]=e,null}dequeue(){if(0===this.size)return null;const e=this._buffer[this._start];return this._buffer[this._start]=null,this.size--,this._start=(this._start+1)%this.maxSize,e}peek(){return 0===this.size?null:this._buffer[this._start]}peekLast(){return 0===this.size?null:this._buffer[(this._start+(this.size-1))%this.maxSize]}find(e){if(0===this.size)return null;for(const t of this._buffer)if(null!=t&&e(t))return t;return null}clear(e){let t=this.dequeue();for(;null!=t;)e&&e(t),t=this.dequeue()}}class ha{constructor(e,t,s,r,n=128){if(this._trackIdToObservations=new Map,this._idCounter=0,this._lastPurge=performance.now(),this._addOrUpdated=new Map,this._removed=[],this._maxAge=0,this._timeInfo=s,this._purgeOptions=r,this.store=e,"unique-id-composite"===t.type)throw new i.A("stream-layer","composite uniqueIds are not supported");this.idField=t.fieldName,this.purgeInterval=n,this._useGeneratedIds=this.idField===re.DN}removeById(e){this._removed.push(e)}removeByTrackId(e){const t=this._trackIdToObservations.get(e);if(t)for(const e of t.entries)this._removed.push(e)}add(e){if(this._useGeneratedIds){const t=this._nextId();e.attributes[this.idField]=t,e.objectId=t}else e.objectId=e.attributes[this.idField];const t=e.objectId;if(this._addOrUpdated.set(t,e),this._maxAge=Math.max(this._maxAge,e.attributes[this._timeInfo.startTimeField]),!this._timeInfo.trackIdField)return null==this._trackIdLessObservations&&(this._trackIdLessObservations=new ua(1e5)),void this._trackIdLessObservations.enqueue(t);const s=e.attributes[this._timeInfo.trackIdField];if(!this._trackIdToObservations.has(s)){const e=null!=this._purgeOptions?.maxObservations?this._purgeOptions.maxObservations:1e3,t=(0,li.qE)(e,0,1e3);this._trackIdToObservations.set(s,new ua(t))}const i=this._trackIdToObservations.get(s),r=i?.enqueue(t);null!=r&&(this._addOrUpdated.has(r)?this._addOrUpdated.delete(r):this._removed.push(r))}checkForUpdates(){const e=this._getToAdd(),t=this._getToRemove(),s=performance.now(),i=s-this._lastPurge,r=Date.now();i>=this.purgeInterval&&(this._purge(s),this._lastPurge=s);const n=[];if(null!=t)for(const e of t){const t=this.store.removeById(e);null!=t&&n.push(t)}const o=[];if(null!=e){const i=new Set(t??[]);for(const t of e)i.has(t.objectId)||(t.attributes[re.Gm]=s,t.attributes[re.Aw]=r,this.store.add(t),o.push(t))}return!(!o.length&&!n?.length||(this.store.update(o,n),0))}_getToAdd(){if(!this._addOrUpdated.size)return null;const e=new Array(this._addOrUpdated.size);let t=0;return this._addOrUpdated.forEach(s=>e[t++]=s),this._addOrUpdated.clear(),e}_getToRemove(){const e=this._removed;return this._removed.length?(this._removed=[],e):null}_nextId(){const e=this._idCounter;return this._idCounter=(this._idCounter+1)%4294967294+1,e}_purge(e){const t=this._purgeOptions;null!=t&&(this._purgeSomeByDisplayCount(t),this._purgeByAge(t),this._purgeByAgeReceived(e,t),this._purgeTracks())}_purgeSomeByDisplayCount(e){if(!e.displayCount)return;let t=this.store.size;if(t>e.displayCount){if(this._timeInfo.trackIdField)for(const s of this._trackIdToObservations.values())if(t>e.displayCount&&s.size){const e=s.dequeue();this._removed.push(e),t--}if(null!=this._trackIdLessObservations){let s=t-e.displayCount;for(;s-- >0;){const e=this._trackIdLessObservations.dequeue();null!=e&&this._removed.push(e)}}}}_purgeByAge(e){const t=this._timeInfo?.startTimeField;if(!e.age||!t)return;const s=60*e.age*1e3,i=this._maxAge-s;this.store.forEach(e=>{e.attributes[t]<i&&this._removed.push(e.objectId)})}_purgeByAgeReceived(e,t){if(!t.ageReceived)return;const s=e-60*t.ageReceived*1e3;this.store.forEach(e=>{e.attributes[re.Gm]<s&&this._removed.push(e.objectId)})}_purgeTracks(){this._trackIdToObservations.forEach((e,t)=>{0===e.size&&this._trackIdToObservations.delete(t)})}}var da=s(30624),pa=s(10107),fa=s(64108);let _a=class extends R.A{constructor(e){super(e)}get connectionStatus(){return this.connection?.connectionStatus}get errorString(){return this.connection?.errorString}};(0,P.Cg)([(0,pa.MZ)()],_a.prototype,"connection",void 0),(0,P.Cg)([(0,pa.MZ)()],_a.prototype,"connectionStatus",null),(0,P.Cg)([(0,pa.MZ)()],_a.prototype,"errorString",null),_a=(0,P.Cg)([(0,fa.$)("esri.views.2d.layers.features.sources.StreamConnectionState")],_a);class ma{constructor(e,t){this._metadata=e,this._onUpdate=t,this._objectIdToFeature=new Map}get size(){return this._objectIdToFeature.size}get reader(){return Pn.K.fromFeatures([...this._objectIdToFeature.values()],this._metadata)}add(e){this._objectIdToFeature.set(e.objectId,e)}forEach(e){this._objectIdToFeature.forEach(e)}removeById(e){const t=this._objectIdToFeature.get(e);return t?(this._objectIdToFeature.delete(e),t):null}clear(){this._objectIdToFeature=new Map}update(e,t){this._onUpdate(e?.length??0)}}class ya extends Yo.K{constructor(e){super(),this._reader=e,this.chunkId="stream-chunk",this.normalizedChunkId="stream-chunk"}get reader(){return this._reader}get first(){return!0}get end(){return!0}get queryInfo(){return{type:"stream",chunkId:this.chunkId,size:this.size(),end:this.end}}get isTiled(){return!1}getTileReader(e){const t=this.queryFeaturesInBounds(e.bounds);return t.setTransformForDisplay(e.transform),t}}class ga extends mo{constructor(e,t,s){super(e.metadata,t,s),this._service=e,this._connectionState=new _a,this._forceRefresh=!1,this.events=new Yr.bk;const{timeInfo:i}=this.metadata,{purgeOptions:r}=t.full;this._stagingStore=new ma(this.metadata.weakCloneWithAdditionalFields([{name:re.Aw,alias:"timeReceived",type:"esriFieldTypeDate"}]),e=>this.events.emit("features-updated",e)),this._manager=new ha(this._stagingStore,this.metadata.featureIdInfo,i,r),this.connect()}destroy(){super.destroy(),this.disconnect()}get about(){return{willQueryAllFeatures:!1,willQueryFullResolutionGeometry:!1}}get connectionStatus(){return this._connectionState.connectionStatus}get errorString(){return this._connectionState?.errorString}get availableFields(){return this._schema.full.availableFields}get definitionExpression(){return this._schema.full.definitionExpression}async tryUpdate(e,t){const s=null!=this._chunk;if(t.sourceRefreshVersion!==this._refreshVersion){if(this._refreshVersion=t.sourceRefreshVersion,!this._manager.checkForUpdates()&&s&&!this._forceRefresh)return this.events.emit("tick"),!0;this._chunk&&(this.store.remove(this._chunk),e.requireInvalidation()),this._forceRefresh=!1,this._chunk=new ya(this._stagingStore.reader),this.store.insert(this._chunk),this.events.emit("tick")}return this._schema.partial=t,!0}async load(e){}unload(e){}disconnect(){this._streamConnection=(0,_.pR)(this._streamConnection),this._connectionState.connection=null,this._handlesGroup?.remove()}connect(){if(null!=this._streamConnection)return;const{geometryType:e,spatialReference:t}=this.metadata,{maxReconnectionAttempts:s,maxReconnectionInterval:i,geometryDefinition:n,definitionExpression:o,customParameters:a}=this._schema.full;this._streamConnection=(0,da.createConnection)(this._service.source,t,this._service.outSpatialReference,e,o,n,s,i,a),this._handlesGroup=(0,r.vE)([this._streamConnection.on("data-received",e=>this._onFeature(e)),this._streamConnection.on("message-received",e=>this._onWebSocketMessage(e))]),this._connectionState.connection=this._streamConnection}clear(){this._manager.checkForUpdates(),this._stagingStore.clear(),this._forceRefresh=!0}updateCustomParameters(e){this._streamConnection?.updateCustomParameters(e)}sendMessageToSocket(e){this._streamConnection?.sendMessageToSocket(e)}sendMessageToClient(e){this._streamConnection?.sendMessageToClient(e)}_onOverride(){}_onWebSocketMessage(e){if("type"in e)switch(e.type){case"delete":if(e.objectIds)for(const t of e.objectIds)this._manager.removeById(t);if(e.trackIds)for(const t of e.trackIds)this._manager.removeByTrackId(t);break;case"clear":this.clear()}this.events.emit("message-received",e)}_onFeature(e){try{this._manager.add(e),this.events.emit("data-received",e)}catch(e){}}}var xa=s(44320),wa=s(79897);let ba=class extends R.A{constructor(e){super(e),this.debugName="",this._updatingHandles=new wa.U,this._idToUpdatingState=new q.A}destroy(){this._updatingHandles=(0,_.pR)(this._updatingHandles),this._idToUpdatingState.clear()}get updating(){const e=!this.destroyed&&(this._updatingHandles?.updating||Array.from(this._idToUpdatingState.values()).some(e=>e));if((0,n.A)("esri-2d-log-updating")){const t=Array.from(this._idToUpdatingState.entries()).map(([e,t])=>`-> ${e}: ${t}`).join("\n");console.log(`${this.debugName}: Updating: ${e}\n-> Handles: ${this._updatingHandles.updating}\n${t}`)}return e}addUpdateTracking(e,t){const s=(0,l.wB)(()=>t.updating,t=>this._idToUpdatingState.set(e,t),{sync:!0});this.addHandles(s)}consumePromise(e){this._updatingHandles.consumePromise(e)}addPromise(e){return this._updatingHandles.addPromise(e)}};(0,P.Cg)([(0,L.MZ)({constructOnly:!0})],ba.prototype,"debugName",void 0),(0,P.Cg)([(0,L.MZ)({readOnly:!0})],ba.prototype,"updating",null),ba=(0,P.Cg)([(0,fa.$)("esri.views.2d.layers.support.UpdateTracking2D")],ba);class va{constructor(e,t,s,i){this._aggregateAdapter=e,this._subscriptions=t,this._connection=s,this._cachedObjectIds=i,this._updateTracking=new ba({debugName:"FeatureSource"}),this.store=new xa.I}destroy(){this._strategy?.destroy(),this._streamMessenger?.destroy(),this._updateTracking?.destroy(),this.store.destroy()}get metadata(){return this._strategy.metadata}get streamMessenger(){return null==this._streamMessenger&&this._initStreamMessenger(),this._streamMessenger}get statistics(){return po.from(this.store)}get updateTracking(){return this._updateTracking}get usedMemory(){return this.store.usedMemory}get queryEngine(){if(!this._queryEngine){if(!this.store||!this._strategy)return null;this._queryEngine=new Zr.do({featureStore:this.store,fieldsIndex:this.metadata.fieldsIndex,geometryType:this.metadata.geometryType,featureIdInfo:this.metadata.featureIdInfo,hasZ:this.metadata.hasZ,hasM:this.metadata.hasM,spatialReference:this.metadata.outSpatialReference,aggregateAdapter:this._aggregateAdapter,timeInfo:this.metadata.timeInfo,definitionExpression:this._strategy?.definitionExpression,availableFields:this._strategy?.availableFields})}return this._queryEngine}get isStream(){return"stream"===this._schema.type}get hasQueryDisplayFilter(){if(!this._schema)return!1;switch(this._schema.type){case"feature":return null!=this._schema.strategy.full.displayFilterInfo;case"parquet":case"stream":return!1}}chunks(){return Array.from(this.store.chunks())}prepareCacheUpdate(e,t){const s=new Set,i=new Set;for(const t of e)this._cachedObjectIds.has(t)||(this._cachedObjectIds.add(t),s.add(t));for(const e of t)this._cachedObjectIds.delete(e),i.add(e);this.hasQueryDisplayFilter&&this._strategy.prepareCacheUpdate(s,i)}async applyCacheUpdate(){this.hasQueryDisplayFilter&&await this._updateTracking.addPromise(this._strategy.applyCacheUpdate())}cleanup(){return this.store.cleanup()}onSubscribe(e){if(this._connection.onEvent({type:"subscribe",tile:e.tile.id}),!this._strategy)return;const t=this._strategy.load(e);t.then(()=>this._connection.onEvent({type:"loaded",tile:e.tile.id})).catch(t=>this._connection.onEvent({type:"error",tile:e.tile.id,error:t})),this._updateTracking.consumePromise(t)}onResume(e){this._updateTracking.consumePromise((0,a.QZ)(this._strategy?.load(e)))}onUnsubscribe(e){this._connection.onEvent({type:"unsubscribe",tile:e.tile.id}),this._strategy?.unload(e)}async applyOverride(e){await(this._strategy?.applyOverride(e))}takeOverrideUpdate(){return this._strategy?.takeOverrideUpdate()}async update(e,t){const s=this._schema;if(this._schema=e,this._queryEngine=(0,_.pR)(this._queryEngine),s&&s.type!==e.type)throw new Error("InternalError: Reconfiguring source types is not supported.");const i=new _o;if(!s||(0,m.i8)(s.service,e.service)||s.strategy.type!==e.strategy.type||(0,m.i8)(e.strategy.full,s.strategy.full)||!await this._strategy.tryUpdate(i,e.strategy.partial)){await this._updateStrategyType(this._schema.service,e,t);let s=null;return"postQueryFilter"in this._schema.strategy.full&&this._schema.strategy.full.postQueryFilter&&(s=await Fn.create({geometryType:this.metadata.geometryType,hasM:!1,hasZ:!1,timeInfo:this.metadata.timeInfo,fieldsIndex:this.metadata.fieldsIndex,spatialReference:this.metadata.outSpatialReference,filterJSON:this._schema.strategy.full.postQueryFilter})),await this.store.update({metadata:this.metadata,definitionExpression:this._schema.strategy.full.definitionExpression,postQueryFilter:s}),!0}return i.requiresInvalidation}unsafeSetQueryHistoricMoment(e){"feature"===this._schema.type&&(this._schema.strategy.full.historicMoment=e,this._strategy.unsafeSetQueryHistoricMoment(new Date(e)))}_initStreamMessenger(){null==this._streamMessenger&&(this._streamMessenger=new fo(this._connection))}async normalizeOverrides(e){const t={historicMoment:e.historicMoment,commands:{updateWeak:e.commands.updateWeak.map(Ur.Om.fromJSON),removeWeak:e.commands.removeWeak,update:e.commands.update.map(Ur.Om.fromJSON),remove:e.commands.remove,release:e.commands.release}},s=e.commands.updateByIdWeak,i=await this._queryOptimizedFeatures(s);if(i.length!==s.length){const e=new Set(i.map(e=>e.objectId));for(const i of s)e.has(i)||t.commands.removeWeak.push(i)}return t.commands.updateWeak.push(...i),t}async _queryOptimizedFeatures(e){if(0===e.length)return[];const t=[],s=(await this._strategy.queryByObjectId(e,["*"])).getCursor();for(;s.next();)t.push(s.readOptimizedFeatureWorldSpace());return t}getObjectIdsFromGlobalIds(e){const t=this.metadata.globalIdField;if(null==t)throw new Error("InternalError: Recieved an edit with globalIds, but not supported by the service");const s=this.store.mapObjectIdsFromGlobalIds(e,t).values();return Array.from(s)}async _updateStrategyType(e,t,s){const i=this._createStrategy(e,t);this._connection.onEvent({type:"updateStrategyStart",about:i.about});const r=!!this._strategy;this.store.clear(),this._strategy?.destroy(),this._strategy=i,(0,n.A)("esri-2d-update-debug")&&console.debug(`Version[${s}] FeatureSource.updateStrategy`,{strategy:i});const o=Array.from(this._subscriptions.values());if(!o.length)return void this._connection.onEvent({type:"updateStrategyEnd"});const c=Promise.all(o.map(e=>this._strategy.load(e).then(()=>this._connection.onEvent({type:"loaded",tile:e.tile.id})).catch(t=>this._connection.onEvent({type:"error",tile:e.tile.id,error:t}))));this._updateTracking.consumePromise(c),this._strategy.prepareCacheUpdate(this._cachedObjectIds);try{r&&await c}catch(e){(0,a.jH)(e)}this._connection.onEvent({type:"updateStrategyEnd"}),(0,n.A)("esri-2d-update-debug")&&console.debug(`Version[${s}] FeatureSource.updateStrategyEnd`,{strategy:i})}_createStrategy(e,t){const s={connection:this._connection,store:this.store};switch(t.type){case"feature":return this._createFeatureLoadStrategy(e,t.strategy,s);case"parquet":return this._createParquetLoadStrategy(e,t.strategy,s);case"stream":return this._createStreamLoadStrategy(e,t.strategy,s)}}_createFeatureLoadStrategy(e,t,s){switch(t.type){case"drill-down":return new Qo(e,t,s);case"paged-tile":return new Jo(e,t,s);case"snapshot":return new ta(e,t,s)}}_createParquetLoadStrategy(e,t,s){switch(t.type){case"xz":return new la(e,t,s,this._connection);case"snapshot":return new oa(e,t,s,this._connection)}}_createStreamLoadStrategy(e,t,s){const i=new ga(e,t,s);return this.streamMessenger.strategy=i,i}}class Sa{constructor(e,t){this.tile=e,this.version=t,this._abortController=new AbortController}get key(){return this.tile.key}get signal(){return this._abortController.signal}abort(){this._abortController.abort()}}var Ia=s(98291);class Ta{constructor(e,t){this.key=new w.A(0,0,0,0),this.bounds=(0,Y.vt)(),this.objectIds=new Set,this.key.set(t);const s=e.getLODInfoAt(this.key);this.tileInfoView=e,this.tileInfoView.getTileBounds(this.bounds,this.key,!0),this.resolution=s.resolution,this.level=s.level,this.scale=s.scale,this.minScale=e.zoomToScale(s.level-1),this.maxScale=e.zoomToScale(s.level+1)}get lod(){return this.tileInfoView.getLODInfoAt(this.key)}get id(){return this.key.id}get extent(){const[e,t,s,i]=this.bounds;return{xmin:e,ymin:t,xmax:s,ymax:i}}get hydratedExtent(){return(0,Y.w1)(this.bounds,this.tileInfoView.spatialReference)}get transform(){return{originPosition:"upperLeft",scale:[this.resolution,this.resolution],translate:[this.bounds[0],this.bounds[3]]}}get normalizedTransform(){return(0,g.Q1)(this.transform)}createArcadeEvaluationOptions(e){return(0,Un.N)(this.scale,e)}createChildTiles(){const e=this.key.getChildKeys(),t=Ia.A.acquire();for(let s=0;s<e.length;s++)t[s]=new Ta(this.tileInfoView,e[s]);return t}getQuantizationParameters(){return ea.A.fromJSON({mode:"view",originPosition:"upperLeft",tolerance:this.resolution,extent:{xmin:this.bounds[0],ymin:this.bounds[1],xmax:this.bounds[2],ymax:this.bounds[3],spatialReference:this.tileInfoView.spatialReference}})}}class ka{constructor(e){this.inner=e,this.resolver=Promise.withResolvers()}}class Aa{constructor(){this._aggregateAdapter={getFeatureObjectIds:e=>this._processor.getFeatureObjectIdsForAggregate(e)},this._subscriptions=new Map,this._cachedObjectIds=new Set,this._updateRequested=!1,this._didSourceRefresh=!1,this._refreshRequested=!0,this._updateSubscriptionRequests=[],this._updateHighlightRequests=[]}destroy(){this._subscriptions.clear(),this._processor?.destroy(),this._source?.destroy(),this._handles?.remove(),this._updateOverridesRequest=null,this._tileInfoView=null}onAttach(e){(0,n.A)("esri-2d-update-debug")&&console.debug("Pipeline.onAttach");const t=this._connection,s=d.A.fromJSON(e.tileInfoJSON);this._tileInfoView=new E(s),this._viewExtent=e.initialViewExtent,this._source=new va(this._aggregateAdapter,this._subscriptions,t,this._cachedObjectIds),this._processor=new uo(t,this._source,e.requiredLevel,e.requiredScale),this._handles=(0,r.vE)([this._source.store.events.on("changed",()=>this._requestUpdate()),this._source.store.events.on("refresh",()=>this._requestRefresh()),(0,l.wB)(()=>this._source.updateTracking.updating,()=>{this._requestUpdate(),(0,a.QZ)(this._connection.layerView.setUpdating({source:this._source.updateTracking.updating,pipeline:!0}))})])}onDetach(){(0,n.A)("esri-2d-update-debug")&&console.debug("Pipeline.onDetach"),this.destroy()}set remoteClient(e){this._connection=new f(e)}get features(){const e=this._source?.queryEngine;if(!e)throw new i.A("no-queryEngine","No query engine defined");return e}get aggregates(){const e=this._processor?.aggregateQueryEngine;if(!e)throw new i.A("no-queryEngine","No aggregate query engine defined");return e}get streamMessenger(){return this._source.streamMessenger}getUsedMemory(){return this._source.usedMemory+this._processor.usedMemory}getDisplayFeatures(e){return this._processor.getDisplayFeatures(e)}getDisplayIds(e){return this._processor.getDisplayIds(e)}getObjectIdsFromGlobalIds(e){return this._source.getObjectIdsFromGlobalIds(e)}updateStationaryExtent(e,t){t&&(this._refreshRequested=!0,this._requestUpdate()),this._viewExtent=e}updateRequiredLevel(e,t){this._processor.updateRequiredLevel(e,t),this._processor.hasClusters&&this._requestUpdate()}async updateSchema(e,t){return(0,n.A)("esri-2d-update-debug")&&this._updateSchemaRequest&&console.error("InternalError: Schema already updating"),this._updateSchemaRequest=new ka({schema:e,version:t}),this._requestUpdate(),this._updateSchemaRequest.resolver.promise}updateSubscriptions(e){const t=new ka(e);return this._updateSubscriptionRequests.push(t),this._requestUpdate(),t.resolver.promise}updateHighlight(e){const t=new ka(e);return this._updateHighlightRequests.push(t),this._requestUpdate(),t.resolver.promise}async onOverride(e){if(null!=this._updateOverridesRequest)throw new i.A("featurelayer","InternalError - Already processing an edit");this._updateOverridesRequest=new ka(e);const t=this._updateOverridesRequest.resolver.promise;return this._requestUpdate(),t}queryStatistics(){return this._source.statistics.toJSON()}async queryVisibleFeatures(e,t){return this.features.executeQuery(e,t)}async queryHeatmapStatistics(e){const t=Math.round((0,u.Lz)(e.radius));let s=Number.POSITIVE_INFINITY,i=Number.NEGATIVE_INFINITY;const r="string"==typeof e.fieldOffset,n=e.fieldOffset??0,o=Array.from(this._subscriptions.values()),a=this._source.chunks(),c=t**2,l=3/(Math.PI*c),h=2*t,d=Math.ceil(p.CQ/h);for(const t of o){const o=t.tile,u=new Float64Array(d*d);for(const t of a){const s=t.getTileReader(o);if(!s)continue;const i=s.getCursor();for(;i.next();){let t=1;if(null!=e.field){const s=i.readAttribute(e.field);t=r?-1*+s:+s+n}const s=i.readXForDisplay()/h,o=i.readYForDisplay()/h,a=Math.floor(s),p=Math.floor(o);if(a<0||p<0||a>=d||p>=d)continue;const f=((.5+a-s)*h)**2+((.5+p-o)*h)**2;if(f>c)continue;const _=t*(l*(1-f/c)**2);u[p+a*d]+=_}}for(let e=0;e<u.length;e++)s=Math.min(s,u[e]),i=Math.max(i,u[e])}return{max:i,min:s}}async getSampleFeatures(e){const t=this._source.chunks();if(t.reduce((e,t)=>e+t.size(),0)<=e.minFeatureCount){if(!this._source.updateTracking.updating){const e=[];return this._source.store.forEachUnsafe(t=>e.push(t.readLegacyFeatureWorldSpace())),e}return null}const s=new Set,i=[],r=t.map(e=>e.reader.getCursor()),n=new c.A,o=3*e.sampleSize;for(let a=0;a<o&&i.length<e.sampleSize;a++){const e=r[n.getIntRange(0,t.length-1)];if(0===e.getSize())continue;const o=n.getIntRange(0,e.getSize()-1);e.setIndex(o);const a=e.getObjectId();s.has(a)||(s.add(a),i.push(e.readLegacyFeatureWorldSpace()))}return i.length>=e.sampleSize?i:null}_requestUpdate(){this._updateRequested||(this._updateRequested=!0,(0,o.d)(()=>this._scheduleNextUpdate()))}_requestRefresh(){this._didSourceRefresh=!0,this._requestUpdate()}_scheduleNextUpdate(){this._updateRequested&&(this._ongoingUpdate||(this._ongoingUpdate=(0,h.oV)(this._doUpdate()).finally(()=>{this._ongoingUpdate=null,this._scheduleNextUpdate()}),this._updateRequested=!1))}_subscribe(e){const t=e.tileId;if(this._subscriptions.has(t))return;(0,n.A)("esri-2d-update-debug")&&console.debug(`Tile[${t}] Pipeline.subscribe`);const s=new Ta(this._tileInfoView,t),i=new Sa(s,e.version);this._subscriptions.set(t,i),this._source.onSubscribe(i),this._processor.onSubscribe(i)}_unsubscribe(e){const t=this._subscriptions.get(e);t&&((0,n.A)("esri-2d-update-debug")&&console.debug(`Tile[${e}] Pipeline.unsubscribe`),t.abort(),this._source.onUnsubscribe(t),this._processor.onUnsubscribe(t),this._subscriptions.delete(t.key.id))}async _doUpdate(){if((0,n.A)("esri-2d-update-debug")&&console.debug("Pipeline._doUpdateStart"),await this._connection.layerView.setUpdating({source:this._source.updateTracking.updating,pipeline:!0}),this._updateSubscriptionRequests.length){const e=this._updateSubscriptionRequests;this._updateSubscriptionRequests=[];for(const t of e)this._doUpdateSubscriptions(t.inner),t.resolver.resolve()}if(this._updateHighlightRequests.length){const e=this._updateHighlightRequests,t=new Set,s=new Set;for(const i of e)for(const{objectId:e,highlightFlags:r}of i.inner.highlights)r?(t.add(e),s.delete(e)):(s.add(e),t.delete(e));this._source.prepareCacheUpdate(t,s)}const e=this._updateSchemaRequest;this._updateSchemaRequest=null;let t=!1;if(null!=e){const{schema:s,version:i}=e.inner;t=await this._doUpdateSchema(s,i)}this._processor.requiresInvalidation()&&(t=!0),this._didSourceRefresh&&(t=!0,this._didSourceRefresh=!1),this._refreshRequested&&(this._refreshRequested=!1,t=!0),t&&(this._processor.invalidate(),await this._connection.container.updateRenderState(this._processor.version));const s=this._updateOverridesRequest;if(this._updateOverridesRequest=null,null!=s){(0,n.A)("esri-2d-update-debug")&&console.debug("Pipeline.applyOverride",s.inner),null!=s.inner.historicMoment&&this._source.unsafeSetQueryHistoricMoment(s.inner.historicMoment);const e=await this._source.normalizeOverrides(s.inner);await this._source.applyOverride(e),(0,n.A)("esri-2d-update-debug")&&console.debug("Pipeline.endOverride",s.inner)}if(await this._source.applyCacheUpdate(),this._updateHighlightRequests.length){const e=this._updateHighlightRequests;this._updateHighlightRequests=[];for(const t of e)this._processor.updateHighlight(t.inner),t.resolver.resolve()}const i=this._source.cleanup();this._processor.removeChunks(i);try{const e=this._source.takeOverrideUpdate();if(null!=e&&this._subscriptions.size){(0,n.A)("esri-2d-update-debug")&&console.debug("Pipeline.applyOverrideChangesStart"),await this._connection.container.lockForOverrides();try{await this._processor.applyOverrideUpdate(e,this._viewExtent)}catch(e){(0,n.A)("esri-2d-update-debug")&&console.debug("InternalError",e)}await this._connection.container.unlockForOverrides(),(0,n.A)("esri-2d-update-debug")&&console.debug("Pipeline.applyOverrideChangesEnd")}this._subscriptions.size&&((0,n.A)("esri-2d-update-debug")&&console.debug("Pipeline.updateChunksStart"),await this._processor.updateChunks(this._viewExtent),(0,n.A)("esri-2d-update-debug")&&console.debug("Pipeline.updateChunksEnd"))}catch(e){(0,a.jH)(e)}null!=s&&s.resolver.resolve(),null!=e&&e.resolver.resolve(),null==e&&t&&await this._connection.container.trySwapRenderState(),this._connection.onEvent({type:"performance",usedMemory:this.getUsedMemory()}),this._updateRequested?((0,n.A)("esri-2d-update-debug")&&console.debug("Pipeline._doUpdateEnd [updateRequested=true]"),await this._connection.layerView.setUpdating({source:this._source.updateTracking.updating,pipeline:!0})):((0,n.A)("esri-2d-update-debug")&&console.debug("Pipeline._doUpdateEnd [updateRequested=false, After flush]"),await this._connection.layerView.setUpdating({source:this._source.updateTracking.updating,pipeline:this._updateRequested}))}async _doUpdateSchema(e,t){(0,n.A)("esri-2d-update-debug")&&console.debug(`Version[${t}] Pipeline.updateStart`,{schema:e});const s={tileInfo:this._tileInfoView?.tileInfo},i=await this._source.update(e.source,t),r=Array.from(this._subscriptions.values()),o=this._processor.update(e,t,s,i,r);return(0,n.A)("esri-2d-update-debug")&&console.debug(`Version[${t}] Pipeline.updateEnd`),o}_doUpdateSubscriptions(e){(0,n.A)("esri-2d-update-debug")&&console.debug("Pipeline.updateSubscriptions",e);for(const t of e.subscribe)this._subscribe(t);for(const t of e.unsubscribe)this._unsubscribe(t)}}},44159(e,t,s){s.d(t,{A:()=>r});var i=s(93687);class r{static{this.pool=new i.A(()=>new r(""),null,null,25,50)}static getId(e,t,s,i){return"object"==typeof e?`${e.level}/${e.row}/${e.col}/${e.world}`:`${e}/${t}/${s}/${i}`}constructor(e,t,s,i){this.set(e,t,s,i)}get key(){return this}get id(){return this.toString()}get normalizedId(){return`${this.level}/${this.row}/${this.col}`}set id(e){this.set(e)}get hash(){const e=4095&this.row,t=4095&this.col,s=63&this.level;return(3&this.world)<<30|t<<22|e<<8|s}acquire(e,t,s,i){this.set(e,t,s,i)}contains(e){const t=e.level-this.level;return t>=0&&this.row===e.row>>t&&this.col===e.col>>t&&this.world===e.world}containsChild(e){const t=e.level-this.level;return t>0&&this.row===e.row>>t&&this.col===e.col>>t&&this.world===e.world}equals(e){return this.level===e.level&&this.row===e.row&&this.col===e.col&&this.world===e.world}clone(){return new r(this)}release(){this.level=0,this.row=0,this.col=0,this.world=0}set(e,t,s,i){if(null==e)this.level=0,this.row=0,this.col=0,this.world=0;else if("object"==typeof e)this.level=e.level||0,this.row=e.row||0,this.col=e.col||0,this.world=e.world||0;else if("string"==typeof e){const[t,s,i,r]=e.split("/");this.level=parseFloat(t),this.row=parseFloat(s),this.col=parseFloat(i),this.world=parseFloat(r)}else this.level=+e,this.row=+t,this.col=+s,this.world=+i||0;return this}toString(){return`${this.level}/${this.row}/${this.col}/${this.world}`}getParentKey(){return this.level<=0?null:new r(this.level-1,this.row>>1,this.col>>1,this.world)}getNormalizedNeighbor(e,t,s){const i=this.clone();return i.col+=e,i.row+=t,s.normalizeKey(i),i}getChildKeys(){const e=this.level+1,t=this.row<<1,s=this.col<<1,i=this.world;return[new r(e,t,s,i),new r(e,t,s+1,i),new r(e,t+1,s,i),new r(e,t+1,s+1,i)]}compareRowMajor(e){return this.row<e.row?-1:this.row>e.row?1:this.col<e.col?-1:this.col>e.col?1:0}}},63907(e,t,s){s.d(t,{$0:()=>d,C5:()=>h,CQ:()=>g,H0:()=>n,SB:()=>c,WR:()=>i,XN:()=>o,iE:()=>a,ld:()=>l,nI:()=>_,pe:()=>r,r6:()=>p,uH:()=>y,vt:()=>u,xL:()=>m,yI:()=>f});const i={POINTS:0,LINES:1,LINE_LOOP:2,LINE_STRIP:3,TRIANGLES:4,TRIANGLE_STRIP:5,TRIANGLE_FAN:6},r={BYTE:5120,UNSIGNED_BYTE:5121,SHORT:5122,UNSIGNED_SHORT:5123,INT:5124,UNSIGNED_INT:5125,FLOAT:5126,HALF_FLOAT:5131},n={RGBA4:32854,R16F:33325,RG16F:33327,RGB32F:34837,RGBA16F:34842,R32F:33326,RG32F:33328,RGBA32F:34836,R11F_G11F_B10F:35898,RGB8:32849,RGBA8:32856,RGB5_A1:32855,R8:33321,RG8:33323,R8I:33329,R8UI:33330,R16I:33331,R16UI:33332,R32I:33333,R32UI:33334,RG8I:33335,RG8UI:33336,RG16I:33337,RG16UI:33338,RG32I:33339,RG32UI:33340,RGB16F:34843,RGB9_E5:35901,SRGB8:35905,SRGB8_ALPHA8:35907,RGB565:36194,RGBA32UI:36208,RGB32UI:36209,RGBA16UI:36214,RGB16UI:36215,RGBA8UI:36220,RGB8UI:36221,RGBA32I:36226,RGB32I:36227,RGBA16I:36232,RGB16I:36233,RGBA8I:36238,RGB8I:36239,R8_SNORM:36756,RG8_SNORM:36757,RGB8_SNORM:36758,RGBA8_SNORM:36759,RGB10_A2:32857,RGB10_A2UI:36975},o=Object.values(n),a={DEPTH24_STENCIL8:35056,DEPTH32F_STENCIL8:36013},c={DEPTH_COMPONENT16:33189,DEPTH_COMPONENT24:33190,DEPTH_COMPONENT32F:36012},l={FLOAT:r.FLOAT,UNSIGNED_BYTE:r.UNSIGNED_BYTE,UNSIGNED_INT_24_8:34042,UNSIGNED_SHORT_4_4_4_4:32819,UNSIGNED_SHORT_5_5_5_1:32820,UNSIGNED_SHORT_5_6_5:33635,BYTE:r.BYTE,UNSIGNED_SHORT:r.UNSIGNED_SHORT,SHORT:r.SHORT,UNSIGNED_INT:r.UNSIGNED_INT,INT:r.INT,HALF_FLOAT:5131,UNSIGNED_INT_2_10_10_10_REV:33640,UNSIGNED_INT_10F_11F_11F_REV:35899,UNSIGNED_INT_5_9_9_9_REV:35902,FLOAT_32_UNSIGNED_INT_24_8_REV:36269},u={Texture:0,TileTexture:1,BufferObject:2,VertexArrayObject:3,Shader:4,Program:5,FramebufferObject:6,Renderbuffer:7,TransformFeedback:8,Sync:9,UNCOUNTED:10,LinesOfCode:10,Uniform:11,COUNT:12},h=1029,d=0,p=36064,f=36065,_=33306,m=36096,y=36128,g={COMPRESSED_RGB_S3TC_DXT1_EXT:33776,COMPRESSED_RGBA_S3TC_DXT1_EXT:33777,COMPRESSED_RGBA_S3TC_DXT3_EXT:33778,COMPRESSED_RGBA_S3TC_DXT5_EXT:33779,COMPRESSED_R11_EAC:37488,COMPRESSED_SIGNED_R11_EAC:37489,COMPRESSED_RG11_EAC:37490,COMPRESSED_SIGNED_RG11_EAC:37491,COMPRESSED_RGB8_ETC2:37492,COMPRESSED_SRGB8_ETC2:37493,COMPRESSED_RGB8_PUNCHTHROUGH_ALPHA1_ETC2:37494,COMPRESSED_SRGB8_PUNCHTHROUGH_ALPHA1_ETC2:37495,COMPRESSED_RGBA8_ETC2_EAC:37496,COMPRESSED_SRGB8_ALPHA8_ETC2_EAC:37497}}}]);
|