@arcgis/core 5.0.0-next.73 → 5.0.0-next.75

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.
Files changed (304) hide show
  1. package/Color.d.ts +8 -0
  2. package/WebDocument2D.d.ts +5 -30
  3. package/analysis/ElevationProfile/ElevationProfileLineQuery.d.ts +1 -1
  4. package/assets/esri/core/workers/RemoteClient.js +1 -1
  5. package/assets/esri/core/workers/chunks/0b666327e8090a6e6f6a.js +1 -0
  6. package/assets/esri/core/workers/chunks/16a7edb381621085a631.js +1 -0
  7. package/assets/esri/core/workers/chunks/{e246b256347a281c13fd.js → 22288b62da20a7a78a4f.js} +1 -1
  8. package/assets/esri/core/workers/chunks/{7e37a3005f2ad2c0a918.js → 23cf4cbc389d2b50e968.js} +1 -1
  9. package/assets/esri/core/workers/chunks/4750f55a289bc0cf3d77.js +1 -0
  10. package/assets/esri/core/workers/chunks/{935a6dccb88557f98189.js → 76b516b8c110ad983bf6.js} +8 -6
  11. package/assets/esri/core/workers/chunks/a5181292b309b8249bd8.js +1 -0
  12. package/assets/esri/core/workers/chunks/ae733ee050f27f7d8924.js +1 -0
  13. package/assets/esri/core/workers/chunks/{64985e9b6e2edb3ceb37.js → b498db9715a722c52995.js} +45 -58
  14. package/assets/esri/core/workers/chunks/befeca51530bba5e8073.js +1 -0
  15. package/assets/esri/core/workers/chunks/cd788ed111e1e35cf9c8.js +1 -0
  16. package/assets/esri/core/workers/chunks/f35021214e534d5e0446.js +1 -0
  17. package/assets/esri/themes/base/widgets/_FeatureTable.scss +99 -22
  18. package/assets/esri/themes/dark/main.css +1 -1
  19. package/assets/esri/themes/light/main.css +1 -1
  20. package/assets/esri/themes/light/view.css +1 -1
  21. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable.json +1 -1
  22. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_ar.json +1 -1
  23. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_bg.json +1 -1
  24. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_bs.json +1 -1
  25. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_ca.json +1 -1
  26. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_cs.json +1 -1
  27. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_da.json +1 -1
  28. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_de.json +1 -1
  29. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_el.json +1 -1
  30. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_en.json +1 -1
  31. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_es.json +1 -1
  32. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_et.json +1 -1
  33. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_fi.json +1 -1
  34. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_fr.json +1 -1
  35. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_he.json +1 -1
  36. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_hr.json +1 -1
  37. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_hu.json +1 -1
  38. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_id.json +1 -1
  39. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_it.json +1 -1
  40. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_ja.json +1 -1
  41. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_ko.json +1 -1
  42. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_lt.json +1 -1
  43. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_lv.json +1 -1
  44. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_nl.json +1 -1
  45. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_no.json +1 -1
  46. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_pl.json +1 -1
  47. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_pt-BR.json +1 -1
  48. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_pt-PT.json +1 -1
  49. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_ro.json +1 -1
  50. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_ru.json +1 -1
  51. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_sk.json +1 -1
  52. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_sl.json +1 -1
  53. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_sr.json +1 -1
  54. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_sv.json +1 -1
  55. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_th.json +1 -1
  56. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_tr.json +1 -1
  57. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_uk.json +1 -1
  58. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_vi.json +1 -1
  59. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_zh-CN.json +1 -1
  60. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_zh-HK.json +1 -1
  61. package/assets/esri/widgets/FeatureTable/t9n/FeatureTable_zh-TW.json +1 -1
  62. package/chunks/ComponentShader.glsl.js +1 -1
  63. package/chunks/GlowBlur.glsl.js +2 -3
  64. package/chunks/HUDMaterial.glsl.js +43 -56
  65. package/config.d.ts +6 -8
  66. package/config.js +1 -1
  67. package/core/Collection.d.ts +27 -1
  68. package/core/types.d.ts +0 -23
  69. package/core/urlUtils.d.ts +10 -0
  70. package/geometry/support/MeshTexture.d.ts +0 -2
  71. package/geometry/support/MeshVertexAttributes.d.ts +0 -2
  72. package/identity/IdentityManagerBase.d.ts +3 -6
  73. package/interfaces.d.ts +3 -3
  74. package/kernel.js +1 -1
  75. package/layers/BaseDynamicLayer.d.ts +1 -4
  76. package/layers/BaseElevationLayer.d.ts +3 -6
  77. package/layers/BuildingSceneLayer.d.ts +1 -4
  78. package/layers/CSVLayer.d.ts +1 -4
  79. package/layers/CatalogLayer.d.ts +1 -4
  80. package/layers/DimensionLayer.d.ts +1 -4
  81. package/layers/ElevationLayer.d.ts +3 -6
  82. package/layers/FeatureLayer.d.ts +1 -4
  83. package/layers/GaussianSplatLayer.d.ts +0 -1
  84. package/layers/GeoJSONLayer.d.ts +1 -4
  85. package/layers/GeoRSSLayer.d.ts +1 -4
  86. package/layers/GraphicsLayer.d.ts +1 -4
  87. package/layers/GroupLayer.d.ts +1 -4
  88. package/layers/ImageryLayer.d.ts +1 -4
  89. package/layers/ImageryTileLayer.d.ts +1 -4
  90. package/layers/IntegratedMesh3DTilesLayer.d.ts +1 -4
  91. package/layers/IntegratedMeshLayer.d.ts +1 -4
  92. package/layers/KMLLayer.d.ts +1 -4
  93. package/layers/Layer.d.ts +2 -6
  94. package/layers/LineOfSightLayer.d.ts +1 -4
  95. package/layers/MapImageLayer.d.ts +1 -4
  96. package/layers/MapNotesLayer.d.ts +1 -4
  97. package/layers/MediaLayer.d.ts +1 -4
  98. package/layers/OGCFeatureLayer.d.ts +1 -4
  99. package/layers/OrientedImageryLayer.d.ts +1 -4
  100. package/layers/ParquetLayer.d.ts +1 -4
  101. package/layers/PointCloudLayer.d.ts +1 -4
  102. package/layers/RouteLayer.d.ts +2 -5
  103. package/layers/SceneLayer.d.ts +1 -4
  104. package/layers/SubtypeGroupLayer.d.ts +1 -12
  105. package/layers/TileLayer.d.ts +1 -4
  106. package/layers/UnknownLayer.d.ts +1 -4
  107. package/layers/UnsupportedLayer.d.ts +1 -4
  108. package/layers/VectorTileLayer.d.ts +1 -4
  109. package/layers/VideoLayer.d.ts +1 -4
  110. package/layers/ViewshedLayer.d.ts +1 -4
  111. package/layers/VoxelLayer.d.ts +1 -4
  112. package/layers/WCSLayer.d.ts +1 -4
  113. package/layers/WFSLayer.d.ts +1 -4
  114. package/layers/WMSLayer.d.ts +1 -4
  115. package/layers/WMTSLayer.d.ts +1 -4
  116. package/layers/catalog/CatalogDynamicGroupLayer.d.ts +1 -4
  117. package/layers/catalog/CatalogFootprintLayer.d.ts +1 -4
  118. package/layers/knowledgeGraph/KnowledgeGraphSublayer.d.ts +1 -6
  119. package/layers/mixins/EditBusLayer.d.ts +0 -1
  120. package/layers/mixins/PublishableLayer.d.ts +15 -0
  121. package/layers/support/FeatureFilter.d.ts +0 -1
  122. package/layers/support/MosaicRule.d.ts +0 -4
  123. package/layers/support/PublishingInfo.d.ts +1 -1
  124. package/layers/support/types.d.ts +2 -2
  125. package/layers/types.d.ts +19 -6
  126. package/package.json +1 -1
  127. package/portal/PortalUser.d.ts +1 -1
  128. package/renderers/support/RendererLegendOptions.d.ts +0 -1
  129. package/request/types.d.ts +0 -1
  130. package/rest/support/NormalizationBinParametersMixin.d.ts +18 -20
  131. package/rest/support/PrintTemplate.d.ts +0 -1
  132. package/rest/support/RelationshipQuery.d.ts +1 -10
  133. package/rest/support/types.d.ts +29 -3
  134. package/smartMapping/heuristics/binLevel.d.ts +1 -1
  135. package/smartMapping/heuristics/scaleRange.d.ts +1 -1
  136. package/smartMapping/heuristics/sizeRange.d.ts +1 -1
  137. package/smartMapping/heuristics/types.d.ts +0 -2
  138. package/smartMapping/labels/bins.d.ts +1 -1
  139. package/smartMapping/labels/clusters.d.ts +1 -1
  140. package/smartMapping/popup/clusters.d.ts +1 -1
  141. package/smartMapping/popup/templates.d.ts +1 -1
  142. package/smartMapping/raster/renderers/classBreaks.d.ts +1 -1
  143. package/smartMapping/raster/renderers/colormap.d.ts +1 -1
  144. package/smartMapping/raster/renderers/flow.d.ts +0 -1
  145. package/smartMapping/raster/renderers/rgb.d.ts +1 -1
  146. package/smartMapping/raster/renderers/shadedRelief.d.ts +0 -1
  147. package/smartMapping/raster/renderers/stretch.d.ts +1 -1
  148. package/smartMapping/raster/renderers/uniqueValue.d.ts +0 -1
  149. package/smartMapping/raster/renderers/vectorField.d.ts +0 -1
  150. package/smartMapping/raster/support/utils.d.ts +0 -2
  151. package/smartMapping/renderers/color.d.ts +6 -6
  152. package/smartMapping/renderers/dotDensity.d.ts +0 -1
  153. package/smartMapping/renderers/heatmap.d.ts +1 -1
  154. package/smartMapping/renderers/location.d.ts +0 -1
  155. package/smartMapping/renderers/opacity.d.ts +1 -1
  156. package/smartMapping/renderers/pieChart.d.ts +0 -2
  157. package/smartMapping/renderers/predominance.d.ts +0 -1
  158. package/smartMapping/renderers/relationship.d.ts +0 -1
  159. package/smartMapping/renderers/size.d.ts +4 -6
  160. package/smartMapping/renderers/type.d.ts +9 -5
  161. package/smartMapping/renderers/univariateColorSize.d.ts +2 -2
  162. package/smartMapping/statistics/classBreaks.d.ts +1 -1
  163. package/smartMapping/statistics/heatmapStatistics.d.ts +1 -1
  164. package/smartMapping/statistics/histogram.d.ts +1 -1
  165. package/smartMapping/statistics/predominantCategories.d.ts +1 -1
  166. package/smartMapping/statistics/summaryStatistics.d.ts +1 -1
  167. package/smartMapping/statistics/summaryStatisticsForAge.d.ts +1 -1
  168. package/smartMapping/statistics/support/ageUtils.d.ts +1 -1
  169. package/smartMapping/statistics/types.d.ts +26 -8
  170. package/smartMapping/statistics/uniqueValues.d.ts +1 -1
  171. package/smartMapping/symbology/color.d.ts +4 -4
  172. package/smartMapping/symbology/dotDensity.d.ts +3 -3
  173. package/smartMapping/symbology/flow.d.ts +3 -3
  174. package/smartMapping/symbology/heatmap.d.ts +3 -3
  175. package/smartMapping/symbology/location.d.ts +1 -1
  176. package/smartMapping/symbology/pieChart.d.ts +3 -3
  177. package/smartMapping/symbology/predominance.d.ts +3 -3
  178. package/smartMapping/symbology/relationship.d.ts +3 -3
  179. package/smartMapping/symbology/size.d.ts +1 -1
  180. package/smartMapping/symbology/support/colorRamps.d.ts +1 -1
  181. package/smartMapping/symbology/type.d.ts +3 -3
  182. package/support/revision.js +1 -1
  183. package/symbols/cim/types.d.ts +0 -12
  184. package/symbols/support/symbolUtils.d.ts +1 -1
  185. package/views/2d/MapViewConstraints.d.ts +2 -10
  186. package/views/2d/engine/brushes.js +1 -1
  187. package/views/2d/engine/vectorTiles/GlyphMosaic.js +1 -1
  188. package/views/2d/engine/vectorTiles/MemoryBuffer.js +1 -1
  189. package/views/2d/engine/vectorTiles/RenderBucket.js +1 -1
  190. package/views/2d/engine/vectorTiles/SpriteMosaic.js +1 -1
  191. package/views/2d/engine/vectorTiles/VTLPainter3D.js +1 -1
  192. package/views/2d/engine/vectorTiles/VectorTileContainer.js +1 -1
  193. package/views/2d/engine/vectorTiles/VertexMemoryBuffer.js +1 -1
  194. package/views/2d/engine/vectorTiles/shaders/VTLBackgroundMaterial.js +1 -1
  195. package/views/2d/engine/vectorTiles/shaders/VTLCircleMaterial.js +1 -1
  196. package/views/2d/engine/vectorTiles/shaders/VTLFillMaterial.js +1 -1
  197. package/views/2d/engine/vectorTiles/shaders/VTLLineMaterial.js +1 -1
  198. package/views/2d/engine/vectorTiles/shaders/VTLMaterial.js +1 -1
  199. package/views/2d/engine/vectorTiles/shaders/VTLSymbolMaterial.js +1 -1
  200. package/views/2d/engine/vectorTiles/style/StyleLayer.js +1 -1
  201. package/views/2d/engine/webgl/Painter.js +1 -1
  202. package/views/2d/engine/webgl/RenderingDevice.js +5 -0
  203. package/views/2d/engine/webgl/WGLContainer.js +1 -1
  204. package/views/2d/engine/webgl/meshing/Mesh.js +1 -1
  205. package/views/2d/engine/webgl/number.js +1 -1
  206. package/views/2d/engine/webgl/shaderGraph/graph/glsl.js +1 -1
  207. package/views/2d/engine/webgl/shaderGraph/techniques/shaders/vector-tiles/VTLShaderBackground.js +5 -0
  208. package/views/2d/engine/webgl/shaderGraph/techniques/shaders/vector-tiles/VTLShaderCircle.js +5 -0
  209. package/views/2d/engine/webgl/shaderGraph/techniques/shaders/vector-tiles/VTLShaderFill.js +5 -0
  210. package/views/2d/engine/webgl/shaderGraph/techniques/shaders/vector-tiles/VTLShaderIcon.js +5 -0
  211. package/views/2d/engine/webgl/shaderGraph/techniques/shaders/vector-tiles/VTLShaderLine.js +5 -0
  212. package/views/2d/engine/webgl/shaderGraph/techniques/shaders/vector-tiles/VTLShaderOutline.js +5 -0
  213. package/views/2d/engine/webgl/shaderGraph/techniques/shaders/vector-tiles/VTLShaderText.js +5 -0
  214. package/views/2d/engine/webgl/shaderGraph/techniques/vectorTiles/VTLTechniqueBackground.js +5 -0
  215. package/views/2d/engine/webgl/shaderGraph/techniques/vectorTiles/VTLTechniqueCircle.js +5 -0
  216. package/views/2d/engine/webgl/shaderGraph/techniques/vectorTiles/VTLTechniqueFill.js +5 -0
  217. package/views/2d/engine/webgl/shaderGraph/techniques/vectorTiles/VTLTechniqueLine.js +5 -0
  218. package/views/2d/engine/webgl/shaderGraph/techniques/vectorTiles/VTLTechniqueSymbol.js +5 -0
  219. package/views/2d/engine/webgl/shaderGraph/techniques/vectorTiles/VTLTechniques.js +5 -0
  220. package/views/2d/engine/webgl/shaders/sources/shaderRepository.js +1 -1
  221. package/views/3d/layers/IntegratedMesh3DTilesLayerView3D.js +1 -1
  222. package/views/3d/layers/graphics/Graphics3DIconSymbolLayer.js +1 -1
  223. package/views/3d/layers/graphics/Graphics3DTextSymbolLayer.js +1 -1
  224. package/views/3d/layers/i3s/meshUtils.js +1 -1
  225. package/views/3d/state/NearFarHeuristic.js +1 -1
  226. package/views/3d/webgl-engine/collections/Component/ComponentObjectCollection.js +1 -1
  227. package/views/3d/webgl-engine/collections/Component/Material/ComponentData.glsl.js +1 -1
  228. package/views/3d/webgl-engine/collections/Component/Material/ComponentMaterial.js +1 -1
  229. package/views/3d/webgl-engine/collections/Component/Material/ComponentTechniqueConfiguration.js +1 -1
  230. package/views/3d/webgl-engine/core/shaderLibrary/attributes/VertexNormal.glsl.js +6 -4
  231. package/views/3d/webgl-engine/core/shaderLibrary/attributes/VertexPosition.glsl.js +18 -14
  232. package/views/3d/webgl-engine/effects/glow/GlowBlur.glsl.js +1 -1
  233. package/views/3d/webgl-engine/effects/glow/GlowRenderNode.js +1 -1
  234. package/views/3d/webgl-engine/lib/edgeRendering/EdgeShaderTechniqueConfiguration.js +1 -1
  235. package/views/3d/webgl-engine/materials/HUDMaterial.js +1 -1
  236. package/views/3d/webgl-engine/shaders/HUDMaterial.glsl.js +1 -1
  237. package/views/3d/webgl-engine/shaders/HUDMaterialTechniqueConfiguration.js +1 -1
  238. package/views/3d/webgl-engine/shaders/sources/edgeRenderer/EdgeUtil.glsl.js +23 -20
  239. package/views/BreakpointsOwner.d.ts +2 -2
  240. package/views/LinkChartView.d.ts +0 -2
  241. package/views/View2D.d.ts +3 -15
  242. package/views/input/types.d.ts +2 -13
  243. package/views/layers/BuildingComponentSublayerView.d.ts +0 -1
  244. package/views/types.d.ts +2 -9
  245. package/views/webgl/RenderingContext.js +1 -1
  246. package/views/webgl/VertexArrayObject.js +1 -1
  247. package/views/webgl/renderState.js +1 -1
  248. package/webdoc/ips/SmoothingProperties.d.ts +1 -1
  249. package/webdoc/ips/SmoothingProperties.js +1 -1
  250. package/widgets/BasemapLayerList/BasemapLayerListVisibleElements.d.ts +10 -10
  251. package/widgets/BasemapLayerList/types.d.ts +6 -1
  252. package/widgets/Bookmarks/BookmarksVisibleElements.d.ts +0 -9
  253. package/widgets/Bookmarks/types.d.ts +0 -4
  254. package/widgets/CatalogLayerList/CatalogLayerListVisibleElements.d.ts +2 -2
  255. package/widgets/CatalogLayerList/types.d.ts +5 -1
  256. package/widgets/Editor/VisibleElements.d.ts +0 -11
  257. package/widgets/ElevationProfile/types.d.ts +1 -1
  258. package/widgets/FeatureTable/FeatureTableViewModel.js +1 -1
  259. package/widgets/FeatureTable/FieldColumn.d.ts +0 -1
  260. package/widgets/FeatureTable/VisibleElements.d.ts +2 -16
  261. package/widgets/FeatureTable/support/AttachmentsViewOptions.d.ts +5 -3
  262. package/widgets/FeatureTable/support/AttachmentsViewOptions.js +1 -1
  263. package/widgets/FeatureTable/support/FeatureStore.js +1 -1
  264. package/widgets/FeatureTable.js +1 -1
  265. package/widgets/Features/FeaturesViewModel.d.ts +3 -27
  266. package/widgets/Features/FeaturesVisibleElements.d.ts +4 -4
  267. package/widgets/LayerList/LayerListViewModel.d.ts +20 -5
  268. package/widgets/LayerList/LayerListVisibleElements.d.ts +10 -12
  269. package/widgets/LayerList/ListItem.d.ts +33 -0
  270. package/widgets/LayerList/ListItemPanel.d.ts +8 -2
  271. package/widgets/LayerList/types.d.ts +58 -15
  272. package/widgets/Legend/support/ActiveLayerInfo.js +1 -1
  273. package/widgets/Popup/PopupVisibleElements.d.ts +6 -6
  274. package/widgets/Popup/types.d.ts +1 -1
  275. package/widgets/ScaleRangeSlider/ScaleRanges.d.ts +1 -1
  276. package/widgets/Sketch/CreateToolVisibilityMap.d.ts +0 -4
  277. package/widgets/Sketch/VisibleElements.d.ts +0 -2
  278. package/widgets/Sketch/types.d.ts +1 -1
  279. package/widgets/TableList/ListItemPanel.d.ts +8 -0
  280. package/widgets/TableList/TableListViewModel.d.ts +9 -14
  281. package/widgets/TableList/TableListVisibleElements.d.ts +9 -11
  282. package/widgets/TableList/types.d.ts +13 -7
  283. package/widgets/support/SnappingControls/VisibleElements.d.ts +0 -4
  284. package/widgets/types.d.ts +1 -9
  285. package/assets/esri/core/workers/chunks/1d8fc0239c907ff5d1e8.js +0 -1
  286. package/assets/esri/core/workers/chunks/562cddaf63985e53ee6e.js +0 -1
  287. package/assets/esri/core/workers/chunks/b899b4e7979c13b99526.js +0 -1
  288. package/assets/esri/core/workers/chunks/d0ae8752419d5b761190.js +0 -1
  289. package/assets/esri/core/workers/chunks/df2ba5f9d57080fca183.js +0 -1
  290. package/assets/esri/core/workers/chunks/ee175fd4ec706f7878c0.js +0 -1
  291. package/assets/esri/core/workers/chunks/fc00d7278b43df813c54.js +0 -1
  292. package/layers/mixins/ScaleRange.d.ts +0 -16
  293. package/views/2d/engine/vectorTiles/shaders/Programs.js +0 -5
  294. package/views/2d/engine/vectorTiles/shaders/VTLMaterialManager.js +0 -5
  295. package/views/2d/engine/vectorTiles/shaders/sources/resolver.js +0 -5
  296. package/views/2d/engine/vectorTiles/shaders/sources/shaderRepository.js +0 -5
  297. package/views/2d/engine/vtlBrushes.js +0 -5
  298. package/views/2d/engine/webgl/brushes/WGLBrushVTLBackground.js +0 -5
  299. package/views/2d/engine/webgl/brushes/WGLBrushVTLCircle.js +0 -5
  300. package/views/2d/engine/webgl/brushes/WGLBrushVTLFill.js +0 -5
  301. package/views/2d/engine/webgl/brushes/WGLBrushVTLLine.js +0 -5
  302. package/views/2d/engine/webgl/brushes/WGLBrushVTLSymbol.js +0 -5
  303. package/views/3d/webgl-engine/effects/glow/GlowPresets.glsl.js +0 -5
  304. package/widgets/FeatureTable/support/FeatureStore.d.ts +0 -1
@@ -0,0 +1 @@
1
+ "use strict";(self.webpackChunkRemoteClient=self.webpackChunkRemoteClient||[]).push([[5981,6061],{5808:(e,t,s)=>{s.d(t,{O:()=>i});const i={geodesic:0,loxodrome:1,"great-elliptic":2,"normal-section":3,"shape-preserving":4}},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 h(e){return e instanceof r.A?Object.keys(e.items):a(e)?(0,n.oY)(e).keys():e?Object.keys(e):[]}function c(e,t){return e instanceof r.A?e.items[t]:e[t]}function l(e){return e?e.declaredClass:null}function u(e,t){const s=e.diff;if(s&&"function"==typeof s)return s(e,t);const i=h(e),r=h(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)&&c(e,s)!==c(t,s)).concat(n,d).sort(),f=l(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=c(e,i),n=c(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&&l(r)===l(n)?u(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&&l(e)!==l(t)?{type:"complete",oldValue:e,newValue:t}:u(e,t)}},10382:(e,t,s)=>{s.d(t,{A:()=>c});var i=s(36563),r=(s(44208),s(74887)),n=s(9775),o=s(72457),a=s(52268),h=s(61322);class c{constructor(){this._inUseClients=new Array,this._clients=new Array,this._clientPromises=new Array,this._ongoingJobsQueue=new n.A,this._ongoingLowPriorityJobsQueue=new n.A}destroy(){this.close()}get closed(){return!this._clients?.length}open(e,t){return new Promise((s,i)=>{let n=!0;const o=e=>{(0,r.Te)(t.signal),n&&(n=!1,e())};this._clients.length=e.length,this._clientPromises.length=e.length,this._inUseClients.length=e.length;for(let n=0;n<e.length;++n){const a=e[n];(0,r.$X)(a)?this._clientPromises[n]=a.then(e=>(this._clients[n]=new h.default(e,t,this._ongoingJobsQueue,this._ongoingLowPriorityJobsQueue),o(s),this._clients[n]),()=>(o(i),null)):(this._clients[n]=new h.default(a,t,this._ongoingJobsQueue,this._ongoingLowPriorityJobsQueue),this._clientPromises[n]=Promise.resolve(this._clients[n]),o(s))}})}broadcast(e,t,s){const i=new Array(this._clientPromises.length);for(let r=0;r<this._clientPromises.length;++r){const n=this._clientPromises[r];i[r]=n.then(i=>i?.invoke(e,t,s))}return i}close(){let e;for(;e=this._ongoingJobsQueue.pop();)e.resolver.reject((0,r.NK)(`Worker closing, aborting job calling '${e.methodName}'`));for(;e=this._ongoingLowPriorityJobsQueue.pop();)e.resolver.reject((0,r.NK)(`Worker closing, aborting job calling '${e.methodName}'`));for(const e of this._clientPromises)e.then(e=>e?.close());this._clients.length=0,this._clientPromises.length=0,this._inUseClients.length=0,(0,o.h)(this)}invoke(e,t,s){return this.apply(e,[t],s)}apply(e,t,s){const i=(0,r.Tw)();(1===s?.jobPriority?this._ongoingLowPriorityJobsQueue:this._ongoingJobsQueue).push({methodName:e,data:t,invokeOptions:s,resolver:i});for(let e=0;e<this._clientPromises.length;e++){const t=this._clients[e];t?t.jobAdded():this._clientPromises[e].then(e=>e?.jobAdded())}return i.promise}createInvokeProxy(e){return(0,a.L)(this,e)}on(e,t){return Promise.all(this._clientPromises).then(()=>(0,i.vE)(this._clients.map(s=>s.on(e,t))))}openPorts(){return new Promise(e=>{const t=new Array(this._clientPromises.length);let s=t.length;for(let i=0;i<this._clientPromises.length;++i)this._clientPromises[i].then(r=>{r&&(t[i]=r.openPort()),0===--s&&e(t)})})}get test(){}}},13069:(e,t,s)=>{s.d(t,{AG:()=>a,lk:()=>r,vD:()=>o,yS:()=>n});const i="randomUUID"in crypto;function r(){if(i)return crypto.randomUUID();const e=crypto.getRandomValues(new Uint16Array(8));e[3]=4095&e[3]|16384,e[4]=16383&e[4]|32768;const t=t=>e[t].toString(16).padStart(4,"0");return t(0)+t(1)+"-"+t(2)+"-"+t(3)+"-"+t(4)+"-"+t(5)+t(6)+t(7)}function n(){return`{${r().toUpperCase()}}`}function o(){return`{${r()}}`}function a(e){const t=e.toUpperCase();return e.startsWith("{")?t:`{${t}}`}},18047:(e,t,s)=>{s.d(t,{Up:()=>h,ZV:()=>c,yx:()=>a});var i=s(73444);const r={ar:"ar-u-nu-latn",bs:"sr-Latn-CS",nn:"no-NN"};let n=new WeakMap,o={};function a(e={}){const t={};return null!=e.digitSeparator&&(t.useGrouping=e.digitSeparator),null!=e.places&&(t.minimumFractionDigits=t.maximumFractionDigits=e.places),t}function h(e){const{minimumFractionDigits:t,maximumFractionDigits:s,useGrouping:i}=e;return{minimumFractionDigits:t,maximumFractionDigits:s,useGrouping:"auto"===i?"auto":"always"===i}}function c(e,t){return Object.is(e,-0)&&(e=0),function(e){const t=e||o;if(!n.has(t)){const s=(0,i.lR)(),o=s&&r[s]||(0,i.QC)();n.set(t,new Intl.NumberFormat(o,e))}return n.get(t)}(t).format(e)}(0,i.Ml)(()=>{n=new WeakMap,o={}}),new Map},30624:(e,t,s)=>{s.r(t),s.d(t,{createConnection:()=>S});var i=s(31635),r=s(11254),n=s(49186),o=s(53966),a=s(74887),h=s(84952),c=s(91429),l=s(16930),u=s(65864),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,h.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,a.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=(0,a.Tw)(),i=t.onmessage,{filter:r,outFields:h,spatialReference:c}=this._config;return s.timeout(e),t.onmessage=e=>{let a=null;try{a=JSON.parse(e.data)}catch(e){}a&&"object"==typeof a||(o.A.getLogger(this).error(new n.A("websocket-connection","Protocol violation. Handshake failed - malformed message",e.data)),s.reject(),this.destroy()),a.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)),s.reject(),this.destroy()),"json"!==a.format&&(o.A.getLogger(this).error(new n.A("websocket-connection","Protocol violation. Handshake failed - format is not set",e.data)),s.reject(),this.destroy()),r&&a.filter!==r&&o.A.getLogger(this).error(new n.A("websocket-connection","Tried to set filter, but server doesn't support it")),h&&a.outFields!==h&&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=[],s.resolve()},t.send(JSON.stringify({filter:r,outFields:h,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),g=s(61956);const y={maxQueryDepth:5,maxRecordCountFactor:3};let x=class extends _{constructor(e){super({...y,...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,h.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 h=(0,a.Tw)();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}`),h.reject(t.error)),this._setWebSocketJSONParseHandler(s),r=!0,h.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")),h.reject())},1e4),h.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(7330),s.e(3508),s.e(2869),s.e(6554),s.e(3910),s.e(4903),s.e(1214),s.e(9953),s.e(8399),s.e(1017),s.e(957),s.e(6606),s.e(8654),s.e(6647),s.e(812),s.e(655),s.e(2561)]).then(s.bind(s,68654))).default)({url:e}),{capabilities:i}=await t.load(),r=i.query.supportsMaxRecordCountFactor,n=i.query.supportsPagination,o=i.query.supportsCentroid,a=this._config.maxRecordCountFactor,h=t.capabilities.query.maxRecordCount,c=r?h*a:h,u=new g.A;if(u.outFields=this._config.outFields??["*"],u.where=this._config.filter?.where??"1=1",u.returnGeometry=!0,u.returnExceededLimitFeatures=!0,u.outSpatialReference=l.A.fromJSON(this._config.spatialReference),o&&(u.returnCentroid=!0),r&&(u.maxRecordCountFactor=a),n)return u.num=c,t.destroy(),this._queryPages(e,u);const d=await(0,m.eW)(e,u,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 b=s(64108);let w=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,h){const c={source:e,sourceSpatialReference:t,spatialReference:s,geometryType:i,filter:v(r,n),maxReconnectionAttempts:o,maxReconnectionInterval:a,customParameters:h};return e?e.path.startsWith("wss://")||e.path.startsWith("ws://")?new _(c):new x(c):new w(c)}(0,i.Cg)([(0,c.MZ)()],w.prototype,"connectionStatus",void 0),(0,i.Cg)([(0,c.MZ)()],w.prototype,"errorString",void 0),w=(0,i.Cg)([(0,b.$)("esri.layers.support.ClientSideConnection")],w)},32730:(e,t,s)=>{s.d(t,{BI:()=>m,D3:()=>f,XJ:()=>_,lc:()=>p,mX:()=>y,rU:()=>g,tH:()=>S});var i=s(799);const r="__begin__",n="__end__",o=new RegExp(r,"ig"),a=new RegExp(n,"ig"),h=new RegExp("^"+r,"i"),c=new RegExp(n+"$","i"),l='"',u=l+" + ",d=" + "+l;function p(e){return e.replaceAll(new RegExp("\\[","g"),"{").replaceAll(new RegExp("\\]","g"),"}")}function f(e){return e.replaceAll(new RegExp("\\{","g"),"[").replaceAll(new RegExp("\\}","g"),"]")}function _(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=p(e.labelExpression),t.type="conventional"),t}function m(e){const t=_(e);if(!t)return null;switch(t.type){case"conventional":return y(t.expression);case"arcade":return t.expression}return null}function g(e){const t=_(e);if(!t)return null;switch(t.type){case"conventional":return function(e){const t=e?.match(x);return t?.[1].trim()||null}(t.expression);case"arcade":return S(t.expression)}return null}function y(e){let t;return e?(t=(0,i.HC)(e,e=>r+'$feature["'+e+'"]'+n),t=h.test(t)?t.replace(h,""):l+t,t=c.test(t)?t.replace(c,""):t+l,t=t.replaceAll(o,u).replaceAll(a,d)):t='""',t}const x=/^\s*\{([^}]+)\}\s*$/i,b=/^\s*(?:(?:\$feature\.(\w+))|(?:\$feature\[(["'])(.+)(\2)\]));?\s*$/i,w=/^\s*(?:(?:\$feature\.(\w+))|(?:\$feature\[(["'])(.+)(\2)\]));?\s*(?:DomainName\(\s*\$feature\s*,\s*(["'])(\1|\3)(\5)\s*\));?\s*$/i,v=/^\s*(?:DomainName\(\s*\$feature\s*,\s*(["'])(.+)(\1)\s*\));?\s*$/i;function S(e){if(!e)return null;let t=b.exec(e)||w.exec(e);return t?t[1]||t[3]:(t=v.exec(e),t?t[2]:null)}},32929:(e,t,s)=>{s.r(t),s.d(t,{default:()=>Ic});var i=s(49186),r=s(36563),n=s(44208),o=s(26390),a=s(74887),h=s(87811),c=s(36708),l=s(90629),u=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,u.oV)(this._eventLog.onEvent(e))}}var _=s(97768),m=s(93637),g=s(6797),y=s(21325),x=s(44159);function b(e,t){return[e,t]}function w(e,t,s){return e[0]=t,e[1]=s,e}const v=new x.A("0/0/0/0");class S{static create(e,t,s=null){const i=(0,y.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),h=b(1/0,1/0);null!=s&&(w(o,Math.max(0,Math.floor((s.xmin-r[0])/n[0])),Math.max(0,Math.floor((r[1]-s.ymax)/n[1]))),w(a,Math.max(0,Math.floor((s.xmax-r[0])/n[0])),Math.max(0,Math.floor((r[1]-s.ymin)/n[1]))),w(h,a[0]-o[0]+1,a[1]-o[1]+1));const{cols:c,rows:l}=t;let u,d,p,f;return!s&&c&&l&&(w(o,c[0],l[0]),w(a,c[1],l[1]),w(h,c[1]-c[0]+1,l[1]-l[0]+1)),e.isWrappable?(u=b(Math.ceil(Math.round((i.valid[1]-i.valid[0])/t.resolution)/e.size[0]),h[1]),d=!0,p=i.origin,f=i.valid):(u=h,d=!1),new S(t.level,t.resolution,t.scale,r,o,a,h,n,u,d,p,f)}constructor(e,t,s,i,r,n,o,a,h,c,l,u){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=h,this.wrap=c,this._spatialReferenceOrigin=l,this._spatialReferenceValid=u}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){v.set(t);const i=s?v.col:this.denormalizeCol(v.col,v.world),r=v.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){v.set(t);const i=s?v.col:this.denormalizeCol(v.col,v.world);return Array.isArray(e)?w(e,this.getXForColumn(i),this.getYForRow(v.row)):(e.x=this.getXForColumn(i),e.y=this.getYForRow(v.row)),e}}var I=s(93687);class P{constructor(){this.spans=[]}static{this.pool=new I.A(()=>new P)}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 x.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 M{constructor(e,t,s){this.row=e,this.colFrom=t,this.colTo=s}}const k=new x.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,h=0!==a?o/a:0,c=(Math.ceil(i)-i)*h,l=(Math.floor(i)-i)*h;return new C(s,Math.floor(i),Math.ceil(n),h,o<0?c:l,o<0?l:c,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 A=[[0,0],[0,0],[0,0],[0,0]];class T{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=>S.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}getLODInfoAt(e){return this._infoByLevel["number"==typeof e?e:e.level]}getTileBounds(e,t,s=!1){k.set(t);const i=this._infoByLevel[k.level];return i?i.getTileBounds(e,k,s):e}getTileCoords(e,t,s=!1){k.set(t);const i=this._infoByLevel[k.level];return i?i.getTileCoords(e,k,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=P.pool.acquire(r),o=this._wrap;let a,h,c,l=1/0,u=-1/0;const d=n.spans;A[0][0]=A[0][1]=A[1][1]=A[3][0]=-t,A[1][0]=A[2][0]=e.size[0]+t,A[2][1]=A[3][1]=e.size[1]+t;for(const t of A)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(A[e][1]===A[f][1]){f=e;continue}const t=C.create(A[e],A[f]);l=Math.min(t.ymin,l),u=Math.max(t.ymax,u),void 0===p[t.ymin]&&(p[t.ymin]=[]),p[t.ymin].push(t),f=e}if(null==l||null==u||u-l>100)return null;let _=[];for(a=l;a<u;){null!=p[a]&&(_=_.concat(p[a])),h=1/0,c=-1/0;for(let e=_.length-1;e>=0;e--){const t=_[e];h=Math.min(h,t.getLeftCol()),c=Math.max(c,t.getRightCol())}if(h=Math.floor(h),c=Math.floor(c),a>=r.first[1]&&a<=r.last[1])if(o)if(r.size[0]<r.worldSize[0]){const e=Math.floor(c/r.worldSize[0]);for(let t=Math.floor(h/r.worldSize[0]);t<=e;t++)d.push(new M(a,Math.max(r.getFirstColumnForWorld(t),h),Math.min(r.getLastColumnForWorld(t),c)))}else d.push(new M(a,h,c));else h>r.last[0]||c<r.first[0]||(h=Math.max(h,r.first[0]),c=Math.min(c,r.last[0]),d.push(new M(a,h,c)));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){k.set(e);const t=this._infoByLevel[k.level],s=this._lodInfos.indexOf(t)-1;return s<0?null:(this._getTileIdAtLOD(k,this._lodInfos[s],k),k.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){k.set(t);const s=this._infoByLevel[k.level],i=e.lodInfo;if(i.resolution>s.resolution){this._getTileIdAtLOD(k,i,k);const t=i.denormalizeCol(k.col,k.world);for(const s of e.spans)if(s.row===k.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(k.col,k.world),h=i.getColumnForX(s.getXForColumn(a)),c=i.getRowForY(s.getYForRow(k.row)),l=i.getColumnForX(s.getXForColumn(a+1))-1,u=i.getRowForY(s.getYForRow(k.row+1))-1;return!(h>o||l<n||c>r||u<t)}const r=i.denormalizeCol(k.col,k.world);return e.spans.some(e=>e.row===k.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,y.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 F=s(31635),z=s(69622),E=s(91869),O=s(3483),R=s(91429),L=s(37585),D=s(9775),N=s(32587),G=s(76030),q=s(44794);class B{constructor(e,t){this.item=e,this.controller=t,this.promise=null}}class W{constructor(e){this._schedule=null,this._task=null,this._deferreds=new N.A,this._controllers=new N.A,this._processingItems=new N.A,this._pausedSignal=(0,q.v)(!1),this.concurrency=1,e.concurrency&&(this.concurrency=e.concurrency),this._queue=new D.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(),h.reject((0,a.NK)())}),h=(0,a.Tw)();return this._deferreds.set(e,h),this._controllers.set(e,i),h.promise.then(n,n),this._queue.push(e),this._scheduleNext(),h.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,G._)(()=>{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 B(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 j=[0,0];let U=class extends z.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 W({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,E.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,O.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(j,o);const e=(0,L.Io)(j,i);e<n&&(n=e,r=o)}return r}};(0,F.Cg)([(0,R.MZ)({constructOnly:!0})],U.prototype,"concurrency",void 0),(0,F.Cg)([(0,R.MZ)({constructOnly:!0})],U.prototype,"priority",void 0),(0,F.Cg)([(0,R.MZ)({constructOnly:!0})],U.prototype,"process",void 0),(0,F.Cg)([(0,R.MZ)({constructOnly:!0})],U.prototype,"scheduler",void 0),(0,F.Cg)([(0,R.MZ)()],U.prototype,"state",void 0),(0,F.Cg)([(0,R.MZ)({constructOnly:!0})],U.prototype,"tileInfoView",void 0),U=(0,F.Cg)([(0,R.$K)("esri.views.2d.tiling.TileQueue")],U);var V=s(19419);new x.A(0,0,0,0),new Map;class Y{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 Y(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 Y(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 X(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 ${static{this.byteSizeHint=2*Uint32Array.BYTES_PER_ELEMENT+Y.byteSizeHint}static estimateMemory(e){return 24+Y.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 $(t,s);return i.records=X(e,Y)??[],i}}class Z{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 Q{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 Z(Uint32Array,i),this._vertices=new Z(Uint32Array,r),this._metrics=new Z(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._entities=new Z(Uint32Array,this._sizeHint*$.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}}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),Y.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),Y.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,h=this._recordVertexStart*a,c=(this._recordVertexStart+this._recordVertexCount)*a;for(let e=h;e!==c;e++){const t=r.getValue(e);r.push(t)}const l=this._current.writer.layout.position,u=l.packPrecisionFactor??1,d=l.offset/Uint32Array.BYTES_PER_ELEMENT,p=e*u,f=t*u;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,h=this._current.writer.vertexWriter,c=e._current.writer.indexWriter,l=e._current.writer.vertexWriter;for(let t=e._current.indexStart;t!==c.length;t++){const e=c.getValue(t);a.push(e-o)}for(let t=e._current.vertexStart*r;t!==l.length;t++){const e=l.getValue(t);h.push(e)}const u=this._current.writer.layout.position,d=u.packPrecisionFactor??1,p=u.offset/Uint32Array.BYTES_PER_ELEMENT,f=t*d,_=s*d;for(let e=n*r;e<=h.length;e+=r)h.i1616Add(e+p,f,_);this.recordEnd()}_getVertexWriter(e,t){const s=this._instanceIdToVertexData;return s.has(e)||s.set(e,new Q(e,t,this._sizeHint)),s.get(e)}}function K(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 ee(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 te{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}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,...s.message}),t.transferList.push(...s.transferList),this._meshes.neighbors.forEach((s,i)=>{const r=s.serialize(),n=1<<i,o=K(n),a=ee(n),h=new x.A(this.tileKey).getNormalizedNeighbor(o,a,e);t.message.push({tileId:h.id,...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=-K(t)*p.CQ,s=-ee(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=-K(t)*p.CQ,r=-ee(t)*p.CQ;s.copyLastFrom(this._meshes.self,i,r)}}}}class se{}var ie=s(72691),re=s(73681);class ne{constructor(){this._defaultResult=null,this._backgroundFillResult=null}static async from(e,t){const s=new ne;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 oe extends ne{static async fromDictionaryRenderer(e,t){const s=await re.n.from(t.dictionaryInfo,t.userConfig,t.fieldMap);return new oe(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 ae extends ne{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 ae(s,t.isMaxInclusive);await Promise.all(t.intervals.map(async t=>{const s=await e.createMeshWriters(t.meshes);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 he extends ne{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 he(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 ce extends ne{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 ce(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.symbol);"<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 le(e,t){switch(t.type){case"simple":case"heatmap":case"dot-density":case"pie-chart":return ne.from(e,t);case"interval":return ae.fromIntervalSchema(e,t);case"dictionary":return oe.fromDictionaryRenderer(e,t);case"label":return he.fromLabelSchema(e,t);case"map":return ce.fromMatcherSchema(e,t);case"subtype":return ue.fromSubtypes(e,t);case"cluster":return de.fromClusterSchema(e,t);case"track":return pe.fromTrackSchema(e,t);default:throw new Error("Impl")}}class ue extends ne{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=le(e,t.renderers[r]).then(e=>s.set(n,e));i.push(o)}return await Promise.all(i),new ue(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 de extends ne{static async fromClusterSchema(e,t){const[s,i]=await Promise.all([le(e,t.feature),le(e,t.cluster)]);return new de(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 pe extends ne{static async fromTrackSchema(e,t){const[s,i,r]=await Promise.all([le(e,t.previousObservation),le(e,t.latestObservation),le(e,t.trackLine)]);return new pe(s,i,r)}constructor(e,t,s){super(),this._previousObservationMatcher=e,this._latestObservationMatcher=t,this._trackLineMatcher=s}match(e,t,s){switch(e.readAttribute(ie.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 fe extends se{static async create(e,t){const s=await le(e,t.symbology),i=t.labels?await le(e,t.labels):null;return new fe(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){const o=this._symbology.match(s,i,r);if(o){for(const r of o)r.write(e,t,s,i,n);if(e.entityRecordCount()>=1&&this._labels){const a=this._labels.match(s,i,r);if(!a)return;for(const r of a)r.setReferences(o),r.write(e,t,s,i,n)}}}getSortKey(e,t){return this._symbology.getSortKey(e,t)}hasArcadeDependency(e){return!(!this._symbology.hasArcadeDependency(e)&&!this._labels?.hasArcadeDependency(e))}}var _e=s(799);class me{}class ge extends me{constructor(e){super(),this._fetcher=e,this._controller=new AbortController,this._pendingIds=new Set,this._pendingRequests=[],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,_e.Wm)(JSON.stringify(t));return this._pendingIds.has(s)||(this._pendingIds.add(s),this._pendingRequests.push({...e,resourceId:s})),s}async fetchEnqueuedResources(){const e=this._pendingRequests;if(this._pendingIds.clear(),this._pendingRequests=[],0===e.length)return;const t=await this._fetcher.fetch(e,this._abortOptions);for(let s=0;s<t.length;s++){const i=e[s].resourceId;this._resourceIdToResource.set(i,t[s])}}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 ye=s(36745),xe=s(28076);const be=1024;xe.D.CIMSolidStroke.capstyle,xe.D.CIMSolidStroke.joinstyle,xe.D.CIMSolidStroke.miterlimit;class we{static{this.instance=null}static local(){return null===we.instance&&(we.instance=new we),we.instance}execute(e,t){return new ve(e,t)}}class ve{constructor(e,t){this._inputGeometries=e,this._angleTolerance=void 0!==t.angleTolerance?t.angleTolerance:120,this._maxCosAngle=Math.cos((1-Math.abs(this._angleTolerance)/180)*Math.PI)}next(){let e=this._inputGeometries.next();if(!e)return null;for(;e;){if("esriGeometryPolygon"===e.geometryType)this._isClosed=!0;else if("esriGeometryPolyline"===e.geometryType)this._isClosed=!1;else{if("esriGeometryEnvelope"!==e.geometryType){e=this._inputGeometries.next();continue}if(this._maxCosAngle)return e;this._isClosed=!0}for(;e.nextPath();)this._processPath(e);return e.reset(),e}return null}_processPath(e){if(e.nextPoint()){const t=e.x,s=e.y;let i=t,r=s,n=e.pathSize,o=0,a=0,h=0,c=0,l=0,u=0;this._isClosed&&++n;for(let d=1;e.nextPoint()||d<n;++d){let p,f;this._isClosed&&d===n-1?(p=t,f=s):(p=e.x,f=e.y);const _=p-i,m=f-r,g=Math.sqrt(_*_+m*m);d>1&&g>0&&h>0&&(o*_+a*m)/g/h<=this._maxCosAngle&&e.setControlPointAt(d-1),1===d&&(c=_,l=m,u=g),g>0&&(i=p,r=f,o=_,a=m,h=g)}this._isClosed&&h>0&&u>0&&(o*c+a*l)/u/h<=this._maxCosAngle&&e.setControlPointAt(0)}}}var Se=s(51118);class Ie{constructor(){this.setIdentity()}getAngle(){return(null==this.rz||0===this.rz&&1!==this.rzCos&&0!==this.rzSin)&&(this.rz=Math.atan2(this.rzSin,this.rzCos)),this.rz}setIdentity(){this.tx=0,this.ty=0,this.tz=0,this.s=1,this.rx=0,this.ry=0,this.rz=0,this.rzCos=1,this.rzSin=0}setTranslate(e,t){this.tx=e,this.ty=t}setTranslateZ(e){this.tz=e}setRotateCS(e,t){this.rz=void 0,this.rzCos=e,this.rzSin=t}setRotate(e){this.rz=e,this.rzCos=void 0,this.rzSin=void 0}setRotateY(e){this.ry=e}setScale(e){this.s=e}setMeasure(e){this.m=e}}function Pe(e,t){e[4]=t}class Me{constructor(e,t=!0,s=!0,i=0){this.isClosed=!1,this.geometryCursor=null,this.geometryCursor=!t&&"esriGeometryPolygon"===e.geometryType||!s&&"esriGeometryPolyline"===e.geometryType?null:e,this.geomUnitsPerPoint=i,this.iterateMultiPath=!1,this.iteratePath=!1,this.internalPlacement=new Ie}next(){if(!this.geometryCursor)return null;const e=this.processMultiPath(this.geometryCursor);return this.iterateMultiPath&&e||(this.geometryCursor=null),e}processMultiPath(e){for(;this.iteratePath||e.pathIndex<e.totalSize-1;){this.iteratePath||e.nextPath(),this.iterateMultiPath=!0;const t=this.processPath(e);if(t)return t}return this.iterateMultiPath=!1,null}}class ke{constructor(e,t,s,i=0){this.isClosed=!1,this.inputGeometries=e,this.acceptPolygon=t,this.acceptPolyline=s,this.geomUnitsPerPoint=i,this.iteratePath=!1,this.multiPathCursor=null}next(){for(;;){if(!this.multiPathCursor){let e=this.inputGeometries.next();for(;e&&(this.isClosed=this.acceptPolygon&&"esriGeometryPolygon"===e.geometryType||"esriGeometryEnvelope"===e.geometryType,this.multiPathCursor=e,!this.multiPathCursor);)e=this.inputGeometries.next();if(!this.multiPathCursor)return null}for(;this.iteratePath||this.multiPathCursor.nextPath();){this.multiPathCursor.seekPathStart();const e=this.processPath(this.multiPathCursor);if(e)return e}this.multiPathCursor=null}}}const Ce=.03;class Ae{constructor(e=0,t=!1){}isEmpty(e){if(!e.nextPoint())return!0;let t,s,i,r;for(t=e.x,s=e.y;e.nextPoint();t=s,s=r)if(i=e.x,r=e.y,i!==t||r!==s)return e.seekPathStart(),!1;return e.seekPathStart(),!0}normalize(e){const t=Math.sqrt(e[0]*e[0]+e[1]*e[1]);0!==t&&(e[0]/=t,e[1]/=t)}getLength(e,t,s,i){const r=s-e,n=i-t;return Math.sqrt(r*r+n*n)}getSegLength(e){const[[t,s],[i,r]]=e;return this.getLength(t,s,i,r)}getCoord2D(e,t,s,i,r){return[e+(s-e)*r,t+(i-t)*r]}getSegCoord2D(e,t){const[[s,i],[r,n]]=e;return this.getCoord2D(s,i,r,n,t)}getAngle(e,t,s,i,r){const n=s-e,o=i-t;return Math.atan2(o,n)}getAngleCS(e,t,s,i,r,n){null==e&&(e=[0,0]);const o=i-t,a=r-s,h=Math.sqrt(o*o+a*a);return 0!==h?(e[0]=o/h,e[1]=a/h,e):(e[0]=1,e[1]=0,e)}getSegAngleCS(e,t,s){const[[i,r],[n,o]]=t;return this.getAngleCS(e,i,r,n,o,s)}cut(e,t,s,i,r,n){return[r<=0?[e,t]:this.getCoord2D(e,t,s,i,r),n>=1?[s,i]:this.getCoord2D(e,t,s,i,n)]}getSubCurve(e,t,s){const i=ye.z.createEmptyOptimizedCIM("esriGeometryPolyline");return this.appendSubCurve(i,e,t,s)?i:null}appendSubCurve(e,t,s,i){e.startPath(),t.seekPathStart();let r=0,n=!0;if(!t.nextPoint())return!1;let o=t.x,a=t.y;for(;t.nextPoint();){const h=this.getLength(o,a,t.x,t.y);if(0!==h){if(n){if(r+h>s){const c=(s-r)/h;let l=1,u=!1;r+h>=i&&(l=(i-r)/h,u=!0);const d=this.cut(o,a,t.x,t.y,c,l);if(d&&e.pushPoints(d),u)break;n=!1}}else{if(r+h>i){const s=this.cut(o,a,t.x,t.y,0,(i-r)/h);s&&e.pushPoint(s[1]);break}e.pushXY(t.x,t.y)}r+=h,o=t.x,a=t.y}else o=t.x,a=t.y}return!0}getCIMPointAlong(e,t){if(!e.nextPoint())return null;let s,i,r,n,o=0;for(s=e.x,i=e.y;e.nextPoint();s=r,i=n){r=e.x,n=e.y;const a=this.getLength(s,i,r,n);if(0!==a){if(o+a>t){const e=(t-o)/a;return this.getCoord2D(s,i,r,n,e)}o+=a}}return null}offset(e,t,s,i,r){if(!e||e.length<2)return null;let n=0,o=e[n++],a=n;for(;n<e.length;){const t=e[n];t[0]===o[0]&&t[1]===o[1]||(n!==a&&(e[a]=e[n]),o=e[a++]),n++}const h=e[0][0]===e[a-1][0]&&e[0][1]===e[a-1][1];if(h&&--a,a<(h?3:2))return null;const c=[];o=h?e[a-1]:null;let l=e[0];for(let r=0;r<a;r++){const n=r===a-1?h?e[0]:null:e[r+1];if(o)if(n){const e=[n[0]-l[0],n[1]-l[1]];this.normalize(e);const r=[l[0]-o[0],l[1]-o[1]];this.normalize(r);const a=r[0]*e[1]-r[1]*e[0],h=r[0]*e[0]+r[1]*e[1];if(0===a&&1===h){l=n;continue}if(a>=0==t<=0){if(h<1){const s=[e[0]-r[0],e[1]-r[1]];this.normalize(s);const n=Math.sqrt((1+h)/2);if(n>1/i){const e=-Math.abs(t)/n;c.push([l[0]-s[0]*e,l[1]-s[1]*e])}}}else switch(s){case"Mitered":{const s=Math.sqrt((1+h)/2);if(s>0&&1/s<i){const i=[e[0]-r[0],e[1]-r[1]];this.normalize(i);const n=Math.abs(t)/s;c.push([l[0]-i[0]*n,l[1]-i[1]*n]);break}}case"Bevelled":c.push([l[0]+r[1]*t,l[1]-r[0]*t]),c.push([l[0]+e[1]*t,l[1]-e[0]*t]);break;case"Rounded":if(h<1){c.push([l[0]+r[1]*t,l[1]-r[0]*t]);const s=Math.floor(2.5*(1-h));if(s>0){const i=1/s;let n=i;for(let o=1;o<s;o++,n+=i){const s=[r[1]*(1-n)+e[1]*n,-r[0]*(1-n)-e[0]*n];this.normalize(s),c.push([l[0]+s[0]*t,l[1]+s[1]*t])}}c.push([l[0]+e[1]*t,l[1]-e[0]*t])}break;default:if(a<0)c.push([l[0]+(r[1]+r[0])*t,l[1]+(r[1]-r[0])*t]),c.push([l[0]+(e[1]-e[0])*t,l[1]-(e[0]+e[1])*t]);else{const s=Math.sqrt((1+Math.abs(h))/2),i=[e[0]-r[0],e[1]-r[1]];this.normalize(i);const n=t/s;c.push([l[0]-i[0]*n,l[1]-i[1]*n])}}}else{const e=[l[0]-o[0],l[1]-o[1]];this.normalize(e),c.push([l[0]+e[1]*t,l[1]-e[0]*t])}else{const e=[n[0]-l[0],n[1]-l[1]];this.normalize(e),c.push([l[0]+e[1]*t,l[1]-e[0]*t])}o=l,l=n}return c.length<(h?3:2)?null:(h&&c.push([c[0][0],c[0][1]]),c)}}class Te{static{this.instance=null}static local(){return null===Te.instance&&(Te.instance=new Te),Te.instance}execute(e,t,s){return new Fe(e,t,s)}}class Fe extends ke{constructor(e,t,s){super(e,!1,!0),this._curveHelper=new Ae,this._width=(void 0!==t.width?t.width:5)*s,this._arrowType=void 0!==t.geometricEffectArrowType?t.geometricEffectArrowType:void 0!==t.arrowType?t.arrowType:"OpenEnded",this._offsetFlattenError=Ce*s}processPath(e){const t=ye.z.createEmptyOptimizedCIM(e.geometryType);switch(this._arrowType){case"OpenEnded":default:this._constructSimpleArrow(t,e,!0);break;case"Block":this._constructSimpleArrow(t,e,!1);break;case"Crossed":this._constructCrossedArrow(t,e)}return t}_constructSimpleArrow(e,t,s){const i=t.pathLength();let r=this._width;i<2*r&&(r=i/2);const n=this._curveHelper.getSubCurve(t,0,i-r);if(!n||!n.nextPath())return;n.seekPathStart();const o=r/2;if(this._curveHelper.isEmpty(n))return;const a=(0,Se.A)(n),h=this._constructOffset(a,-o);if(!h)return;const c=this._constructOffset(a,o);if(!c)return;const l=this._constructArrowBasePoint(h,-o/2);if(!l)return;const u=this._constructArrowBasePoint(c,o/2);if(!u)return;t.seekInPath(t.pathSize-1);const d=[t.x,t.y];e.pushPath(c),e.nextPath(),e.nextPoint(),e.setControlPoint(),e.pushPoint(u),e.nextPoint(),e.setControlPoint(),e.pushPoint(d),e.nextPoint(),e.setControlPoint(),e.pushPoint(l),e.nextPoint(),e.setControlPoint(),e.pushPoints(h.reverse()),e.setControlPoint(),s||(e.setControlPointAt(0),e.setControlPointAt(e.pathSize-1),e.pushPoint(c[0])),e.reset()}_constructCrossedArrow(e,t){const s=t.pathLength();let i=this._width;s<3.732050807568877*i&&(i=s/3.732050807568877),t.seekPathStart();const r=this._curveHelper.getSubCurve(t,0,s-2.732050807568877*i);if(!r)return;r.nextPath();const n=i/2;if(this._curveHelper.isEmpty(r))return;const o=(0,Se.A)(r),a=this._constructOffset(o,n);if(!a)return;const h=this._constructOffset(o,-n);if(!h)return;const c=this._curveHelper.getSubCurve(t,0,s-i);if(!c)return;if(c.nextPath(),this._curveHelper.isEmpty(c))return;const l=(0,Se.A)(c),u=this._constructOffset(l,n);if(!u)return;const d=this._constructOffset(l,-n);if(!d)return;const p=u[u.length-1],f=this._constructArrowBasePoint(u,n/2);if(!f)return;const _=d[d.length-1],m=this._constructArrowBasePoint(d,-n/2);if(!m)return;t.seekInPath(t.pathSize-1);const g=[t.x,t.y];e.pushPath(a),e.nextPath(),e.nextPoint(),e.setControlPoint(),e.pushPoint(_),e.nextPoint(),e.setControlPoint(),e.pushPoint(m),e.nextPoint(),e.setControlPoint(),e.pushPoint(g),e.nextPoint(),e.setControlPoint(),e.pushPoint(f),e.nextPoint(),e.setControlPoint(),e.pushPoint(p),e.nextPoint(),e.setControlPoint(),e.pushPoints(h.reverse()),e.nextPoint(),e.setControlPoint(),e.reset()}_constructOffset(e,t){return this._curveHelper.offset(e,t,"Rounded",4,this._offsetFlattenError)}_constructArrowBasePoint(e,t){if(!e||e.length<2)return null;const s=e[e.length-2],i=e[e.length-1],r=[i[0]-s[0],i[1]-s[1]];return this._curveHelper.normalize(r),[i[0]+r[1]*t,i[1]-r[0]*t]}}var ze=s(16930),Ee=s(6774),Oe=s(93397);const Re=(0,Oe.z9)(()=>Promise.all([s.e(3661),s.e(1878),s.e(5756),s.e(3299),s.e(1352),s.e(6160)]).then(s.bind(s,46160))),Le=(0,Oe.z9)(()=>Promise.all([s.e(3661),s.e(1878),s.e(5756),s.e(3299),s.e(5666)]).then(s.bind(s,55666))),De=(0,Oe.z9)(()=>Promise.all([s.e(3661),s.e(1878),s.e(5756),s.e(3299),s.e(1190)]).then(s.bind(s,51190))),Ne=(0,Oe.z9)(()=>Promise.all([s.e(3661),s.e(1878),s.e(5756),s.e(3299),s.e(7528)]).then(s.bind(s,97528))),Ge=(0,Oe.z9)(()=>Promise.all([s.e(3661),s.e(1878),s.e(5756),s.e(3299),s.e(1352),s.e(795)]).then(s.bind(s,50795))),qe=(0,Oe.z9)(()=>Promise.all([s.e(3661),s.e(1878),s.e(5756),s.e(3299),s.e(5605)]).then(s.bind(s,15605))),Be=(0,Oe.z9)(()=>Promise.all([s.e(3661),s.e(1878),s.e(5756),s.e(3299),s.e(3637)]).then(s.bind(s,3637))),We=(0,Oe.z9)(()=>Promise.all([s.e(3661),s.e(1878),s.e(5756),s.e(3299)]).then(s.bind(s,83299)));let je;function Ue(e){switch(e.type){case"CIMGeometricEffectDonut":case"CIMGeometricEffectBuffer":return Re.getImportPromise();case"CIMGeometricEffectEnclosingPolygon":return Le.getImportPromise();case"CIMGeometricEffectOffset":return Promise.all([qe.getImportPromise(),Ge.getImportPromise()]);case"CIMGeometricEffectTaperedPolygon":return Promise.all([Be.getImportPromise(),De.getImportPromise(),Ne.getImportPromise()]);default:return Promise.resolve()}}class Ve{constructor(e){this._geometry=e}next(){const e=this._geometry;return this._geometry=null,e}}function Ye(e,t,s){if(!e)return null;je||(je=new Ee.O3(0,0,0,1));const i=s?-1:1,r="esriGeometryPolygon"===e.geometryType,n=r?3:2,o=r?3:2;let a,h;for(je.reset(n),je.setPixelMargin(t+1),je.setExtent(512);e.nextPath();)if(!(e.pathSize<o)){for(e.nextPoint(),a=e.x,h=i*e.y,je.moveTo(a,h);e.nextPoint();)a=e.x,h=i*e.y,je.lineTo(a,h);r&&je.close()}const c=je.result(!1);if(c){const t=ye.z.createEmptyOptimizedCIM(e.geometryType);for(const e of c){t.startPath();for(const s of e)t.pushXY(s.x,i*s.y)}return t.reset(),t}return null}class He{static{this.instance=null}static local(){return null===He.instance&&(He.instance=new He),He.instance}execute(e,t,s,i,r,n){return new Xe(e,t,s,i,r,n)}}class Xe{constructor(e,t,s,i,r,n){this._preventClipping=n,this._inputGeometries=e,this._tileKey=i,this._curveHelper=new Ae,this._size=(void 0!==t.size?t.size:1)*s,this._maxInflateSize=r*s,this._offsetFlattenError=Ce*s}next(){let e;for(;e=this._inputGeometries.next();){if(0===this._size)return e;if("esriGeometryEnvelope"===e.geometryType)if(this._size>0){const t=ye.z.createEmptyOptimizedCIM(e.geometryType),s=(0,Se.x)(e)[0],i=this._curveHelper.offset(s,this._size,"Rounded",4,this._offsetFlattenError);if(i)return t.pushPath(i),t}else if(this._size<0){const t=e.asJSON();if(Math.min(t.xmax-t.xmin,t.ymax-t.ymin)+2*this._size>0)return ye.z.fromJSONCIM({xmin:t.xmin-this._size,xmax:t.xmax+this._size,ymin:t.ymin-this._size,ymax:t.ymax+this._size})}const t=!this._preventClipping&&this._tileKey?Ye(e,this._maxInflateSize,!0):e;if(!t)continue;const s=Re.module,i={...t.asJSON(),spatialReference:{wkid:ze.A.WebMercator.wkid}},r=s.execute(i,this._size);return r?ye.z.fromJSONCIM(r):null}return null}}var $e=s(95108);class Ze{static{this.instance=null}static local(){return null===Ze.instance&&(Ze.instance=new Ze),Ze.instance}execute(e,t,s){return new Qe(e,t,s)}}class Qe{constructor(e,t,s){this._defaultPointSize=20,this._inputGeometries=e,this._geomUnitsPerPoint=s,this._rule=t.rule??"FullGeometry",this._defaultSize=this._defaultPointSize*s}next(){let e;for(;e=this._inputGeometries.next();){const t=this._processGeom((0,Se.x)(e));if(t?.length)return ye.z.fromJSONCIM({paths:t})}return null}_clone(e){return[e[0],e[1]]}_mid(e,t){return[(e[0]+t[0])/2,(e[1]+t[1])/2]}_mix(e,t,s,i){return[e[0]*t+s[0]*i,e[1]*t+s[1]*i]}_add(e,t){return[e[0]+t[0],e[1]+t[1]]}_add2(e,t,s){return[e[0]+t,e[1]+s]}_sub(e,t){return[e[0]-t[0],e[1]-t[1]]}_dist(e,t){return Math.sqrt((e[0]-t[0])*(e[0]-t[0])+(e[1]-t[1])*(e[1]-t[1]))}_norm(e){return Math.sqrt(e[0]*e[0]+e[1]*e[1])}_normalize(e,t=1){const s=t/this._norm(e);e[0]*=s,e[1]*=s}_leftPerpendicular(e){const t=-e[1],s=e[0];e[0]=t,e[1]=s}_leftPerp(e){return[-e[1],e[0]]}_rightPerpendicular(e){const t=e[1],s=-e[0];e[0]=t,e[1]=s}_rightPerp(e){return[e[1],-e[0]]}_dotProduct(e,t){return e[0]*t[0]+e[1]*t[1]}_crossProduct(e,t){return e[0]*t[1]-e[1]*t[0]}_rotateDirect(e,t,s){const i=e[0]*t-e[1]*s,r=e[0]*s+e[1]*t;e[0]=i,e[1]=r}_makeCtrlPt(e){const t=[e[0],e[1]];return Pe(t,1),t}_addAngledTicks(e,t,s,i){const r=this._sub(s,t);this._normalize(r);const n=this._crossProduct(r,this._sub(i,t));let o;o=n>0?this._rightPerp(r):this._leftPerp(r);const a=Math.abs(n)/2,h=[];h.push([t[0]+(o[0]-r[0])*a,t[1]+(o[1]-r[1])*a]),h.push(t),h.push(s),h.push([s[0]+(o[0]+r[0])*a,s[1]+(o[1]+r[1])*a]),e.push(h)}_addBezier2(e,t,s,i,r){if(0===r--)return void e.push(i);const n=this._mid(t,s),o=this._mid(s,i),a=this._mid(n,o);this._addBezier2(e,t,n,a,r),this._addBezier2(e,a,o,i,r)}_addBezier3(e,t,s,i,r,n){if(0===n--)return void e.push(r);const o=this._mid(t,s),a=this._mid(s,i),h=this._mid(i,r),c=this._mid(o,a),l=this._mid(a,h),u=this._mid(c,l);this._addBezier3(e,t,o,c,u,n),this._addBezier3(e,u,l,h,r,n)}_add90DegArc(e,t,s,i,r){const n=r??this._crossProduct(this._sub(s,t),this._sub(i,t))>0,o=this._mid(t,s),a=this._sub(o,t);n?this._leftPerpendicular(a):this._rightPerpendicular(a),o[0]+=a[0],o[1]+=a[1],this._addBezier3(e,t,this._mix(t,.33333,o,.66667),this._mix(s,.33333,o,.66667),s,4)}_addArrow(e,t,s){const i=t[0],r=t[1],n=t[t.length-1],o=this._sub(i,r),a=this._norm(o);this._normalize(o);const h=Math.abs(this._crossProduct(o,this._sub(n,r)));let c=this._dotProduct(o,this._sub(n,r));c<.05*a?c=.05*a:c>.95*a&&(c=.95*a);const l=.5*h,u=this._leftPerp(o),d=[r[0]+o[0]*c,r[1]+o[1]*c],p=t.length-1,f=[];f.push(s?[-u[0],-u[1]]:u);let _=[-o[0],-o[1]];for(let e=1;e<p-1;e++){const s=this._sub(t[e+1],t[e]);this._normalize(s);const i=this._dotProduct(s,_),r=this._crossProduct(s,_),n=Math.sqrt((1+i)/2),o=this._sub(s,_);this._normalize(o),o[0]/=n,o[1]/=n,f.push(r<0?[-o[0],-o[1]]:o),_=s}f.push(this._rightPerp(_));for(let s=f.length-1;s>0;s--)e.push([t[s][0]+f[s][0]*l,t[s][1]+f[s][1]*l]);e.push([d[0]+f[0][0]*l,d[1]+f[0][1]*l]),e.push([d[0]+f[0][0]*h,d[1]+f[0][1]*h]),e.push(i),e.push([d[0]-f[0][0]*h,d[1]-f[0][1]*h]),e.push([d[0]-f[0][0]*l,d[1]-f[0][1]*l]);for(let s=1;s<f.length;s++)e.push([t[s][0]-f[s][0]*l,t[s][1]-f[s][1]*l])}_addDash(e,t,s){const i=this._norm(s)/7;this._normalize(s);let r=[];for(let n=0;n<=7;n++)r.push([t[0]+s[0]*n*i,t[1]+s[1]*n*i]),1&n&&(e.push(r),r=[])}_cp2(e,t,s){return e.length>=2?e[1]:this._add2(e[0],t*this._defaultSize,s*this._defaultSize)}_cp3(e,t,s,i){if(e.length>=3)return e[2];const r=this._mix(e[0],1-s,t,s),n=this._sub(t,e[0]);return this._normalize(n),this._rightPerpendicular(n),[r[0]+n[0]*i*this._defaultSize,r[1]+n[1]*i*this._defaultSize]}_arrowPath(e){if(e.length>2)return e;const t=e[0],s=this._cp2(e,-4,0),i=this._sub(t,s);this._normalize(i);const r=this._rightPerp(i);return[t,s,[t[0]+(r[0]-i[0])*this._defaultSize,t[1]+(r[1]-i[1])*this._defaultSize]]}_arrowLastSeg(e){const t=e[0],s=this._cp2(e,-4,0);let i;if(e.length>=3)i=e[e.length-1];else{const e=this._sub(t,s);this._normalize(e);const r=this._rightPerp(e);i=[t[0]+(r[0]-e[0])*this._defaultSize,t[1]+(r[1]-e[1])*this._defaultSize]}return[s,i]}_processGeom(e){if(!e)return null;const t=[];for(const s of e){const e=s.length>1&&(0,$e.Yl)(s)<this._defaultSize;if(!s||0===s.length||e)continue;const i=s.length;let r=s[0];switch(this._rule){case"PerpendicularFromFirstSegment":{const e=this._cp2(s,0,-1),i=this._cp3(s,e,.5,4),n=[];n.push(i),n.push(this._mid(r,e)),t.push(n);break}case"ReversedFirstSegment":{const e=this._cp2(s,0,-1);t.push([e,r]);break}case"PerpendicularToSecondSegment":{if(s.length<3)return[];const e=this._cp2(s,-4,1),i=this._cp3(s,e,.882353,-1.94),n=[];n.push(this._mid(e,i)),n.push(r),t.push(n);break}case"SecondSegmentWithTicks":{if(s.length<3)return[];const e=this._cp2(s,-4,1),i=this._cp3(s,e,.882353,-1.94),n=this._sub(i,e);let o;o=this._crossProduct(n,this._sub(r,e))>0?this._rightPerp(n):this._leftPerp(n);const a=[];a.push([e[0]+(o[0]-n[0])/3,e[1]+(o[1]-n[1])/3]),a.push(e),a.push(i),a.push([i[0]+(o[0]+n[0])/3,i[1]+(o[1]+n[1])/3]),t.push(a);break}case"DoublePerpendicular":{const e=this._cp2(s,0,-1),i=this._cp3(s,e,.5,3),n=this._mid(r,e),o=this._sub(n,i);this._normalize(o);const a=this._crossProduct(o,this._sub(r,i));this._leftPerpendicular(o);const h=[];h.push(r),h.push([i[0]+o[0]*a,i[1]+o[1]*a]),t.push(h);const c=[];c.push([i[0]-o[0]*a,i[1]-o[1]*a]),c.push(e),t.push(c);break}case"OppositeToFirstSegment":{const e=this._cp2(s,0,-1),i=this._cp3(s,e,.5,3),n=this._mid(r,e),o=this._sub(n,i);this._normalize(o);const a=this._crossProduct(o,this._sub(r,i));this._leftPerpendicular(o);const h=[];h.push([i[0]+o[0]*a,i[1]+o[1]*a]),h.push([i[0]-o[0]*a,i[1]-o[1]*a]),t.push(h);break}case"TriplePerpendicular":{const e=this._cp2(s,0,-1),i=this._cp3(s,e,.5,4),n=this._mid(r,e),o=this._sub(n,i);this._normalize(o);const a=this._crossProduct(o,this._sub(r,i));this._leftPerpendicular(o);const h=[];h.push([i[0]+o[0]*a*.8,i[1]+o[1]*a*.8]),h.push([n[0]+.8*(r[0]-n[0]),n[1]+.8*(r[1]-n[1])]),t.push(h),t.push([i,n]);const c=[];c.push([i[0]-o[0]*a*.8,i[1]-o[1]*a*.8]),c.push([n[0]+.8*(e[0]-n[0]),n[1]+.8*(e[1]-n[1])]),t.push(c);break}case"HalfCircleFirstSegment":{const e=this._cp2(s,0,-1),i=this._cp3(s,e,.5,4),n=this._mid(r,e);let o=this._sub(e,r);const a=Math.cos(Math.PI/18),h=Math.sin(Math.PI/18),c=Math.sqrt((1+a)/2),l=Math.sqrt((1-a)/2),u=[];let d;this._crossProduct(o,this._sub(i,r))>0?(u.push(r),o=this._sub(r,n),d=e):(u.push(e),o=this._sub(e,n),d=r),this._rotateDirect(o,c,l),o[0]/=c,o[1]/=c;for(let e=1;e<=18;e++)u.push(this._add(n,o)),this._rotateDirect(o,a,h);u.push(d),t.push(u);break}case"HalfCircleSecondSegment":{const e=this._cp2(s,0,-1),i=this._cp3(s,e,1,-1);let n=this._sub(r,e);this._normalize(n);const o=this._crossProduct(n,this._sub(i,e))/2;this._leftPerpendicular(n);const a=[e[0]+n[0]*o,e[1]+n[1]*o];n=this._sub(e,a);const h=Math.cos(Math.PI/18);let c=Math.sin(Math.PI/18);o>0&&(c=-c);const l=[e];for(let e=1;e<=18;e++)this._rotateDirect(n,h,c),l.push(this._add(a,n));t.push(l);break}case"HalfCircleExtended":{const e=this._cp2(s,0,-2),n=this._cp3(s,e,1,-1);let o;if(i>=4)o=s[3];else{const t=this._sub(r,e);o=this._add(n,t)}const a=this._dist(e,n)/2/.75,h=this._sub(e,r);this._normalize(h,a);const c=this._sub(n,o);this._normalize(c,a);const l=[o,n];t.push(l);const u=[this._clone(n)];this._addBezier3(u,n,this._add(n,c),this._add(e,h),e,4),u.push(r),t.push(u);break}case"OpenCircle":{const e=this._cp2(s,-2,0),i=this._sub(e,r),n=Math.cos(Math.PI/18),o=-Math.sin(Math.PI/18),a=[e];for(let e=1;e<=33;e++)this._rotateDirect(i,n,o),a.push(this._add(r,i));t.push(a);break}case"CoverageEdgesWithTicks":{const e=this._cp2(s,0,-1);let n,o;if(i>=3)n=s[2];else{const t=this._sub(e,r),s=this._leftPerp(t);n=[r[0]+s[0]-.25*t[0],r[1]+s[1]-.25*t[1]]}if(i>=4)o=s[3];else{const t=this._mid(r,e),s=this._sub(r,e);this._normalize(s),this._leftPerpendicular(s);const i=this._crossProduct(s,this._sub(n,t));this._rightPerpendicular(s),o=[n[0]+s[0]*i*2,n[1]+s[1]*i*2]}const a=this._sub(e,r);let h,c;h=this._crossProduct(a,this._sub(n,r))>0?this._rightPerp(a):this._leftPerp(a),c=[],c.push(n),c.push(r),c.push([r[0]+(h[0]-a[0])/3,r[1]+(h[1]-a[1])/3]),t.push(c),h=this._crossProduct(a,this._sub(o,e))>0?this._rightPerp(a):this._leftPerp(a),c=[],c.push([e[0]+(h[0]+a[0])/3,e[1]+(h[1]+a[1])/3]),c.push(e),c.push(o),t.push(c);break}case"GapExtentWithDoubleTicks":{const e=this._cp2(s,0,2),n=this._cp3(s,e,0,1);let o;if(i>=4)o=s[3];else{const t=this._sub(e,r);o=this._add(n,t)}this._addAngledTicks(t,r,e,this._mid(n,o)),this._addAngledTicks(t,n,o,this._mid(r,e));break}case"GapExtentMidline":{const e=this._cp2(s,2,0),n=this._cp3(s,e,0,1);let o;if(i>=4)o=s[3];else{const t=this._sub(e,r);o=this._add(n,t)}const a=[];a.push(this._mid(r,n)),a.push(this._mid(e,o)),t.push(a);break}case"Chevron":{const e=this._cp2(s,-1,-1);let n;if(i>=3)n=s[2];else{const t=this._sub(e,r);this._leftPerpendicular(t),n=this._add(r,t)}t.push([e,this._makeCtrlPt(r),n]);break}case"PerpendicularWithArc":{const e=this._cp2(s,0,-2),n=this._cp3(s,e,.5,-1),o=this._sub(e,r),a=this._norm(o);o[0]/=a,o[1]/=a;const h=this._crossProduct(o,this._sub(n,r));let c=this._dotProduct(o,this._sub(n,r));c<.05*a?c=.05*a:c>.95*a&&(c=.95*a);const l=[r[0]+o[0]*c,r[1]+o[1]*c];let u=this._leftPerp(o),d=[];if(d.push([l[0]-u[0]*h,l[1]-u[1]*h]),d.push([l[0]+u[0]*h,l[1]+u[1]*h]),t.push(d),i>=4){const e=s[3];let i=this._dotProduct(o,this._sub(e,r));i<.1*a?i=.1*a:i>.9*a&&(i=.9*a);const n=[r[0]+o[0]*i,r[1]+o[1]*i],h=this._crossProduct(o,this._sub(e,r)),c=[];c.push([n[0]-u[0]*h,n[1]-u[1]*h]),c.push([n[0]+u[0]*h,n[1]+u[1]*h]),t.push(c)}const p=[e[0]+u[0]*h,e[1]+u[1]*h];u=this._sub(e,p);const f=Math.cos(Math.PI/18);let _=Math.sin(Math.PI/18);h<0&&(_=-_),d=[r,e];for(let e=1;e<=9;e++)this._rotateDirect(u,f,_),d.push(this._add(p,u));t.push(d);break}case"ClosedHalfCircle":{const e=this._cp2(s,2,0),i=this._mid(r,e),n=this._sub(e,i),o=Math.cos(Math.PI/18),a=Math.sin(Math.PI/18),h=[r,e];for(let e=1;e<=18;e++)this._rotateDirect(n,o,a),h.push(this._add(i,n));t.push(h);break}case"TripleParallelExtended":{const e=this._cp2(s,0,-2),i=this._cp3(s,e,1,-2),n=this._mid(r,e),o=this._sub(i,e);this._normalize(o);const a=Math.abs(this._crossProduct(o,this._sub(n,e)))/2,h=this._dist(e,i),c=[e,r];c.push([r[0]+o[0]*h*.5,r[1]+o[1]*h*.5]),t.push(c);const l=[];l.push([n[0]-o[0]*a,n[1]-o[1]*a]),l.push([n[0]+o[0]*h*.375,n[1]+o[1]*h*.375]),Pe(l[l.length-1],1),l.push([n[0]+o[0]*h*.75,n[1]+o[1]*h*.75]),t.push(l);const u=[e,i];t.push(u);break}case"ParallelWithTicks":{const e=this._cp2(s,3,0),i=this._cp3(s,e,.5,-1),n=this._sub(i,e);this._normalize(n);const o=this._crossProduct(n,this._sub(i,r));this._leftPerpendicular(n),this._addAngledTicks(t,r,e,i),this._addAngledTicks(t,this._mix(r,1,n,o),this._mix(e,1,n,o),this._mid(r,e));break}case"Parallel":{const e=this._cp2(s,3,0),i=this._cp3(s,e,.5,-1),n=this._sub(e,r);this._normalize(n);const o=this._leftPerp(n),a=this._crossProduct(n,this._sub(i,r));let h=[r,e];t.push(h),h=[],h.push([r[0]+o[0]*a,r[1]+o[1]*a]),h.push([e[0]+o[0]*a,e[1]+o[1]*a]),t.push(h);break}case"PerpendicularToFirstSegment":{const e=this._cp2(s,3,0),i=this._cp3(s,e,.5,-1),n=this._mid(r,e),o=this._sub(e,r);this._normalize(o);const a=this._crossProduct(o,this._sub(i,r));this._leftPerpendicular(o);const h=[];h.push([n[0]-o[0]*a*.25,n[1]-o[1]*a*.25]),h.push([n[0]+o[0]*a*1.25,n[1]+o[1]*a*1.25]),t.push(h);break}case"ParallelOffset":{const e=this._cp2(s,3,0),i=this._cp3(s,e,.5,-1),n=this._sub(e,r);this._normalize(n);const o=this._crossProduct(n,this._sub(i,r));this._leftPerpendicular(n);const a=[];a.push([r[0]-n[0]*o,r[1]-n[1]*o]),a.push([e[0]-n[0]*o,e[1]-n[1]*o]),t.push(a);const h=[];h.push([r[0]+n[0]*o,r[1]+n[1]*o]),h.push([e[0]+n[0]*o,e[1]+n[1]*o]),t.push(h);break}case"OffsetOpposite":{const e=this._cp2(s,3,0),i=this._cp3(s,e,.5,-1),n=this._sub(e,r);this._normalize(n);const o=this._crossProduct(n,this._sub(i,r));this._leftPerpendicular(n);const a=[];a.push([r[0]-n[0]*o,r[1]-n[1]*o]),a.push([e[0]-n[0]*o,e[1]-n[1]*o]),t.push(a);break}case"OffsetSame":{const e=this._cp2(s,3,0),i=this._cp3(s,e,.5,-1),n=this._sub(e,r);this._normalize(n);const o=this._crossProduct(n,this._sub(i,r));this._leftPerpendicular(n);const a=[];a.push([r[0]+n[0]*o,r[1]+n[1]*o]),a.push([e[0]+n[0]*o,e[1]+n[1]*o]),t.push(a);break}case"CircleWithArc":{let e=this._cp2(s,3,0);const n=this._cp3(s,e,.5,-1);let o,a;if(i>=4)o=s[3],a=this._crossProduct(this._sub(o,e),this._sub(n,e))>0;else{o=e,a=this._crossProduct(this._sub(o,r),this._sub(n,r))>0;const t=24*this._geomUnitsPerPoint,s=this._sub(o,r);this._normalize(s,t);const i=Math.sqrt(2)/2;this._rotateDirect(s,i,a?i:-i),e=this._add(r,s)}const h=this._sub(e,r),c=Math.cos(Math.PI/18),l=Math.sin(Math.PI/18),u=[e];for(let e=1;e<=36;e++)this._rotateDirect(h,c,l),u.push(this._add(r,h));this._add90DegArc(u,e,o,n,a),Pe(u[u.length-8],1),t.push(u);break}case"DoubleJog":{let e,n=this._cp2(s,-3,1),o=this._cp3(s,n,-1,-.5);if(i>=4)e=s[3];else{const t=r;r=n,e=o;const s=this._dist(r,t),i=this._dist(e,t);let a=30*this._geomUnitsPerPoint;.5*s<a&&(a=.5*s),.5*i<a&&(a=.5*i),n=this._mix(r,a/s,t,(s-a)/s),o=this._mix(e,a/i,t,(i-a)/i)}const a=this._mid(r,n),h=this._mid(e,o),c=this._dist(r,n),l=this._dist(o,e);let u=Math.min(c,l)/8;u=Math.min(u,24*this._geomUnitsPerPoint);const d=Math.cos(Math.PI/4);let p=this._sub(r,n);this._normalize(p,u),this._crossProduct(p,this._sub(e,n))>0?this._rotateDirect(p,d,-d):this._rotateDirect(p,d,d);let f=[];f.push(n),f.push(this._add(a,p)),f.push(this._sub(a,p)),f.push(r),t.push(f),p=this._sub(e,o),this._normalize(p,u),this._crossProduct(p,this._sub(r,o))<0?this._rotateDirect(p,d,d):this._rotateDirect(p,d,-d),f=[],f.push(o),f.push(this._add(h,p)),f.push(this._sub(h,p)),f.push(e),t.push(f);break}case"PerpendicularOffset":{const e=this._cp2(s,-4,1),i=this._cp3(s,e,.882353,-1.94),n=this._sub(i,e);this._crossProduct(n,this._sub(r,e))>0?this._rightPerpendicular(n):this._leftPerpendicular(n);const o=[n[0]/8,n[1]/8],a=this._sub(this._mid(e,i),o);t.push([a,r]);break}case"LineExcludingLastSegment":{const e=this._arrowPath(s),i=[];let r=e.length-2;for(;r--;)i.push(e[r]);t.push(i);break}case"MultivertexArrow":{const e=this._arrowPath(s),i=[];this._addArrow(i,e,!1),t.push(i);break}case"CrossedArrow":{const e=this._arrowPath(s),i=[];this._addArrow(i,e,!0),t.push(i);break}case"ChevronArrow":{const[e,i]=this._arrowLastSeg(s),n=10*this._geomUnitsPerPoint,o=this._sub(r,e),a=this._norm(o);this._normalize(o);const h=this._crossProduct(o,this._sub(i,e));let c=this._dotProduct(o,this._sub(i,e));c<.05*a?c=.05*a:c>.95*a-n&&(c=.95*a-n);const l=[e[0]+o[0]*c,e[1]+o[1]*c],u=this._leftPerp(o),d=[];d.push([l[0]+u[0]*h+o[0]*n,l[1]+u[1]*h+o[1]*n]),d.push(r),d.push([l[0]-u[0]*h+o[0]*n,l[1]-u[1]*h+o[1]*n]),t.push(d);break}case"ChevronArrowOffset":{const[e,i]=this._arrowLastSeg(s),n=this._sub(r,e),o=this._norm(n);this._normalize(n);const a=this._crossProduct(n,this._sub(i,e));let h=this._dotProduct(n,this._sub(i,e));h<.05*o?h=.05*o:h>.95*o&&(h=.95*o);const c=[e[0]+n[0]*h,e[1]+n[1]*h];this._leftPerpendicular(n);const l=[];l.push([c[0]+n[0]*a*.5,c[1]+n[1]*a*.5]),l.push(this._mid(c,r)),l.push([c[0]-n[0]*a*.5,c[1]-n[1]*a*.5]),t.push(l);break}case"PartialFirstSegment":{const[e,i]=this._arrowLastSeg(s),n=this._sub(r,e),o=this._norm(n);this._normalize(n);let a=this._dotProduct(n,this._sub(i,e));a<.05*o?a=.05*o:a>.95*o&&(a=.95*o);const h=[e[0]+n[0]*a,e[1]+n[1]*a];t.push([e,h]);break}case"Arch":{const e=this._cp2(s,0,-1),i=this._cp3(s,e,.5,1),n=this._sub(r,e),o=this._mix(i,1,n,.55),a=this._mix(i,1,n,-.55),h=[r];this._addBezier2(h,r,o,i,4),this._addBezier2(h,i,a,e,4),t.push(h);break}case"CurvedParallelTicks":{const e=this._cp2(s,-4,1),i=this._cp3(s,e,.882353,-1.94),n=this._sub(i,e);this._crossProduct(n,this._sub(r,e))>0?this._rightPerpendicular(n):this._leftPerpendicular(n);const o=[n[0]/8,n[1]/8],a=this._sub(this._mid(e,i),o),h=this._sub(this._mix(e,.75,i,.25),o),c=this._sub(this._mix(e,.25,i,.75),o),l=[e];this._addBezier2(l,e,h,a,3),this._addBezier2(l,a,c,i,3),t.push(l);for(let e=0;e<8;e++){const s=l[2*e+1],i=[this._clone(s)];i.push(this._add(s,[n[0]/4,n[1]/4])),t.push(i)}break}case"Arc90Degrees":{const e=this._cp2(s,0,-1),i=this._cp3(s,e,.5,1),n=[e];this._add90DegArc(n,e,r,i),t.push(n);break}case"TipWithPerpendicularAndTicks":{const[e,i]=this._arrowLastSeg(s),n=10*this._geomUnitsPerPoint,o=this._sub(r,e),a=this._norm(o);this._normalize(o);let h=this._crossProduct(o,this._sub(i,e)),c=this._dotProduct(o,this._sub(i,e));c<.05*a?c=.05*a:c>.95*a-n&&(c=.95*a-n);const l=this._leftPerp(o),u=[r[0]-o[0]*n,r[1]-o[1]*n],d=.5*Math.max(a-c-n,n);h=Math.abs(h);const p=[];p.push([u[0]+l[0]*(h+d)-o[0]*d,u[1]+l[1]*(h+d)-o[1]*d]),p.push([u[0]+l[0]*h,u[1]+l[1]*h]),p.push([u[0]-l[0]*h,u[1]-l[1]*h]),p.push([u[0]-l[0]*(h+d)-o[0]*d,u[1]-l[1]*(h+d)-o[1]*d]),t.push(p),t.push([u,r]);break}case"ConcentricCircles":{const e=this._cp2(s,1,0),n=this._cp3(s,e,2,0),o=Math.cos(Math.PI/18),a=Math.sin(Math.PI/18);let h=this._dist(e,r),c=[h,0],l=[];for(let e=0;e<=36;e++)l.push(this._add(r,c)),this._rotateDirect(c,o,a);if(t.push(l),i>=4){l=[];const e=s[3];h=this._dist(e,r),c=[h,0];for(let e=0;e<=36;e++)l.push(this._add(r,c)),0===e&&(l.push(this._add(r,c)),Pe(l[1],1)),this._rotateDirect(c,o,a);t.push(l)}l=[],h=this._dist(n,r),c=[h,0];for(let e=0;e<=36;e++)l.push(this._add(r,c)),this._rotateDirect(c,o,a);t.push(l);break}case"DoubleJogArrow":{r=this._arrowPath(s)[0];const[e,i]=this._arrowLastSeg(s),n=this._sub(r,e),o=this._norm(n);this._normalize(n);const a=Math.abs(this._crossProduct(n,this._sub(i,r)));let h=Math.abs(this._dotProduct(n,this._sub(i,r)));h<.05*o?h=.05*o:h>.95*o&&(h=.95*o);const c=Math.max(a,h),l=this._leftPerp(n);let u=[];const d=[r[0]-n[0]*h*.5+l[0]*a*.5,r[1]-n[1]*h*.5+l[1]*a*.5];u.push([d[0],d[1]]),d[0]+=n[0]*c*.5+l[0]*c*.4,d[1]+=n[1]*c*.5+l[1]*c*.4,u.push([d[0],d[1]]),d[0]-=l[0]*c*.25,d[1]-=l[1]*c*.25,u.push([d[0],d[1]]),d[0]+=n[0]*c*.5+l[0]*c*.4,d[1]+=n[1]*c*.5+l[1]*c*.4,u.push([d[0],d[1]]),t.push(u),u=[],d[0]=r[0]-n[0]*h*.5-l[0]*a*.5,d[1]=r[1]-n[1]*h*.5-l[1]*a*.5,u.push([d[0],d[1]]),d[0]+=n[0]*c*.5-l[0]*c*.4,d[1]+=n[1]*c*.5-l[1]*c*.4,u.push([d[0],d[1]]),d[0]+=l[0]*c*.25,d[1]+=l[1]*c*.25,u.push([d[0],d[1]]),d[0]+=n[0]*c*.5-l[0]*c*.4,d[1]+=n[1]*c*.5-l[1]*c*.4,u.push([d[0],d[1]]),t.push(u);break}case"LinkedChevrons":{const e=this._cp2(s,-5,0),i=this._cp3(s,e,-.2,1),n=this._sub(r,e);this._normalize(n);const o=this._leftPerp(n),a=Math.abs(this._crossProduct(n,this._sub(i,e)));t.push([e,r]);const h=[];h.push([r[0]-n[0]*a+o[0]*a,r[1]-n[1]*a+o[1]*a]),h.push(r),h.push([r[0]-n[0]*a-o[0]*a,r[1]-n[1]*a-o[1]*a]),t.push(h),this._addDash(t,e,[-n[0]*a+o[0]*a,-n[1]*a+o[1]*a]),this._addDash(t,e,[-n[0]*a-o[0]*a,-n[1]*a-o[1]*a]);break}case"SegmentThenHalfCircle":{const e=this._cp2(s,2,0),n=this._cp3(s,e,1.5,0);let o;o=i>=4?s[3]:this._cp3(s,e,1.25,-.5);const a=this._sub(e,r);this._normalize(a);const h=.5*this._dist(e,n),c=this._crossProduct(a,this._sub(o,r))>0,l=Math.cos(Math.PI/18);let u=Math.sin(Math.PI/18);c&&(u=-u);const d=[r,e];a[0]*=h,a[1]*=h;const p=this._add(e,a);a[0]=-a[0],a[1]=-a[1];for(let e=1;e<=18;e++)this._rotateDirect(a,l,u),d.push(this._add(p,a));t.push(d);break}case"LineWithStraightTicks":{const e=this._cp2(s,-2,1),i=this._cp3(s,e,-1,-.5),n=this._sub(i,e);this._normalize(n);const o=this._dotProduct(n,this._sub(e,r)),a=this._dotProduct(n,this._sub(i,r));let h=[r];h.push([r[0]+n[0]*o,r[1]+n[1]*o]),h.push(e),t.push(h),h=[r],h.push([r[0]+n[0]*a,r[1]+n[1]*a]),h.push(i),t.push(h);break}case"DoubleCurve":{const e=this._cp2(s,-5,-1),i=this._cp3(s,e,2,0),n=Math.atan2(1,5),o=Math.cos(n),a=Math.sin(n),h=this._sub(e,r),c=this._dist(r,e);this._normalize(h),this._rotateDirect(h,o,-a);const l=[r];l.push([r[0]+h[0]*c*.5,r[1]+h[1]*c*.5]),Pe(l[1],1),l.push([r[0]+h[0]*c*.8,r[1]+h[1]*c*.8]),this._addBezier2(l,l[2],[r[0]+h[0]*c,r[1]+h[1]*c],e,3);const u=this._sub(i,e),d=this._dist(e,i);this._normalize(u),this._rotateDirect(u,o,-a),this._addBezier2(l,e,[i[0]-u[0]*d,i[1]-u[1]*d],[i[0]-u[0]*d*.8,i[1]-u[1]*d*.8],3),l.push(i),t.push(l);break}case"ParallelWithTicksByWidth":{const e=this._cp2(s,0,-1),i=this._cp3(s,e,.5,3),n=this._sub(e,r);this._normalize(n);const o=this._crossProduct(n,this._sub(i,r));this._leftPerpendicular(n),o>0?(this._addAngledTicks(t,r,[r[0]+n[0]*o,r[1]+n[1]*o],e),this._addAngledTicks(t,e,[e[0]+n[0]*o,e[1]+n[1]*o],r)):(this._addAngledTicks(t,[r[0]+n[0]*o,r[1]+n[1]*o],r,e),this._addAngledTicks(t,[e[0]+n[0]*o,e[1]+n[1]*o],r,e));break}case"EnclosingRoundedRectangle":{const e=this._cp2(s,3,-2),t=[Math.min(r[0],e[0]),Math.max(r[1],e[1])],i=[Math.max(r[0],e[0]),Math.min(r[1],e[1])],n=i[0]-t[0],o=t[1]-i[1],a=Math.min(n,o)/10,h=[];h.push([t[0]+a+.75*(n-2*a),t[1]]),h.push([i[0]-a,t[1]]),this._add90DegArc(h,[i[0]-a,t[1]],[i[0],t[1]-a],[i[0],t[1]]),h.push([i[0],i[1]+a]),this._add90DegArc(h,[i[0],i[1]+a],[i[0]-a,i[1]],i),h.push([t[0]+a,i[1]]),this._add90DegArc(h,[t[0]+a,i[1]],[t[0],i[1]+a],[t[0],i[1]]),h.push([t[0],t[1]-a]),this._add90DegArc(h,[t[0],t[1]-a],[t[0]+a,t[1]],t),h.push([t[0]+a+.75*(n-2*a),t[1]]);break}default:t.push(s)}}return t}}class Je{static{this.instance=null}static local(){return null===Je.instance&&(Je.instance=new Je),Je.instance}execute(e,t,s){return new Ke(e,t,s)}}class Ke extends ke{constructor(e,t,s){super(e,!0,!0),this._curveHelper=new Ae,this._beginCut=(void 0!==t.beginCut?t.beginCut:1)*s,this._endCut=(void 0!==t.endCut?t.endCut:1)*s,this._middleCut=(void 0!==t.middleCut?t.middleCut:0)*s,this._invert=void 0!==t.invert&&t.invert,this._beginCut<0&&(this._beginCut=0),this._endCut<0&&(this._endCut=0),this._middleCut<0&&(this._middleCut=0)}processPath(e){const{_beginCut:t,_endCut:s,_middleCut:i}=this,r=e.pathLength(),n=ye.z.createEmptyOptimizedCIM("esriGeometryPolyline");if(this._invert){if(0!==t||0!==s||0!==i)if(t+s+i>=r)for(n.startPath();e.nextPoint();)n.pushXY(e.x,e.y);else this._curveHelper.appendSubCurve(n,e,0,t),this._curveHelper.appendSubCurve(n,e,.5*(r-i),.5*(r+i)),this._curveHelper.appendSubCurve(n,e,r-s,s)}else if(0===t&&0===s&&0===i)for(n.startPath();e.nextPoint();)n.pushXY(e.x,e.y);else t+s+i<r&&(0===i?this._curveHelper.appendSubCurve(n,e,t,r-s):(this._curveHelper.appendSubCurve(n,e,t,.5*(r-i)),this._curveHelper.appendSubCurve(n,e,.5*(r+i),r-s)));return 0===n.totalSize?null:n}}class et{constructor(){this._values=[],this.extPtGap=0,this.ctrlPtGap=0,this._length=0,this._currentValue=0}isEmpty(){return 0===this._values.length}size(){return this._values.length}init(e,t,s=!0){if(this._setEmpty(),!e||0===e.length)return!1;for(let t=0;t<e.length;t++){let i=Math.abs(e[t]);s&&i<1e-7&&(i=1e-7),this._values.push(i),this._length+=i}return t&&1&e.length&&(this._length*=2),0!==this._length&&(this.ctrlPtGap=this.extPtGap=0,this._currentValue=-1,!0)}scale(e){const t=this._values?this._values.length:0;for(let s=0;s<t;++s)this._values[s]*=e;this._length*=e,this.extPtGap*=e,this.ctrlPtGap*=e}addValue(e){this._length+=e,this._values.push(e)}firstValue(){return this._values[0]}lastValue(){return this._values[this._values.length-1]}nextValue(){return this._currentValue++,this._currentValue===this._values.length&&(this._currentValue=0),this._values[this._currentValue]}reset(){this._currentValue=-1}length(){return this._length}_setEmpty(){this.extPtGap=this.ctrlPtGap=this._length=0,this._currentValue=-1,this._values.length=0}}class tt{constructor(){this.pt=null,this.ca=0,this.sa=0}}class st{constructor(){this.reset()}reset(){this.segment=null,this.segmentLength=0,this.abscissa=0,this.isPathEnd=!1,this.isPartEnd=!1}isValid(){return null!==this.segment}copyTo(e){e.segment=this.segment,e.segmentLength=this.segmentLength,e.abscissa=this.abscissa,e.isPathEnd=this.isPathEnd,e.isPartEnd=this.isPartEnd}}class it extends Ae{constructor(e=0,t=!1){super(e,t),this._tempPos=new st,this._tempPt=[0,0],this._tolerance=Ce,this._currentPosition=new st}updateTolerance(e){this._tolerance=Ce*e}init(e,t,s=!0){return s?(this._patternLength=t.length(),this._partExtPtGap=t.extPtGap,this._partCtrlPtGap=t.ctrlPtGap):(this._patternLength=0,this._partExtPtGap=0,this._partCtrlPtGap=0),this._currentPosition.reset(),this._partSegCount=0,this._pathCursor=e,this._seg=-1,this._setPosAtNextPart()}curPositionIsValid(){return this._currentPosition.isValid()}nextPosition(e,t=0){const s=new st;return!!this._nextPosition(e,s,null,t)&&(s.copyTo(this._currentPosition),!0)}curPointAndAngle(e){e.pt=this._getPoint(this._currentPosition);const[t,s]=this._getAngleCS(this._tempPt,this._currentPosition);e.ca=t,e.sa=s}nextPointAndAngle(e,t,s=0){const i=this._tempPos;if(!this._nextPosition(e,i,null,s))return!1;i.copyTo(this._currentPosition),t.pt=this._getPoint(i);const[r,n]=this._getAngleCS(this._tempPt,i);return t.ca=r,t.sa=n,!0}nextCurve(e){if(0===e)return null;const t=ye.z.createEmptyOptimizedCIM("esriGeometryPolyline");t.startPath(),t.nextPath();const s=new st;return this._nextPosition(e,s,t,1)?(s.copyTo(this._currentPosition),t):null}isPathEnd(){return this._currentPosition.isPathEnd}getPathEnd(){return this._currentPosition.segment[1]}getPt(e){return this._pathCursor.seekInPath(e),[this._pathCursor.x,this._pathCursor.y]}getSeg(e){return[this.getPt(e),this.getPt(e+1)]}_nextPosition(e,t,s,i){if(this._currentPosition.isPathEnd)return!1;let r=this._currentPosition.abscissa;for(this._currentPosition.segmentLength>0&&(r/=this._currentPosition.segmentLength),this._currentPosition.copyTo(t);t.abscissa+e*this._partLengthRatio>t.segmentLength+this._tolerance;){if(s){if(0===s.pathSize)if(0===r){const e=t.segment[0];s.pushXY(e[0],e[1])}else s.pushPoint(this.getSegCoord2D(t.segment,r));const e=t.segment[1];s.pushXY(e[0],e[1])}if(r=0,e-=(t.segmentLength-t.abscissa)/this._partLengthRatio,this._partSegCount)t.segment=this._nextSegment(),t.segmentLength=this.getSegLength(t.segment),t.abscissa=0,this._partSegCount--;else{if(!this._setPosAtNextPart())return 0!==i&&(t.segmentLength=this.getSegLength(t.segment),t.isPartEnd=!0,1===i?(t.abscissa=t.segmentLength,t.isPathEnd=!0):t.abscissa=t.segmentLength+e,!0);this._currentPosition.copyTo(t)}}if(t.abscissa+=e*this._partLengthRatio,s){0===s.pathSize&&(0===r?s.pushPoint(t.segment[0]):s.pushPoint(this.getSegCoord2D(t.segment,r)));const e=t.abscissa/t.segmentLength;1===e?s.pushPoint(t.segment[1]):s.pushPoint(this.getSegCoord2D(t.segment,e))}return this._partSegCount||Math.abs(t.abscissa-t.segmentLength)<this._tolerance&&(t.isPathEnd=this._partIsLast,t.isPartEnd=!0),!0}_getPoint(e){const t=e.segmentLength<=0?0:e.abscissa/e.segmentLength;return this.getSegCoord2D(this._currentPosition.segment,t)}_getAngleCS(e,t){const s=t.segmentLength<=0?0:t.abscissa/t.segmentLength;return this.getSegAngleCS(e,this._currentPosition.segment,s)}_setPosAtNextPart(){for(;this._partSegCount;)this._hasNextSegment()&&this._nextSegment(),this._partSegCount--;if(!this._hasNextSegment())return!1;for(this._partLength=0,this._partIsLast=!0,this._partSegCount=0;this._hasNextSegment();)if(this._partLength+=this.getSegLength(this._nextSegment()),this._partSegCount++,this._pathCursor.getControlPointAt(this._getEndPointIndex())){this._partIsLast=!this._hasNextSegment();break}let e=this._partSegCount;for(;e;)this._previousSegment(),--e;this._currentPosition.segment=this._nextSegment(),this._currentPosition.segmentLength=this.getSegLength(this._currentPosition.segment),this._currentPosition.abscissa=0,this._currentPosition.isPathEnd=this._currentPosition.isPartEnd=!1,--this._partSegCount;const t=this._getStartPointIndex();this._ctrlPtBegin=this._pathCursor.getControlPointAt(t);let s=t+this._partSegCount+1;if(s>=this._pathCursor.pathSize&&(s=0),this._ctrlPtEnd=this._pathCursor.getControlPointAt(s),this._patternLength>0){const e=this._ctrlPtBegin?this._partCtrlPtGap:this._partExtPtGap,t=this._ctrlPtEnd?this._partCtrlPtGap:this._partExtPtGap;let s=Math.round((this._partLength-(e+t))/this._patternLength);s<=0&&(s=e+t>0?0:1),this._partLengthRatio=this._partLength/(e+t+s*this._patternLength),this._partLengthRatio<.01&&(this._partLengthRatio=1)}else this._partLengthRatio=1;return!0}_hasNextSegment(){return this._seg<this._pathCursor.pathSize-2}_previousSegment(){return this.getSeg(--this._seg)}_nextSegment(){return this.getSeg(++this._seg)}_getStartPointIndex(){return this._seg}_getEndPointIndex(){return this._seg+1}}class rt{static{this.instance=null}static local(){return null===rt.instance&&(rt.instance=new rt),rt.instance}execute(e,t,s){return new nt(e,t,s)}}class nt extends ke{constructor(e,t,s){super(e,!0,!0),this._firstCurve=null,this._walker=new it,this._walker.updateTolerance(s),this._endings=t.lineDashEnding,this._customDashPos=-(t.offsetAlongLine??0)*s,this._offsetAtEnd=(t.customEndingOffset??0)*s;let i=(0,Oe.FH)(t).dashTemplate;null==i&&(i=[]),i.length%2&&(i=[...i,...i]),this._pattern=new et,this._pattern.init(i,!0),this._pattern.scale(s)}processPath(e){if(0===this._pattern.length()){this.iteratePath=!1;const t=(0,Se.A)(e);return ye.z.fromJSONCIM({paths:[t]})}if(!this.iteratePath){let t=!0;switch(this._endings){case"HalfPattern":case"HalfGap":default:this._pattern.extPtGap=0;break;case"FullPattern":this.isClosed||(this._pattern.extPtGap=.5*this._pattern.firstValue());break;case"FullGap":this.isClosed||(this._pattern.extPtGap=.5*this._pattern.lastValue());break;case"NoConstraint":this.isClosed||(t=!1);break;case"Custom":this.isClosed||(this._pattern.extPtGap=.5*this._offsetAtEnd)}const s=e.pathLength();if(this._pattern.isEmpty()||s<.1*this._pattern.length()){const t=(0,Se.A)(e);return ye.z.fromJSONCIM({paths:[t]})}if(!this._walker.init(e,this._pattern,t)){const t=(0,Se.A)(e);return ye.z.fromJSONCIM({paths:[t]})}}let t;if(this.iteratePath)t=this._pattern.nextValue();else{let e;switch(this._endings){case"HalfPattern":default:e=.5*this._pattern.firstValue();break;case"HalfGap":e=.5*-this._pattern.lastValue();break;case"FullGap":e=-this._pattern.lastValue();break;case"FullPattern":e=0;break;case"NoConstraint":case"Custom":e=-this._customDashPos}let s=e/this._pattern.length();s-=Math.floor(s),e=s*this._pattern.length(),this._pattern.reset(),t=this._pattern.nextValue();let i=!1;for(;e>=t;)e-=t,t=this._pattern.nextValue(),i=!i;t-=e,i?(this._walker.nextPosition(t),t=this._pattern.nextValue()):this.isClosed&&(this._firstCurve=this._walker.nextCurve(t),t=this._pattern.nextValue(),this._walker.nextPosition(t),t=this._pattern.nextValue())}let s=this._walker.nextCurve(t);if(s)if(this._walker.isPathEnd()){if(this.iteratePath=!1,this._firstCurve){for(this._firstCurve.nextPath();this._firstCurve.nextPoint();)s.pushXY(this._firstCurve.x,this._firstCurve.y);this._firstCurve=null}}else t=this._pattern.nextValue(),!this._walker.nextPosition(t)||this._walker.isPathEnd()?(this.iteratePath=!1,this._firstCurve&&(s.pushCursor(this._firstCurve),this._firstCurve=null)):this.iteratePath=!0;else this.iteratePath=!1,s=this._firstCurve,this._firstCurve=null;return s?.reset(),s}}class ot{static{this.instance=null}static local(){return null===ot.instance&&(ot.instance=new ot),ot.instance}execute(e,t,s,i,r,n){return new at(e,t,s,i,r,n)}}class at{constructor(e,t,s,i,r,n){this._preventClipping=n,this._inputGeometries=e,this._tileKey=i,this._maxInflateSize=r*s,this._width=(void 0!==t.width?t.width:2)*s,t.method,this._option=t.option}next(){let e;for(;e=this._inputGeometries.next();){if("esriGeometryEnvelope"===e.geometryType&&this._width>0){const t=e.asJSON();return Math.min(t.xmax-t.xmin,t.ymax-t.ymin)-2*this._width<0?e:ye.z.fromJSONCIM({paths:[[[t.xmin+this._width,t.ymin+this._width],[t.xmax-this._width,t.ymin+this._width],[t.xmax-this._width,t.ymax-this._width],[t.xmin+this._width,t.ymax-this._width],[t.xmin+this._width,t.ymin+this._width]],[[t.xmin,t.ymin],[t.xmin,t.ymax],[t.xmax,t.ymax],[t.xmax,t.ymin],[t.xmin,t.ymin]]]})}if("esriGeometryPolygon"===e.geometryType){if(0===this._width)return e.clone();const t=Re.module,s=!this._preventClipping&&this._tileKey?Ye(e,this._maxInflateSize,!0):e.clone();if(!s)continue;const i={...s.asJSON(),spatialReference:{wkid:ze.A.WebMercator.wkid}},r=t.execute(i,-this._width);if(r)for(const e of r.rings)if(e){s.startPath();for(const t of e.reverse())s.pushXY(t[0],s.yFactor*t[1])}return s}}return null}}var ht=s(537);class ct{static{this.instance=null}static local(){return null===ct.instance&&(ct.instance=new ct),ct.instance}execute(e,t){return new lt(e,t)}}class lt{constructor(e,t){this._inputGeometries=e,this._medhod=t.method}next(){let e=this._inputGeometries.next();const t=this._medhod;for(;null!=e;){if(e.totalSize>0)switch(t){case"RectangularBox":return ut(e);case"ConvexHull":return this._constructConvexHull(e);default:return dt(e)}e=this._inputGeometries.next()}return null}_constructConvexHull(e){switch(e.geometryType){case"esriGeometryPolyline":case"esriGeometryPolygon":{const t=Le.module,s={...e.asJSON(),spatialReference:{wkid:ze.A.WebMercator.wkid}},i=t.execute(s);return i?ye.z.fromJSONCIM(i):null}case"esriGeometryEnvelope":return e;default:return null}}}function ut(e){const t=(0,ht.z8)(e),s={xmin:t[0],ymin:t[1],xmax:t[2],ymax:t[3]};return ye.z.fromJSONCIM(s)}function dt(e){switch(e.geometryType){case"esriGeometryPolyline":{const t=[];for(;e.nextPath();)pt(e,t);return ye.z.fromJSONCIM({rings:t})}case"esriGeometryPolygon":case"esriGeometryEnvelope":return e;default:return null}}function pt(e,t){if(e.seekPathStart(),!e.nextPoint())return;const s=e.x,i=e.y,r=[[s,i]];for(t.push(r);e.nextPoint();)r.push([e.x,e.y]);r.push([s,i])}class ft{static{this.instance=null}static local(){return null===ft.instance&&(ft.instance=new ft),ft.instance}execute(e,t,s){return new _t(e,t,s)}}class _t extends ke{constructor(e,t,s){super(e,!1,!0),this._curveHelper=new Ae,this._length=(void 0!==t.length?t.length:20)*s,this._angle=void 0!==t.angle?t.angle:225,this._position=void 0!==t.position?t.position:50,this._length<0&&(this._length=-this._length),this._position<20&&(this._position=20),this._position>80&&(this._position=80),this._mirror=!1}processPath(e){const t=ye.z.createEmptyOptimizedCIM("esriGeometryPolyline");if(this._curveHelper.isEmpty(e))return null;e.seekInPath(0);const s=e.x,i=e.y;e.seekInPath(e.pathSize-1);const r=e.x,n=e.y,o=[r-s,n-i];this._curveHelper.normalize(o);const a=s+(r-s)*this._position/100,h=i+(n-i)*this._position/100,c=Math.cos((90-this._angle)/180*Math.PI);let l=Math.sin((90-this._angle)/180*Math.PI);this._mirror&&(l=-l),this._mirror=!this._mirror;const u=[a-this._length/2*c,h-this._length/2*l],d=[a+this._length/2*c,h+this._length/2*l];return t.pushPath([[s,i],u,d,[r,n]]),t}}class mt{static{this.instance=null}static local(){return null===mt.instance&&(mt.instance=new mt),mt.instance}execute(e,t,s){return new gt(e,t,s)}}class gt{constructor(e,t,s){this._inputGeometries=e,this._offsetX=void 0!==t.offsetX?t.offsetX*s:0,this._offsetY=void 0!==t.offsetY?t.offsetY*s:0}next(){let e=this._inputGeometries.next();for(;e;){if(e.totalSize>0)return this._move(e.clone(),this._offsetX,this._offsetY);e=this._inputGeometries.next()}return null}_move(e,t,s){for(;e.nextPath();)for(;e.nextPoint();)e.x=e.x+t,e.y=e.y+s;return e.reset(),e}}var yt=s(60408);class xt{static{this.instance=null}static local(){return null===xt.instance&&(xt.instance=new xt),xt.instance}execute(e,t,s,i,r,n){return new bt(e,t,s,i,r,n)}}class bt{constructor(e,t,s,i,r,n){this._preventClipping=n,this._inputGeometries=e,this._tileKey=i,this._curveHelper=new Ae,this._offset=(t.offset??1)*s,this._method=t.method,this._maxInflateSize=Math.max(Math.abs(r*s),10),this._option=t.option,this._offsetFlattenError=Ce*s}next(){let e;for(;e=this._inputGeometries.next();){if(0===this._offset)return e.clone();if("esriGeometryEnvelope"===e.geometryType){if("Rounded"===this._method&&this._offset>0){const t=(0,Se.A)(e),s=this._curveHelper.offset(t,-this._offset,this._method,4,this._offsetFlattenError);if(s){const t=ye.z.createEmptyOptimizedCIM(e.geometryType);return t.pushPath(s),t}return null}const t=e.asJSON();if((0,yt.ZC)(t)&&Math.min(t.xmax-t.xmin,t.ymax-t.ymin)+2*this._offset>0)return ye.z.fromJSONCIM({xmin:t.xmin-this._offset,xmax:t.xmax+this._offset,ymin:t.ymin-this._offset,ymax:t.ymax+this._offset})}const t=!this._preventClipping&&this._tileKey?Ye(e,this._maxInflateSize,!0):e.clone();if(!t)continue;const s=qe.module,i=Ge.module,r={...t.asJSON(),spatialReference:{wkid:ze.A.WebMercator.wkid}};let n,o=wt(this._method);return"esriGeometryPolygon"===e.geometryType&&this._offset>0?("square"===o&&(o="bevel"),n=i.executeMany([r],[this._offset],o,"round")[0]):n=s.execute(r,-this._offset,{joins:o,flattenError:this._offsetFlattenError,miterLimit:4}),n?ye.z.fromJSONCIM(n):null}return null}}function wt(e){switch(e){case"Rounded":return"round";case"Bevelled":return"bevel";case"Mitered":return"miter";case"Square":return"square"}}var vt=s(12359);class St{static{this.instance=null}static local(){return null===St.instance&&(St.instance=new St),St.instance}execute(e,t,s){return new It(e,t,s)}}class It{constructor(e,t,s){this._inputGeometries=e,this._length=(void 0!==t.length?t.length:xe.D.CIMGeometricEffectRadial.length)*s,this._angle=void 0!==t.angle?t.angle*Math.PI/180:xe.D.CIMGeometricEffectRadial.angle,this._lx=Math.cos(this._angle)*this._length,this._ly=Math.sin(this._angle)*this._length}next(){let e=this._inputGeometries.next();for(;e;){if("esriGeometryPoint"===e.geometryType||"esriGeometryMultipoint"===e.geometryType){const t=ye.z.createEmptyOptimizedCIM("esriGeometryPolyline");return e.nextPath()&&e.nextPoint()&&t.pushPath([[e.x,e.y],[e.x+this._lx,e.y+this._ly]]),t}if("esriGeometryPolygon"===e.geometryType){const t=(0,vt.IK)(e);if(!t)return null;const s=ye.z.createEmptyOptimizedCIM("esriGeometryPolyline");return s.pushPath([[t[0],t[1]],[t[0]+this._lx,t[1]+this._ly]]),s}e=this._inputGeometries.next()}return null}}class Pt{static{this.instance=null}static local(){return null===Pt.instance&&(Pt.instance=new Pt),Pt.instance}execute(e,t,s){return new Mt(e,t,s)}}class Mt{constructor(e,t,s){this._inputGeometries=e,this._reverse=void 0===t.reverse||t.reverse}next(){let e=this._inputGeometries.next();for(;e;){if(!this._reverse)return e;if("esriGeometryPolyline"===e.geometryType)return kt(e.clone());e=this._inputGeometries.next()}return null}}function kt(e){for(;e.nextPath();)for(let t=0;t<e.pathSize/2;t++){e.seekInPath(t);const s=e.x,i=e.y;e.seekInPath(e.pathSize-t-1);const r=e.x,n=e.y;e.x=s,e.y=i,e.seekInPath(t),e.x=r,e.y=n}return e.reset(),e}class Ct{static{this.instance=null}static local(){return null===Ct.instance&&(Ct.instance=new Ct),Ct.instance}execute(e,t,s){return new At(e,t,s)}}class At{constructor(e,t,s){this._inputGeometries=e,this._rotateAngle=void 0!==t.angle?t.angle*Math.PI/180:0}next(){let e=this._inputGeometries.next();for(;e;){if(0===this._rotateAngle||"esriGeometryPoint"===e.geometryType)return e;if(e.totalSize>0){const t=(0,ht.z8)(e),s=(t[2]+t[0])/2,i=(t[3]+t[1])/2;return e.reset(),this._rotate(e.clone(),s,i)}e=this._inputGeometries.next()}return null}_rotate(e,t,s){const i=Math.cos(this._rotateAngle),r=Math.sin(this._rotateAngle);for(;e.nextPath();)for(;e.nextPoint();){const n=e.x-t,o=e.y-s;e.x=t+n*i-o*r,e.y=s+n*r+o*i}return e.reset(),e}}class Tt{static{this.instance=null}static local(){return null===Tt.instance&&(Tt.instance=new Tt),Tt.instance}execute(e,t,s){return new Ft(e,t,s)}}class Ft{constructor(e,t,s){this._inputGeometries=e,this._xFactor=void 0!==t.xScaleFactor?t.xScaleFactor:1.15,this._yFactor=void 0!==t.yScaleFactor?t.yScaleFactor:1.15}next(){const e=this._inputGeometries.next();if(e){if(1===this._xFactor&&1===this._yFactor)return e;if("esriGeometryPoint"===e.geometryType)return e;if(e.totalSize>0){const t=(0,ht.z8)(e),s=(t[2]+t[0])/2,i=(t[3]+t[1])/2;return e.reset(),this._scaleCursor(e.clone(),s,i)}}return null}_scaleCursor(e,t,s){for(;e.nextPath();)for(;e.nextPoint();)e.x=t+(e.x-t)*this._xFactor,e.y=s+(e.y-s)*this._yFactor;return e.reset(),e}}class zt{constructor(){this._polyline=[]}beginPath(e){this._polyline.push([e])}lineTo(e){if(0===this._polyline.length)throw new Error("No path started. Call beginPath first.");this._polyline[this._polyline.length-1].push(e)}getPointCount(){return this._polyline.reduce((e,t)=>e+t.length,0)}addSegment(e,t,s){s&&this.beginPath(e),this.lineTo(t)}getXY(e){let t=0;for(const s of this._polyline){if(e<t+s.length)return s[e-t];t+=s.length}return null}getGeometry(){return this._polyline}}class Et{static{this.instance=null}static local(){return null===Et.instance&&(Et.instance=new Et),Et.instance}execute(e,t,s){return new Ot(e,t,s)}}class Ot extends ke{constructor(e,t,s){super(e,!1,!0),this._suppress=void 0!==t.suppress&&t.suppress,this._invert=void 0!==t.invert&&t.invert}processPath(e){if(e.totalSize<=0)return null;if(!this._suppress){const t=ye.z.createEmptyOptimizedCIM("esriGeometryPolygon",!1,!1,e.yFactor);for(e.seekPathEnd();e.nextPoint();)t.pushXY(e.x,e.y);return t}const t=[],s=new Array(e.pathSize);let i=0;for(e.seekPathStart();e.nextPoint();)s[i++]=e.getControlPoint(),t.push([e.x,e.y]);let r=!0,n=!0,o=!1,a=!this._invert;i=0;const h=new zt;let c=t[0];for(;i<t.length-1;){const e=t[i+1],l=s[i],u=s[i+1];i++,n&&(a=l||u?this._invert:!this._invert,n=!1),a?(h.addSegment(c,e,r),r=!1):o=!0,c=e,u&&(a?(a=!1,r=!0):a=!0)}const l=h.getGeometry();if(0===l.length)return null;if(!o&&t[0][0]===t[t.length-1][0]&&t[0][1]===t[t.length-1][1]){const e=l[l.length-1];return e[0][0]===e[e.length-1][0]&&e[0][1]===e[e.length-1][1]||e.push([e[0][0],e[0][1]]),ye.z.fromJSONCIM({paths:l})}const u=l[l.length-1];return h.getPointCount()>1&&"esriGeometryPolygon"===e.geometryType&&u[0][0]===u[u.length-1][0]&&u[0][1]===u[u.length-1][1]&&l.length>1&&(l[l.length-1].push(...l[0]),l.splice(0,1)),ye.z.fromJSONCIM({paths:l})}}var Rt=s(53966);const Lt=()=>Rt.A.getLogger("esri.symbols.cim.effects.EffectTaperedPolygon");class Dt{static{this.instance=null}static local(){return null===Dt.instance&&(Dt.instance=new Dt),Dt.instance}execute(e,t,s){return new Nt(e,t,s)}}class Nt extends ke{constructor(e,t,s){super(e,!1,!0),this._slopeS=0,this._slopeC=1,this._lastTangent1=new Ee.bR(NaN,NaN),this._lastWidth=0,this._geomUnitsPerPoint=s,this._halfFromWidth=Math.abs(void 0!==t.fromWidth?t.fromWidth:0)*s*.5,this._halfToWidth=Math.abs(void 0!==t.toWidth?t.toWidth:1)*s*.5,this._originalLength=(void 0!==t.length?t.length:0)*s,this._length=0}processPath(e){if(e.totalSize<=0)return null;if(this._halfFromWidth<=0&&this._halfToWidth<=0){const t=ye.z.createEmptyOptimizedCIM("esriGeometryPolygon",!1,!1,e.yFactor);for(e.seekPathEnd();e.prevPoint();)t.pushXY(e.x,e.y);for(e.seekPathStart();e.nextPoint();)t.pushXY(e.x,e.y);return t}const t=e.getCurrentPath().asJSON(),s=Ne.module.execute(t,.25*this._geomUnitsPerPoint,{removeDegenerateParts:!0}),r=null==s?null:(0,yt.Bi)(s)?s.rings:(0,yt.Rg)(s)?s.paths:null;if(!r)return Lt().error(new i.A("mapview-bad-resource","Unable to process geometry")),null;const n=De.module.execute(s);if((0===this._originalLength||this._originalLength>n)&&n>0){this._length=n;const e=(this._halfToWidth-this._halfFromWidth)/this._length;if(Math.abs(e)<1){const t=e*e;this._slopeC=Math.sqrt(1/(1+t)),this._slopeS=Math.sqrt(t/(1+t)),e<0&&(this._slopeS=-this._slopeS)}else this._slopeC=this._slopeS=.7071}else this._length=this._originalLength,this._slopeC=1,this._slopeS=0;const o=[];for(const e of r){const t=new zt,s=new zt;let i=0;this._setFromOffset(e.slice(0,2),t,s);for(let r=0,n=3;n<=e.length;++r,++n)i=this._setOffset(e.slice(r,n),i,t,s);this._setToOffset(e.slice(-2),i,t,s);const[r]=t.getGeometry(),[n]=s.getGeometry();o.push([...r,...n.reverse()])}const a={rings:o,spatialReference:{wkid:ze.A.WebMercator.wkid}},h=Be.module.execute(a);return ye.z.fromJSONCIM(h)}_setFromOffset([[e,t],[s,i]],r,n){const o=this._halfFromWidth,a=new Ee.bR(s-e,i-t).normalize().scale(o);r.beginPath([e-a.y,t+a.x]),n.beginPath([e+a.y,t-a.x])}_setToOffset([[e,t],[s,i]],r,n,o){let a;a=(r+=Math.sqrt((s-e)**2+(i-t)**2))>=this._length?this._halfToWidth:this._halfFromWidth+(this._halfToWidth-this._halfFromWidth)*r/this._length;const h=new Ee.bR(s-e,i-t).normalize().scale(a);n.lineTo([s-h.y,i+h.x]),o.lineTo([s+h.y,i-h.x])}_setOffset([[e,t],[s,r],[n,o]],a,h,c){const l=Math.sqrt((s-e)**2+(r-t)**2);let u;u=a+l>=this._length?this._halfToWidth:this._halfFromWidth+(this._halfToWidth-this._halfFromWidth)*(a+l)/this._length,a+=l;const d=new Ee.bR(s,r),p=new Ee.bR(s-e,r-t).normalize(),f=new Ee.bR(n-s,o-r).normalize(),_=Ee.bR.sub(f,p),m=h.getPointCount(),g=c.getPointCount();p.leftPerpendicular(),f.leftPerpendicular();const y=p.x*f.x+p.y*f.y;if(y>.99){const e=Ee.bR.add(p,f).scale(u/2),t=e.clone().rotate(this._slopeC,this._slopeS);h.lineTo([d.x+t.x,d.y+t.y]);const s=e.rotateReverse(this._slopeC,this._slopeS);c.lineTo([d.x-s.x,d.y-s.y])}else{const s=p.x*f.y-p.y*f.x;if(_.scale(1/s),s<0){_.scale(-u).rotateReverse(this._slopeC,this._slopeS);const e=c.getXY(g-1);e||Lt().error(new i.A("mapview-bad-resource","Unable to process geometry, index out of scope"));const t=Ee.bR.add(d,_).sub(Ee.bR.fromArray(e));if(p.x*t.y-p.y*t.x>0){const e=p.clone().scale(-u).rotateReverse(this._slopeC,this._slopeS),t=f.clone().scale(-u).rotateReverse(this._slopeC,this._slopeS);c.lineTo([d.x+e.x,d.y+e.y]),c.lineTo([d.x,d.y]),c.lineTo([d.x+t.x,d.y+t.y])}else c.lineTo([d.x+_.x,d.y+_.y])}else{_.scale(u).rotate(this._slopeC,this._slopeS);const e=h.getXY(m-1);e||Lt().error(new i.A("mapview-bad-resource","Unable to process geometry, index out of scope"));const t=Ee.bR.add(d,_).sub(Ee.bR.fromArray(e));if(p.x*t.y-p.y*t.x>0){const e=p.clone().scale(u).rotate(this._slopeC,this._slopeS),t=f.clone().scale(u).rotate(this._slopeC,this._slopeS);h.lineTo([d.x+e.x,d.y+e.y]),h.lineTo([d.x,d.y]),h.lineTo([d.x+t.x,d.y+t.y])}else h.lineTo([d.x+_.x,d.y+_.y])}const r=Math.acos(y);let n=1;if(u>.25){const e=2*Math.acos(1-.25/u);e<r&&(n=Math.round(r/e))}const o=Math.cos(r/n),a=Math.sin(r/n),l=p.clone();if(s<0){l.rotate(this._slopeC,this._slopeS);const s=h.getXY(m-1);s||Lt().error(new i.A("mapview-bad-resource","Unable to process geometry, index out of scope"));const r=Ee.bR.add(d,l.clone().scale(this._lastWidth)),n=Ee.bR.sub(r,Ee.bR.fromArray(s)),o=p.x*n.y-p.y*n.x;if(!isNaN(this._lastTangent1.x)&&!isNaN(this._lastTangent1.y)&&o>0){const s=new Ee.bR(e,t),i=this._lastTangent1.clone().scale(this._lastWidth);i.rotate(this._slopeC,this._slopeS);const r=p.clone().scale(this._lastWidth);r.rotate(this._slopeC,this._slopeS),h.lineTo([s.x+i.x,s.y+i.y]),h.lineTo([s.x,s.y]),h.lineTo([s.x+r.x,s.y+r.y])}}else{l.scale(-1).rotateReverse(this._slopeC,this._slopeS);const s=c.getXY(g-1);s||Lt().error(new i.A("mapview-bad-resource","Unable to process geometry, index out of scope"));const r=Ee.bR.add(d,l.clone().scale(this._lastWidth)),n=Ee.bR.sub(r,Ee.bR.fromArray(s)),o=p.x*n.y-p.y*n.x;if(!isNaN(this._lastTangent1.x)&&!isNaN(this._lastTangent1.y)&&o>0){const s=new Ee.bR(e,t),i=this._lastTangent1.clone().scale(-this._lastWidth);i.rotateReverse(this._slopeC,this._slopeS);const r=p.clone().scale(-this._lastWidth);r.rotateReverse(this._slopeC,this._slopeS),c.lineTo([s.x+i.x,s.y+i.y]),c.lineTo([s.x,s.y]),c.lineTo([s.x+r.x,s.y+r.y])}}l.scale(u);for(let e=0;e<=n;e++)s<0?(h.lineTo([d.x+l.x,d.y+l.y]),l.rotateReverse(o,a)):(c.lineTo([d.x+l.x,d.y+l.y]),l.rotate(o,a))}return this._lastTangent1.setCoords(p.x,p.y),this._lastWidth=u,a}}class Gt{static{this.instance=null}static local(){return null===Gt.instance&&(Gt.instance=new Gt),Gt.instance}execute(e,t,s){return new qt(e,t,s)}}class qt{constructor(e,t,s){this._inputGeometries=e,this._height=(void 0!==t.amplitude?t.amplitude:2)*s,this._period=(void 0!==t.period?t.period:3)*s,this._style=t.waveform,this._height<=0&&(this._height=Math.abs(this._height)),this._period<=0&&(this._period=Math.abs(this._period)),this._pattern=new et,this._pattern.addValue(this._period),this._pattern.addValue(this._period),this._walker=new it,this._walker.updateTolerance(s)}next(){let e=this._inputGeometries.next();for(;e;){if(0===this._height||0===this._period)return e;const t=this._processGeom(e);if(t)return t;e=this._inputGeometries.next()}return null}_processGeom(e){const t=ye.z.createEmptyOptimizedCIM(e.geometryType);for(;e.nextPath();){t.startPath();const s=e.pathLength();if(this._walker.init(e,this._pattern))switch(this._style){case"Sinus":default:this._constructCurve(t,s,!1);break;case"Square":this._constructSquare(t,s);break;case"Triangle":this._constructTriangle(t,s);break;case"Random":this._constructCurve(t,s,!0)}else for(;e.nextPoint();)t.pushXY(e.x,e.y)}return t}_constructCurve(e,t,s){let i=Math.round(t/this._period);0===i&&(i=1);const r=16*i+1,n=t/i,o=this._period/16,a=1/r,h=2*Math.PI*t/n,c=2*Math.PI*Math.random(),l=2*Math.PI*Math.random(),u=2*Math.PI*Math.random(),d=.75-Math.random()/2,p=.75-Math.random()/2,f=new tt;this._walker.curPointAndAngle(f),e.pushPoint(f.pt);let _=0;for(;;){if(!this._walker.nextPointAndAngle(o,f)){e.pushPoint(this._walker.getPathEnd());break}{const t=_;let i;if(_+=a,s){const e=this._height/2*(1+.3*Math.sin(d*h*t+c));i=e*Math.sin(h*t+l),i+=e*Math.sin(p*h*t+u),i/=2}else i=.5*this._height*Math.sin(.5*h*t);e.pushXY(f.pt[0]-i*f.sa,f.pt[1]+i*f.ca)}}}_constructSquare(e,t){Math.round(t/this._period);let s=!0;for(;;){let t=!1;if(this._walker.curPositionIsValid()){const i=new tt;this._walker.curPointAndAngle(i);const r=new tt;if(this._walker.nextPointAndAngle(this._period,r)){const n=new tt;this._walker.nextPointAndAngle(this._period,n)&&(s?(e.pushPoint(i.pt),s=!1):e.pushPoint(i.pt),e.pushXY(i.pt[0]-this._height/2*i.sa,i.pt[1]+this._height/2*i.ca),e.pushXY(r.pt[0]-this._height/2*r.sa,r.pt[1]+this._height/2*r.ca),e.pushXY(r.pt[0]+this._height/2*r.sa,r.pt[1]-this._height/2*r.ca),e.pushXY(n.pt[0]+this._height/2*n.sa,n.pt[1]-this._height/2*n.ca),t=!0)}}if(!t){e.pushPoint(this._walker.getPathEnd());break}}}_constructTriangle(e,t){Math.round(t/this._period);let s=!0;for(;;){let t=!1;if(this._walker.curPositionIsValid()){const i=new tt;this._walker.curPointAndAngle(i);const r=new tt;if(this._walker.nextPointAndAngle(this._period/2,r)){const n=new tt;this._walker.nextPointAndAngle(this._period,n)&&(this._walker.nextPosition(this._period/2)&&(s?(e.pushPoint(i.pt),s=!1):e.pushPoint(i.pt),e.pushXY(r.pt[0]-this._height/2*r.sa,r.pt[1]+this._height/2*r.ca),e.pushXY(n.pt[0]+this._height/2*n.sa,n.pt[1]-this._height/2*n.ca)),t=!0)}}if(!t){e.pushPoint(this._walker.getPathEnd());break}}}}class Bt{static{this.instance=null}static local(){return null===Bt.instance&&(Bt.instance=new Bt),Bt.instance}execute(e,t,s){return new Wt(e,t,s)}}class Wt extends Me{constructor(e,t,s){super(e),this._geometryWalker=new it,this._geometryWalker.updateTolerance(s),this._angleToLine=t.angleToLine??!0,this._offset=(t.offset?t.offset:0)*s,this._originalEndings=t.endings,this._offsetAtEnd=(t.customEndingOffset?t.customEndingOffset:0)*s,this._position=-(t.offsetAlongLine?t.offsetAlongLine:0)*s,this._pattern=new et,this._pattern.init(t.placementTemplate,!1),this._pattern.scale(s),this._endings=this._originalEndings}processPath(e){if(this._pattern.isEmpty())return null;let t;if(this.iteratePath)t=this._pattern.nextValue();else{"WithFullGap"===this._originalEndings&&this.isClosed?this._endings="WithMarkers":this._endings=this._originalEndings,this._pattern.extPtGap=0;let s,i=!0;switch(this._endings){case"NoConstraint":s=-this._position,s=this._adjustPosition(s),i=!1;break;case"WithHalfGap":default:s=-this._pattern.lastValue()/2;break;case"WithFullGap":s=-this._pattern.lastValue(),this._pattern.extPtGap=this._pattern.lastValue();break;case"WithMarkers":s=0;break;case"Custom":s=-this._position,s=this._adjustPosition(s),this._pattern.extPtGap=.5*this._offsetAtEnd}if(!this._geometryWalker.init(e,this._pattern,i))return null;this._pattern.reset();let r=0;for(;s>r;)s-=r,r=this._pattern.nextValue();r-=s,t=r,this.iteratePath=!0}const s=new tt;return this._geometryWalker.nextPointAndAngle(t,s)?"WithFullGap"===this._endings&&this._geometryWalker.isPathEnd()?(this.iteratePath=!1,null):"WithMarkers"===this._endings&&this._geometryWalker.isPathEnd()&&(this.iteratePath=!1,this.isClosed)?null:(this.internalPlacement.setTranslate(s.pt[0]-this._offset*s.sa,s.pt[1]+this._offset*s.ca),this._angleToLine&&this.internalPlacement.setRotateCS(s.ca,s.sa),this.internalPlacement):(this.iteratePath=!1,null)}_adjustPosition(e){let t=e/this._pattern.length();return t-=Math.floor(t),t*this._pattern.length()}}class jt{static{this.instance=null}static local(){return null===jt.instance&&(jt.instance=new jt),jt.instance}execute(e,t,s){return new Ut(e,t,s)}}class Ut extends Me{constructor(e,t,s){super(e,!1,!0),this._curveHelper=new Ae,this._placePerPart=t.placePerPart??!1,this._angleToLine=void 0===t.angleToLine||t.angleToLine,this._offset=void 0!==t.offset?t.offset*s:0,this._type=t.extremityPlacement,this._position=void 0!==t.offsetAlongLine?t.offsetAlongLine*s:0,this._beginProcessed=!1}processMultiPath(e){return this._placePerPart?super.processMultiPath(e):this.processPath(e)}processPath(e){let t;switch(this._type){case"Both":default:this._beginProcessed?(t=this._atExtremities(e,this._position,!1),this._beginProcessed=!1,this.iterateMultiPath=!1,this.iteratePath=!1):(t=this._atExtremities(e,this._position,!0),this._beginProcessed=!0,this.iterateMultiPath=!0,this.iteratePath=!0);break;case"JustBegin":t=this._atExtremities(e,this._position,!0);break;case"JustEnd":t=this._atExtremities(e,this._position,!1);case"None":}return t}_atExtremities(e,t,s){if(this._placePerPart||(s?e.seekPath(0):e.seekPath(e.totalSize-1)),s||e.seekPathEnd(),s?e.nextPoint():e.prevPoint()){let i=0,[r,n]=[0,0],[o,a]=[e.x,e.y];const h=[0,0];for(;s?e.nextPoint():e.prevPoint();){r=o,n=a,o=e.x,a=e.y;const s=this._curveHelper.getLength(r,n,o,a);if(i+s>t){const e=(t-i)/s,[c,l]=this._curveHelper.getAngleCS(h,r,n,o,a,e),u=this._curveHelper.getCoord2D(r,n,o,a,e);return this.internalPlacement.setTranslate(u[0]-this._offset*l,u[1]+this._offset*c),this._angleToLine&&this.internalPlacement.setRotateCS(-c,-l),this.internalPlacement}i+=s}}return null}}const Vt=.001;class Yt{static{this.instance=null}static local(){return null===Yt.instance&&(Yt.instance=new Yt),Yt.instance}execute(e,t,s){return new Ht(e,t,s)}}class Ht extends Me{constructor(e,t,s){super(e),this._segmentIterator=null,this._segCount=0,this._firstSeg=!0,this._seg=null,this._ms=[],this._from=0,this._to=0,this._pt=null,this._walker=new it,this._walker.updateTolerance(s),this._placePerPart=t.placePerPart??!1,this._angleToLine=t.angleToLine??!1,this._offset=(t.offset??0)*s,this._interval=(t.interval??0)*s,this._interval<=0&&(this._interval=.01),this._skipRate=t.skipMarkerRate??0,this._skipRate<=1&&(this._skipRate=0),this._placeAtExtremities=t.placeAtExtremities??!1}processPath(e){if(!this.iteratePath){const{fromGeometry:t}=We.module,s=t(e.getCurrentPath().asJSON()).getGeometry(),i=s.getPathStart(0);this._segmentIterator=s.querySegmentIteratorAtVertex(i),this._segCount=s.getSegmentCountPath(0),this._firstSeg=!0,this.iteratePath=!0,this._pt=s.getXY(0).clone()}for(;0===this._ms.length&&this._segmentIterator?.hasNextSegment();){--this._segCount,this._seg=this._segmentIterator.nextSegment(),this._from=this._seg.getStartAttributeAsDbl(2,0),this._to=this._seg.getEndAttributeAsDbl(2,0);const t=!isNaN(this._from),s=!isNaN(this._to);t&&(this._from=Math.round(this._from/Vt)*Vt,Math.abs(this._from)<Vt&&(this._from=0)),s&&(this._to=Math.round(this._to/Vt)*Vt,Math.abs(this._to)<Vt&&(this._to=0));let i=t?Math.floor(this._from/this._interval):0,r=s?Math.floor(this._to/this._interval):0;if(t&&(this._placeAtExtremities||!this._firstSeg||!this._placePerPart&&e.pathIndex>0)&&Math.abs(i*this._interval-this._from)<Vt&&(!this._skipRate||i%this._skipRate)&&this._ms.push(this._from),this._firstSeg=!1,t&&s&&!(Math.abs(this._from-this._to)<Vt))if(this._from<=this._to){i*this._interval<this._from+Vt&&++i,r*this._interval>this._to-Vt&&--r;for(let e=i;e<=r;++e)(!this._skipRate||e%this._skipRate)&&this._ms.push(e*this._interval)}else{i*this._interval>this._from-Vt&&--i,r*this._interval<this._to+Vt&&++r;for(let e=r;e<=i;++e)(!this._skipRate||e%this._skipRate)&&this._ms.push(e*this._interval)}}let t=0;if(0===this._ms.length){if(this.iteratePath=!1,!this._segCount&&this._placeAtExtremities&&!isNaN(this._to)&&(this._placePerPart||e.pathIndex===e.totalSize-1)){const e=Math.floor(this._to/this._interval);Math.abs(e*this._interval-this._to)<Vt&&(!this._skipRate||e%this._skipRate)&&(this._ms.push(this._to),t=1)}if(0===this._ms.length)return null}const s=this._ms.pop(),i=isNaN(this._from)||isNaN(this._to)||Math.abs(this._from-this._to)<Vt?t:(s-this._from)/(this._to-this._from);this._seg.queryCoord2D(i,this._pt);const r=this._seg.getTangent(i),{x:n,y:o}=r.normalize();return this.internalPlacement.setTranslate(this._pt.x-this._offset*o,this._pt.y+this._offset*n),this._angleToLine&&this.internalPlacement.setRotateCS(n,o),this.internalPlacement.setMeasure(s),this.internalPlacement}}class Xt{static{this.instance=null}static local(){return null===Xt.instance&&(Xt.instance=new Xt),Xt.instance}execute(e,t,s){return new $t(e,t,s)}}class $t extends Me{constructor(e,t,s){super(e),this._walker=new it,this._walker.updateTolerance(s),this._angleToLine=void 0===t.angleToLine||t.angleToLine,this._offset=void 0!==t.offset?t.offset*s:0,this._beginGap=void 0!==t.beginPosition?t.beginPosition*s:0,this._endGap=void 0!==t.endPosition?t.endPosition*s:0,this._flipFirst=void 0===t.flipFirst||t.flipFirst,this._pattern=new et,this._pattern.init(t.positionArray,!1,!1),this._subPathLen=0,this._posCount=this._pattern.size(),this._isFirst=!0,this._prevPos=0}processPath(e){if(this._pattern.isEmpty())return null;let t;if(this.iteratePath){const e=this._pattern.nextValue()*this._subPathLen,s=this._beginGap+e;t=s-this._prevPos,this._prevPos=s}else{if(this._posCount=this._pattern.size(),this._isFirst=!0,this._prevPos=0,this._subPathLen=e.pathLength()-this._beginGap-this._endGap,this._subPathLen<0)return this.iteratePath=!1,null;if(!this._walker.init(e,this._pattern,!1))return null;this._pattern.reset();const s=this._pattern.nextValue()*this._subPathLen,i=this._beginGap+s;t=i-this._prevPos,this._prevPos=i,this.iteratePath=!0}const s=new tt;if(!this._walker.nextPointAndAngle(t,s,1))return this.iteratePath=!1,null;this.internalPlacement.setTranslate(s.pt[0]-this._offset*s.sa,s.pt[1]+this._offset*s.ca);const i=this._isFirst&&this._flipFirst;let r,n;return this._angleToLine?(r=s.ca,n=s.sa):(r=1,n=0),i&&(r=-r,n=-n),this.internalPlacement.setRotateCS(r,n),this._isFirst=!1,this._posCount--,0===this._posCount&&(this.iteratePath=!1),this.internalPlacement}}const Zt=512,Qt=24,Jt=1e-6;class Kt{static{this.instance=null}static local(){return null===Kt.instance&&(Kt.instance=new Kt),Kt.instance}execute(e,t,s,i){return new es(e,t,s,i)}}class es{constructor(e,t,s,i){if(this._xMin=0,this._xMax=0,this._yMin=0,this._yMax=0,this._currentX=0,this._currentY=0,this._accelerationMap=null,this._testInsidePolygon=!1,this._verticalSubdivision=!0,this._stepX=Math.abs(t.stepX??16)*s,this._stepY=Math.abs(t.stepY??16)*s,this._stepX=Math.round(128*this._stepX)/128,this._stepY=Math.round(128*this._stepY)/128,0!==this._stepX&&0!==this._stepY){if(this._gridType=t.gridType??"Fixed","Random"===this._gridType){const e=t.seed??13,s=1;this._randomLCG=new h.A(e*s),this._randomness=(t.randomness??100)/100,this._gridAngle=0,this._shiftOddRows=!1,this._cosAngle=1,this._sinAngle=0,this._offsetX=0,this._offsetY=0,this._buildRandomValues()}else{if(this._randomness=0,this._gridAngle=t.gridAngle??0,this._shiftOddRows=t.shiftOddRows??!1,this._offsetX=(t.offsetX??0)*s,this._offsetY=(t.offsetY??0)*s,this._cosAngle=Math.cos(this._gridAngle/180*Math.PI),this._sinAngle=-Math.sin(this._gridAngle/180*Math.PI),this._stepX)if(this._offsetX<0)for(;this._offsetX<-.5*this._stepX;)this._offsetX+=this._stepX;else for(;this._offsetX>=.5*this._stepX;)this._offsetX-=this._stepX;if(this._stepY)if(this._offsetY<0)for(;this._offsetY<-.5*this._stepY;)this._offsetY+=this._stepY;else for(;this._offsetY>=.5*this._stepY;)this._offsetY-=this._stepY}if(this._graphicOriginX=0,this._graphicOriginY=0,null!=i){const[e,t,s,r]=i.split("/"),n=parseFloat(e),o=parseFloat(t),a=parseFloat(s),h=parseFloat(r);this._graphicOriginX=-(h*2**n+a)*Zt,this._graphicOriginY=o*Zt,this._testInsidePolygon=!0}this._internalPlacement=new Ie,this._calculateMinMax(e),this._geometryCursor=e}}next(){return this._geometryCursor?this._nextInside():null}_buildRandomValues(){if(!es._randValues){es._randValues=[];for(let e=0;e<Qt;e++)for(let e=0;e<Qt;e++)es._randValues.push(this._randomLCG.getFloat()),es._randValues.push(this._randomLCG.getFloat())}}_calculateMinMax(e){let t,s,i,r,n,o,a,h,c,l,u,d,p,f;this._xMin=0,this._xMax=0,this._yMin=0,this._yMax=0,a=h=p=u=Number.MAX_VALUE,c=l=f=d=-Number.MAX_VALUE;const _=1!==this._cosAngle;for(e.reset();e.nextPath();)for(;e.nextPoint();)o=e.x,n=e.y,t=o-this._graphicOriginX-this._offsetX,s=n-this._graphicOriginY-this._offsetY,_?(i=this._cosAngle*t-this._sinAngle*s,r=this._sinAngle*t+this._cosAngle*s):(i=t,r=s),a=Math.min(a,i),c=Math.max(c,i),h=Math.min(h,r),l=Math.max(l,r),u=Math.min(u,n),d=Math.max(d,n),p=Math.min(p,o),f=Math.max(f,o);u=u!==Number.MAX_VALUE?u:-512-this._stepY,d=d!==-Number.MAX_VALUE?d:this._stepY,p=p!==Number.MAX_VALUE?p:-this._stepX,f=f!==-Number.MAX_VALUE?f:Zt+this._stepX;const m=d-u,g=f-p;if(this._verticalSubdivision=m>=g,this._polygonMin=this._verticalSubdivision?u:p,this._testInsidePolygon){let e=0-this._graphicOriginX-this._offsetX-this._stepX,t=Zt-this._graphicOriginX-this._offsetX+this._stepX,s=-512-this._graphicOriginY-this._offsetY-this._stepY,i=0-this._graphicOriginY-this._offsetY+this._stepY;if(_){const r=[[e,s],[e,i],[t,s],[t,i]];e=s=Number.MAX_VALUE,t=i=-Number.MAX_VALUE;for(const n of r){const r=this._cosAngle*n[0]-this._sinAngle*n[1],o=this._sinAngle*n[0]+this._cosAngle*n[1];e=Math.min(e,r),t=Math.max(t,r),s=Math.min(s,o),i=Math.max(i,o)}}a=a!==Number.MAX_VALUE?Math.max(a,e):e,h=h!==Number.MAX_VALUE?Math.max(h,s):s,c=c!==-Number.MAX_VALUE?Math.min(c,t):t,l=l!==-Number.MAX_VALUE?Math.min(l,i):i}this._xMin=Math.round(a/this._stepX),this._xMax=Math.round(c/this._stepX),this._yMin=Math.round(h/this._stepY),this._yMax=Math.round(l/this._stepY),this._currentX=this._xMax+1,this._currentY=this._yMin-1,this._buildAccelerationMap(e,p,f,u,d)}_buildAccelerationMap(e,t,s,i,r){e.reset();const n=new Map,o=this._verticalSubdivision,a=o?r-i:s-t;let h=Math.ceil(a/10);if(h<=1)return;const c=Math.floor(a/h);let l,u,d,p,f,_,m,g,y,x,b;for(h++,this._delta=c,o?(y=-512-2*this._stepY,x=2*this._stepY,b=i):(y=-2*this._stepX,x=Zt+2*this._stepX,b=t);e.nextPath();)if(!(e.pathSize<2)&&e.nextPoint())for(l=e.x,u=e.y;e.nextPoint();l=d,u=p){if(d=e.x,p=e.y,o){if(u===p||u<y&&p<y||u>x&&p>x)continue;f=Math.min(u,p),_=Math.max(u,p)}else{if(l===d||l<y&&d<y||l>x&&d>x)continue;f=Math.min(l,d),_=Math.max(l,d)}for(;f<_;)m=Math.floor((f-b)/c),ts(m,l,u,d,p,n),f+=c;g=Math.floor((_-b)/c),g>m&&ts(g,l,u,d,p,n)}this._accelerationMap=n}_nextInside(){for(;;){if(this._currentX>this._xMax){if(this._currentY++,this._currentY>this._yMax)return null;this._currentX=this._xMin,this._shiftOddRows&&this._currentY%2&&this._currentX--}let e=this._currentX*this._stepX+this._offsetX;this._shiftOddRows&&this._currentY%2&&(e+=.5*this._stepX);const t=this._currentY*this._stepY+this._offsetY;let s,i;if(this._currentX++,"Random"===this._gridType){const r=(this._currentX%Qt+Qt)%Qt,n=(this._currentY%Qt+Qt)%Qt;s=this._graphicOriginX+e+this._stepX*this._randomness*(.5-es._randValues[n*Qt+r])*2/3,i=this._graphicOriginY+t+this._stepY*this._randomness*(.5-es._randValues[n*Qt+r+1])*2/3}else s=this._graphicOriginX+this._cosAngle*e+this._sinAngle*t,i=this._graphicOriginY-this._sinAngle*e+this._cosAngle*t;if(!this._testInsidePolygon||this._isInsidePolygon(s,i,this._geometryCursor))return this._internalPlacement.setTranslate(s,i),this._internalPlacement}}_isInsidePolygon(e,t,s){if(null==this._accelerationMap)return function(e,t,s){let i,r,n,o,a=0;for(e+=Jt,t+=Jt,s.reset();s.nextPath();)if(s.nextPoint())for(i=s.x,r=s.y;s.nextPoint();i=n,r=o)n=s.x,o=s.y,r>t!=o>t&&((n-i)*(t-r)-(o-r)*(e-i)>0?a++:a--);return 0!==a}(e,t,s);e+=Jt,t+=Jt;const i=this._verticalSubdivision,r=i?t:e,n=Math.floor((r-this._polygonMin)/this._delta),o=this._accelerationMap.get(n);if(!o)return!1;let a,h,c,l=0;for(const s of o){if(a=s[0],h=s[1],i){if(a[1]>t==h[1]>t)continue;c=(h[0]-a[0])*(t-a[1])-(h[1]-a[1])*(e-a[0])}else{if(a[0]>e==h[0]>e)continue;c=(h[1]-a[1])*(e-a[0])-(h[0]-a[0])*(t-a[1])}c>0?l++:l--}return 0!==l}}function ts(e,t,s,i,r,n){let o=n.get(e);o||(o=[],n.set(e,o)),o.push([[t,s],[i,r]])}class ss{static{this.instance=null}static local(){return null===ss.instance&&(ss.instance=new ss),ss.instance}execute(e,t,s){return new is(e,t,s)}}class is extends Me{constructor(e,t,s){super(e),this._curveHelper=new Ae,this._angleToLine=void 0===t.angleToLine||t.angleToLine,this._offset=void 0!==t.offset?t.offset*s:0,this._relativeTo=t.relativeTo,this._position=void 0!==t.startPointOffset?t.startPointOffset*s:0,this._epsilon=.001*s}processPath(e){const t=this._position;if("SegmentMidpoint"===this._relativeTo){if(this.iteratePath||(this.iteratePath=!0),e.nextPoint()){let[t,s]=[e.x,e.y],[i,r]=[0,0];const n=[0,0];for(;e.nextPoint();){i=e.x,r=e.y;const o=this._curveHelper.getLength(t,s,i,r);if(o<this._epsilon){t=i,s=r;continue}const a=.5+this._position/o,[h,c]=this._curveHelper.getAngleCS(n,t,s,i,r,a),l=this._curveHelper.getCoord2D(t,s,i,r,a);return this.internalPlacement.setTranslate(l[0]-this._offset*c,l[1]+this._offset*h),this._angleToLine&&this.internalPlacement.setRotateCS(h,c),this.internalPlacement}}return this.iteratePath=!1,null}const s="LineEnd"===this._relativeTo;return this.onLine(e,t,s)}onLine(e,t,s){let i,r=!1;switch(this._relativeTo){case"LineMiddle":default:e.seekPathStart(),i=e.pathLength()/2+t;break;case"LineBeginning":i=t;break;case"LineEnd":i=t,r=!0}s?e.seekPathEnd():e.seekPathStart();let n=0;if(s?e.prevPoint():e.nextPoint()){let[t,o]=[e.x,e.y],[a,h]=[0,0];const c=[0,0];for(;s?e.prevPoint():e.nextPoint();){a=e.x,h=e.y;const s=this._curveHelper.getLength(t,o,a,h);if(n+s>i){const e=(i-n)/s,[l,u]=this._curveHelper.getAngleCS(c,t,o,a,h,e),d=this._curveHelper.getCoord2D(t,o,a,h,e),p=r?-this._offset:this._offset;return this.internalPlacement.setTranslate(d[0]-p*u,d[1]+p*l),this._angleToLine&&(r?this.internalPlacement.setRotateCS(-l,-u):this.internalPlacement.setRotateCS(l,u)),this.internalPlacement}t=a,o=h,n+=s}}return null}}class rs{static{this.instance=null}static local(){return null===rs.instance&&(rs.instance=new rs),rs.instance}execute(e,t,s){return new ns(e,t,s)}}class ns extends Me{constructor(e,t,s){super(e),this._curveHelper=new Ae,this._angleToLine=void 0===t.angleToLine||t.angleToLine,this._offset=void 0!==t.offset?t.offset*s:0,this._endPoints=void 0===t.placeOnEndPoints||t.placeOnEndPoints,this._controlPoints=void 0===t.placeOnControlPoints||t.placeOnControlPoints,this._regularVertices=void 0===t.placeOnRegularVertices||t.placeOnRegularVertices,this._tags=[],this._tagIterator=0}processPath(e){if(this.iteratePath||(this._preparePath(e),this.iteratePath=!0),this._tagIterator>=this._tags.length)return this._tags.length=0,this._tagIterator=0,this.iteratePath=!1,null;const t=this._tags[this._tagIterator];this._angleToLine&&this.internalPlacement.setRotate(t[2]);let s=t[0],i=t[1];if(0!==this._offset){const e=Math.cos(t[2]),r=Math.sin(t[2]);s-=this._offset*r,i+=this._offset*e}return this.internalPlacement.setTranslate(s,i),this._tagIterator++,this.internalPlacement}_preparePath(e){this._tags.length=0,this._tagIterator=0,e.seekPathStart();const t=e.isClosed();let s=0,i=!1,r=0,n=0;if(e.seekPathStart(),e.nextPoint()){let o=e.x,a=e.y,h=e.getControlPoint(),c=!0,l=e.nextPoint();for(;l;){const u=e.x,d=e.y,p=e.getControlPoint();(this._angleToLine||0!==this._offset)&&(r=this._curveHelper.getAngle(o,a,u,d,0)),c?(c=!1,t?(s=r,i=h):(this._endPoints||this._controlPoints&&h)&&this._tags.push([o,a,r])):h?this._controlPoints&&this._tags.push([o,a,os(n,r)]):this._regularVertices&&this._tags.push([o,a,os(n,r)]),(this._angleToLine||0!==this._offset)&&(n=this._curveHelper.getAngle(o,a,u,d,1)),l=e.nextPoint(),l||(t?p||i?this._controlPoints&&this._tags.push([u,d,os(n,s)]):this._regularVertices&&this._tags.push([u,d,os(n,s)]):(this._endPoints||this._controlPoints&&p)&&this._tags.push([u,d,n])),o=u,a=d,h=p}}this._tagIterator=0}}function os(e,t){const s=Math.PI;for(;Math.abs(t-e)>s+2e-15;)t-e>s?t-=2*s:t+=2*s;return(e+t)/2}var as=s(32011);class hs{static{this.instance=null}static local(){return null===hs.instance&&(hs.instance=new hs),hs.instance}execute(e,t,s){return new cs(e,t,s)}}class cs{constructor(e,t,s){this._geometryCursor=e,this._offsetX=void 0!==t.offsetX?t.offsetX*s:0,this._offsetY=void 0!==t.offsetY?t.offsetY*s:0,this._method=void 0!==t.method?t.method:"OnPolygon",this._placementPerPart=void 0!==t.placePerPart&&t.placePerPart,this._internalPlacement=new Ie}next(){const e=this._geometryCursor;if(!e)return null;if(!this._placementPerPart)return this._geometryCursor=null,this._polygonCenter(e);for(;e.nextPath();)if(!(e.getCurrentRingArea()<0))return this._polygonCenter(e.getCurrentPath());return this._geometryCursor=null,null}_polygonCenter(e){let t=!1;switch(this._method){case"CenterOfMass":{const s=(0,vt.TP)(e);s&&(this._internalPlacement.setTranslate(s[0]+this._offsetX,s[1]+this._offsetY),t=!0)}break;case"BoundingBoxCenter":{const s=(0,ht.z8)(e);s&&(this._internalPlacement.setTranslate((s[2]+s[0])/2+this._offsetX,(s[3]+s[1])/2+this._offsetY),t=!0)}break;default:{const s=(0,as.d)(e);null!==s&&(this._internalPlacement.setTranslate(s[0]+this._offsetX,s[1]+this._offsetY),t=!0)}}return t?this._internalPlacement:null}}function ls(e){if(!e)return null;switch(e.type){case"CIMGeometricEffectAddControlPoints":return we.local();case"CIMGeometricEffectArrow":return Te.local();case"CIMGeometricEffectBuffer":return He.local();case"CIMGeometricEffectControlMeasureLine":return Ze.local();case"CIMGeometricEffectCut":return Je.local();case"CIMGeometricEffectDashes":return rt.local();case"CIMGeometricEffectDonut":return ot.local();case"CIMGeometricEffectJog":return ft.local();case"CIMGeometricEffectMove":return mt.local();case"CIMGeometricEffectOffset":return xt.local();case"CIMGeometricEffectRadial":return St.local();case"CIMGeometricEffectReverse":return Pt.local();case"CIMGeometricEffectRotate":return Ct.local();case"CIMGeometricEffectScale":return Tt.local();case"CIMGeometricEffectSuppress":return Et.local();case"CIMGeometricEffectTaperedPolygon":return Dt.local();case"CIMGeometricEffectWave":return Gt.local();case"CIMGeometricEffectEnclosingPolygon":return ct.local()}return null}class us{static getPlacement(e,t,s,i,r){const n=function(e){if(!e)return null;switch(e.type){case"CIMMarkerPlacementAlongLineSameSize":return Bt.local();case"CIMMarkerPlacementAtExtremities":return jt.local();case"CIMMarkerPlacementAtMeasuredUnits":return Yt.local();case"CIMMarkerPlacementAtRatioPositions":return Xt.local();case"CIMMarkerPlacementInsidePolygon":return Kt.local();case"CIMMarkerPlacementOnLine":return ss.local();case"CIMMarkerPlacementOnVertices":return rs.local();case"CIMMarkerPlacementPolygonCenter":return hs.local()}return null}(s);return n?(-1===t&&e.invertY(),n.execute(e,s,i,r)):null}}var ds=s(68197);function ps(e,t){return[!!e?.minScale&&t.scaleToZoom(e.minScale)||0,!!e?.maxScale&&t.scaleToZoom(e.maxScale)||100]}function fs(e){return 1<<e}function _s(e){let t=0;for(const[s,i]of e)i&&(t|=1<<s);return t}function ms(e){let t;if(!e)return[0,0,0,0];if("string"==typeof e){const s=ds.A.fromString(e);if(!s)return Rt.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 gs(e){switch(e){case"butt":case"Butt":return 0;case"round":case"Round":return 1;case"square":case"Square":return 2}}function ys(e){switch(e){case"bevel":case"Bevel":return 0;case"miter":case"Miter":return 2;case"round":case"Round":return 1}}function xs(e,t){return Math.round(Math.min(Math.sqrt(e*t),255))}function bs(e,t){return Math.round(e*t)/t}const ws=0,vs=1,Ss=2,Is=3,Ps=4,Ms=5;new(s(32488).A);var ks=s(4718);s(11831),s(92602),new Map,new Set;var Cs=s(34727);function As(e,t=0){let s=0;for(let i=0;i<4;i++)s+=e[t+i]*Ts[i];return s}const Ts=[1/256,1/65536,1/16777216,1/4294967296];As(new Uint8ClampedArray([255,255,255,255])),As(new Uint8ClampedArray([255,255,255,0])),s(5760);var Fs=s(34304);function zs(e){return e[0]=1,e[1]=0,e[2]=0,e[3]=1,e[4]=0,e[5]=0,e}function Es(e,t,s){const i=t[0],r=t[1],n=t[2],o=t[3],a=t[4],h=t[5],c=s[0],l=s[1],u=s[2],d=s[3],p=s[4],f=s[5];return e[0]=i*c+n*l,e[1]=r*c+o*l,e[2]=i*u+n*d,e[3]=r*u+o*d,e[4]=i*p+n*f+a,e[5]=r*p+o*f+h,e}function Os(e,t,s){const i=t[0],r=t[1],n=t[2],o=t[3],a=t[4],h=t[5],c=Math.sin(s),l=Math.cos(s);return e[0]=i*l+n*c,e[1]=r*l+o*c,e[2]=i*-c+n*l,e[3]=r*-c+o*l,e[4]=a,e[5]=h,e}function Rs(e,t,s){const i=t[0],r=t[1],n=t[2],o=t[3],a=t[4],h=t[5],c=s[0],l=s[1];return e[0]=i,e[1]=r,e[2]=n,e[3]=o,e[4]=i*c+n*l+a,e[5]=r*c+o*l+h,e}function Ls(e,t){const s=Math.sin(t),i=Math.cos(t);return e[0]=i,e[1]=s,e[2]=-s,e[3]=i,e[4]=0,e[5]=0,e}function Ds(e,t,s){return e[0]=t[0]-s[0],e[1]=t[1]-s[1],e[2]=t[2]-s[2],e[3]=t[3]-s[3],e[4]=t[4]-s[4],e[5]=t[5]-s[5],e}const Ns=Es,Gs=Ds;function qs(){const e=new Float32Array(6);return e[0]=1,e[3]=1,e}function Bs(e,t,s,i){const r=t[i],n=t[i+1];e[i]=s[0]*r+s[2]*n+s[4],e[i+1]=s[1]*r+s[3]*n+s[5]}function Ws(e,t,s,i=0,r=0,n=2){const o=r||t.length/n;for(let r=i;r<o;r++)Bs(e,t,s,r*n)}Object.freeze(Object.defineProperty({__proto__:null,add:function(e,t,s){return e[0]=t[0]+s[0],e[1]=t[1]+s[1],e[2]=t[2]+s[2],e[3]=t[3]+s[3],e[4]=t[4]+s[4],e[5]=t[5]+s[5],e},copy:function(e,t){return e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=t[3],e[4]=t[4],e[5]=t[5],e},determinant:function(e){return e[0]*e[3]-e[1]*e[2]},equals:function(e,t){const s=e[0],i=e[1],r=e[2],n=e[3],o=e[4],a=e[5],h=t[0],c=t[1],l=t[2],u=t[3],d=t[4],p=t[5],f=(0,Fs.FD)();return Math.abs(s-h)<=f*Math.max(1,Math.abs(s),Math.abs(h))&&Math.abs(i-c)<=f*Math.max(1,Math.abs(i),Math.abs(c))&&Math.abs(r-l)<=f*Math.max(1,Math.abs(r),Math.abs(l))&&Math.abs(n-u)<=f*Math.max(1,Math.abs(n),Math.abs(u))&&Math.abs(o-d)<=f*Math.max(1,Math.abs(o),Math.abs(d))&&Math.abs(a-p)<=f*Math.max(1,Math.abs(a),Math.abs(p))},exactEquals:function(e,t){return e[0]===t[0]&&e[1]===t[1]&&e[2]===t[2]&&e[3]===t[3]&&e[4]===t[4]&&e[5]===t[5]},frob:function(e){return Math.sqrt(e[0]**2+e[1]**2+e[2]**2+e[3]**2+e[4]**2+e[5]**2+1)},fromRotation:Ls,fromScaling:function(e,t){return e[0]=t[0],e[1]=0,e[2]=0,e[3]=t[1],e[4]=0,e[5]=0,e},fromTranslation:function(e,t){return e[0]=1,e[1]=0,e[2]=0,e[3]=1,e[4]=t[0],e[5]=t[1],e},identity:zs,invert:function(e,t){const s=t[0],i=t[1],r=t[2],n=t[3],o=t[4],a=t[5];let h=s*n-i*r;return h?(h=1/h,e[0]=n*h,e[1]=-i*h,e[2]=-r*h,e[3]=s*h,e[4]=(r*a-n*o)*h,e[5]=(i*o-s*a)*h,e):null},mul:Ns,multiply:Es,multiplyScalar:function(e,t,s){return e[0]=t[0]*s,e[1]=t[1]*s,e[2]=t[2]*s,e[3]=t[3]*s,e[4]=t[4]*s,e[5]=t[5]*s,e},multiplyScalarAndAdd:function(e,t,s,i){return e[0]=t[0]+s[0]*i,e[1]=t[1]+s[1]*i,e[2]=t[2]+s[2]*i,e[3]=t[3]+s[3]*i,e[4]=t[4]+s[4]*i,e[5]=t[5]+s[5]*i,e},rotate:Os,scale:function(e,t,s){const i=t[0],r=t[1],n=t[2],o=t[3],a=t[4],h=t[5],c=s[0],l=s[1];return e[0]=i*c,e[1]=r*c,e[2]=n*l,e[3]=o*l,e[4]=a,e[5]=h,e},set:function(e,t,s,i,r,n,o){return e[0]=t,e[1]=s,e[2]=i,e[3]=r,e[4]=n,e[5]=o,e},str:function(e){return"mat2d("+e[0]+", "+e[1]+", "+e[2]+", "+e[3]+", "+e[4]+", "+e[5]+")"},sub:Gs,subtract:Ds,translate:Rs},Symbol.toStringTag,{value:"Module"})),Object.freeze(Object.defineProperty({__proto__:null,clone:function(e){const t=new Float32Array(6);return t[0]=e[0],t[1]=e[1],t[2]=e[2],t[3]=e[3],t[4]=e[4],t[5]=e[5],t},create:qs,fromValues:function(e,t,s,i,r,n){const o=new Float32Array(6);return o[0]=e,o[1]=t,o[2]=s,o[3]=i,o[4]=r,o[5]=n,o},transform:Bs,transformMany:Ws},Symbol.toStringTag,{value:"Module"}));var js=s(88340);var Us=s(18989);class Vs{constructor(e,t,s,i){this.transformedX=0,this.transformedY=0,this.center=(0,js.fA)(e,t),this.centerT=(0,js.vt)(),this.halfWidth=s/2,this.halfHeight=i/2,this.width=s,this.height=i}get x(){return this.center[0]}get y(){return this.center[1]}get blX(){return this.center[0]+this.halfWidth}get blY(){return this.center[1]+this.halfHeight}get trX(){return this.center[0]-this.halfWidth}get trY(){return this.center[1]-this.halfHeight}get xmin(){return this.x-this.halfWidth}get xmax(){return this.x+this.halfWidth}get ymin(){return this.y-this.halfHeight}get ymax(){return this.y+this.halfHeight}set x(e){this.center[0]=e}set y(e){this.center[1]=e}clone(){return new Vs(this.x,this.y,this.width,this.height)}serialize(e){return e.writeF32(this.center[0]),e.writeF32(this.center[1]),e.push(this.width),e.push(this.height),e}findCollisionDelta(e,t=4){const s=Math.abs(e.centerT[0]-this.centerT[0]),i=Math.abs(e.centerT[1]-this.centerT[1]),r=(e.halfWidth+this.halfWidth+t)/s,n=(e.halfHeight+this.halfHeight+t)/i,o=Math.min(r,n);return Math.log2(o)}extend(e){const t=Math.min(this.xmin,e.xmin),s=Math.min(this.ymin,e.ymin),i=Math.max(this.xmax,e.xmax)-t,r=Math.max(this.ymax,e.ymax)-s,n=t+i/2,o=s+r/2;this.width=i,this.height=r,this.halfWidth=i/2,this.halfHeight=r/2,this.x=n,this.y=o}static deserialize(e){const t=e.readF32(),s=e.readF32(),i=e.readInt32(),r=e.readInt32();return new Vs(t,s,i,r)}}const Ys=Math.PI/180;class Hs{constructor(e,t,s,i){this._rotationT=qs(),this._xBounds=0,this._yBounds=0,this.minZoom=0,this.maxZoom=255,this._bounds=null;const r=s.rect,n=new Float32Array(8);e*=i,t*=i;const o=0===s.code?s.metrics.width:r.width*i,a=0===s.code?s.metrics.height:r.height*i;this.width=o,this.height=a,n[0]=e,n[1]=t,n[2]=e+o,n[3]=t,n[4]=e,n[5]=t+a,n[6]=e+o,n[7]=t+a,this._data=n,this._setTextureCoords(r),this._scale=i,this._mosaic=s,this.x=e,this.y=t,this.maxOffset=Math.max(e+o,t+a)}get mosaic(){return this._mosaic}set angle(e){this._angle=e,Ls(this._rotationT,-e),this._setOffsets()}get angle(){return this._angle}get xTopLeft(){return this._data[0]}get yTopLeft(){return this._data[1]}get xBottomRight(){return this._data[6]}get yBottomRight(){return this._data[7]}get texcoords(){return this._texcoords}get textureBinding(){return this._mosaic.textureBinding}get offsets(){return this._offsets||this._setOffsets(),this._offsets}get bounds(){if(!this._bounds){const{height:e,width:t}=this._mosaic.metrics,s=t*this._scale,i=Math.abs(e)*this._scale,r=new Float32Array(8);r[0]=this.x,r[1]=this.y,r[2]=this.x+s,r[3]=this.y,r[4]=this.x,r[5]=this.y+i,r[6]=this.x+s,r[7]=this.y+i,Ws(r,r,Es(qs(),this._rotationT,this._transform));let n=1/0,o=1/0,a=-1/0,h=-1/0;for(let e=0;e<4;e++){const t=r[2*e],s=r[2*e+1];n=Math.min(n,t),o=Math.min(o,s),a=Math.max(a,t),h=Math.max(h,s)}const c=a-n,l=h-o,u=n+c/2,d=o+l/2;this._bounds=new Vs(u,d,c,l)}return this._bounds}setTransform(e){this._transform=e,this._offsets=null}_setOffsets(){this._offsets||(this._offsets={topLeft:[0,0],topRight:[0,0],bottomLeft:[0,0],bottomRight:[0,0]});const e=Es(qs(),this._rotationT,this._transform);this._offsets.topLeft[0]=this._data[0],this._offsets.topLeft[1]=this._data[1],this._offsets.topRight[0]=this._data[2],this._offsets.topRight[1]=this._data[3],this._offsets.bottomLeft[0]=this._data[4],this._offsets.bottomLeft[1]=this._data[5],this._offsets.bottomRight[0]=this._data[6],this._offsets.bottomRight[1]=this._data[7],(0,L.l0)(this._offsets.topLeft,this._offsets.topLeft,e),(0,L.l0)(this._offsets.topRight,this._offsets.topRight,e),(0,L.l0)(this._offsets.bottomLeft,this._offsets.bottomLeft,e),(0,L.l0)(this._offsets.bottomRight,this._offsets.bottomRight,e)}_setTextureCoords({x:e,y:t,width:s,height:i}){this._texcoords={topLeft:[e,t],topRight:[e+s,t],bottomLeft:[e,t+i],bottomRight:[e+s,t+i]}}}const Xs=(e,t)=>({code:0,page:0,sdf:!0,rect:new Us.A(0,0,11,8),textureBinding:t,metrics:{advance:0,height:4,width:e,left:0,top:0}});function $s(e,t){return e.forEach(e=>(0,L.l0)(e,e,t)),{topLeft:e[0],topRight:e[1],bottomLeft:e[2],bottomRight:e[3]}}class Zs{constructor(e,t,s,i){this._rotation=0,this._decorate(e,t,s,i),this.glyphs=e,this.bounds=this._createBounds(e),this.isMultiline=t.length>1,this._hasRotation=0!==s.angle,this._transform=this._createGlyphTransform(this.bounds,s),this._borderLineSizePx=s.borderLineSizePx,(s.borderLineSizePx||s.hasBackground)&&([this.bounds,this.textBox]=this.shapeBackground(this._transform));for(const t of e)t.setTransform(this._transform)}setRotation(e){if(0===e&&0===this._rotation)return;this._rotation=e;const t=this._transform;Es(t,Ls(qs(),e),t);for(const e of this.glyphs)e.setTransform(this._transform)}_decorate(e,t,s,i){if(!s.decoration||"none"===s.decoration||!e.length)return;const r=s.scale,n="underline"===s.decoration?i?.baseline??26:i?.midline??16,o=e[0].textureBinding;for(const s of t){const t=s.startX*r,i=s.startY*r,a=(s.width+s.glyphWidthEnd)*r;e.push(new Hs(t,i+n*r,Xs(a,o),1))}}shapeBackground(e){const t=(1.5+(this._borderLineSizePx||0))/2,s=this._borderLineSizePx?t:0,{xmin:i,ymin:r,xmax:n,ymax:o,x:a,y:h,width:c,height:l}=this.bounds,u=[i-8,r-8],d=[n+8,r-8],p=[i-8,o+8],f=[n+8,o+8],_=$s([[u[0]-t,u[1]-t],[d[0]+t,d[1]-t],[u[0]+s,u[1]+s],[d[0]-s,d[1]+s]],e),m=$s([[p[0]+s,p[1]-s],[f[0]-s,f[1]-s],[p[0]-t,p[1]+t],[f[0]+t,f[1]+t]],e),g=$s([[u[0]-t,u[1]-t],[u[0]+s,u[1]+s],[p[0]-t,p[1]+t],[p[0]+s,p[1]-s]],e),y=$s([[d[0]-s,d[1]+s],[d[0]+t,d[1]-t],[f[0]-s,f[1]-s],[f[0]+t,f[1]+t]],e),x={main:$s([u,d,p,f],e),top:_,bot:m,left:g,right:y};return[new Vs(a,h,c+2*t,l+2*t),x]}get boundsT(){const e=this.bounds,t=(0,L.hZ)((0,js.vt)(),e.x,e.y);if((0,L.l0)(t,t,this._transform),this._hasRotation){const s=Math.max(e.width,e.height);return new Vs(t[0],t[1],s,s)}return new Vs(t[0],t[1],e.width,e.height)}_createBounds(e){let t=1/0,s=1/0,i=0,r=0;for(const n of e)t=Math.min(t,n.xTopLeft),s=Math.min(s,n.yTopLeft),i=Math.max(i,n.xBottomRight),r=Math.max(r,n.yBottomRight);const n=i-t,o=r-s;return new Vs(t+n/2,s+o/2,n,o)}_createGlyphTransform(e,t){const s=Ys*t.angle,i=qs(),r=(0,js.vt)();return Rs(i,i,(0,L.hZ)(r,t.xOffset,-t.yOffset)),t.useCIMAngleBehavior?Os(i,i,s):(Rs(i,i,(0,L.hZ)(r,e.x,e.y)),Os(i,i,s),Rs(i,i,(0,L.hZ)(r,-e.x,-e.y))),i}}class Qs{constructor(e,t,s,i,r,n){this.glyphWidthEnd=0,this.startX=0,this.startY=0,this.start=Math.max(0,Math.min(t,s)),this.end=Math.max(0,Math.max(t,s)),this.end<e.length&&(this.glyphWidthEnd=e[this.end].metrics.width),this.width=i,this.yMin=r,this.yMax=n}}const Js=e=>10===e,Ks=e=>32===e;function ei(e,t){const s=t.scale,i=new Array,r=e.sdfPadding,{faceInfo:n,glyphs:o,isRightToLeft:a}=e,h=function(e,t,s){const i=new Array,r=1/s.scale,n=s.maxLineWidth*r,o=t?e.length-1:0,a=t?-1:e.length,h=t?-1:1;let c=o,l=0,u=0,d=c,p=d,f=0,_=1/0,m=0;for(;c!==a;){const{code:t,metrics:s}=e[c],r=Math.abs(s.top);if(Js(t)||Ks(t)||(_=Math.min(_,r),m=Math.max(m,r+s.height)),Js(t))c!==o&&(i.push(new Qs(e,d,c-h,l,_===1/0?0:_,m)),_=1/0,m=0),l=0,d=c+h,p=c+h,u=0;else if(Ks(t))p=c+h,u=0,f=s.advance,l+=s.advance;else if(l>n){if(p!==d){const t=p-2*h;l-=f,i.push(new Qs(e,d,t,l-u,_,m)),_=1/0,m=0,d=p,l=u}else i.push(new Qs(e,d,c-h,l,_,m)),_=1/0,m=0,d=c,p=c,l=0;l+=s.advance,u+=s.advance}else l+=s.advance,u+=s.advance;c+=h}const g=new Qs(e,d,c-h,l,_,m);return g.start>=0&&g.end<e.length&&i.push(g),i}(o,a,t),c=h.length?function(e,t){let s=0;for(let t=0;t<e.length;t++){const{width:i}=e[t];s=Math.max(i,s)}const i="underline"===t.decoration?4:0,r=e[0].yMin;return{x:0,y:r,height:e[e.length-1].yMax+t.lineHeight*(e.length-1)+i-r,width:s}}(h,t):{y:0,height:0},l=function(e){if(!e)return 0;switch(e){case"Left":case"left":return-1;case"Right":case"right":return 1;case"Justify":return Rt.A.getLogger("esri.views.2d.engine.webgl.alignmentUtils").warnOnce("Horizontal alignment 'justify' is not implemented. Falling back to 'center'."),0;case"Center":case"center":return 0}}(t.horizontalAlignment),u=function(e){if(!e)return 0;switch(e){case"Top":case"top":return 1;case"Center":case"middle":return 0;case"Baseline":case"baseline":return 2;case"Bottom":case"bottom":return-1}}(t.verticalAlignment),d=2===u?1:0,p=d?0:u-1,f=(1-d)*-c.y+p*(c.height/2)+-22*d;for(let n=0;n<h.length;n++){const{start:a,end:c,width:u}=h[n];let d=-1*(l+1)*(u/2)-r;const p=(e.isRightToLeft?h.length-1-n:n)*t.lineHeight+f-r;h[n].startX=d,h[n].startY=p;for(let e=a;e<=c;e++){const t=o[e];if(Js(t.code))continue;const r=new Hs(d+t.metrics.left,p-t.metrics.top,t,s);d+=t.metrics.advance,i.push(r)}}return new Zs(i,h,t,n)}s(39829),Math.PI,s(59868);var ti=s(13195);function si(e){if(!e)return 0;switch(e.type){case"CIMGeometricEffectArrow":return Math.abs(.5*e.width);case"CIMGeometricEffectBuffer":return Math.abs(e.size);case"CIMGeometricEffectControlMeasureLine":return 500;case"CIMGeometricEffectExtension":case"CIMGeometricEffectRadial":return Math.abs(e.length);case"CIMGeometricEffectJog":return Math.abs(.5*e.length);case"CIMGeometricEffectMove":return Math.max(Math.abs((0,Oe.$w)(e.offsetX)),Math.abs((0,Oe.$w)(e.offsetY)));case"CIMGeometricEffectOffset":case"CIMGeometricEffectOffsetTangent":return Math.abs(e.offset);case"CIMGeometricEffectRegularPolygon":return Math.abs(e.radius);case"CIMGeometricEffectRotate":case"CIMGeometricEffectScale":default:return 0;case"CIMGeometricEffectTaperedPolygon":return.5*Math.max(Math.abs(e.fromWidth),Math.abs(e.toWidth));case"CIMGeometricEffectWave":return Math.abs(e.amplitude);case"CIMGeometricEffectDonut":return Math.abs(e.width)}}function ii(e){if(!e)return 0;let t=0;for(const s of e)t+=si(s);return t}Math.PI,Math.PI;const ri=96/72;class ni{static executeEffects(e,t,s,i){const r=ri,n=ii(e);let o=new Ve(t);for(const t of e){const e=ls(t);e&&(o=e.execute(o,t,r,s,n,i))}return o}static applyEffects(e,t){if(!e)return t;const s=ii(e);let i,r=new Ve(ye.z.fromJSONCIM(t));for(const t of e){const e=ls(t);e&&(r=e.execute(r,t,1,null,s,!1))}const n=[];let o=null;for(;i=r.next();)n.push(...(0,Se.x)(i)),o=i.geometryType;return 0===n.length||null===o?null:"esriGeometryPolygon"===o?{rings:n}:{paths:n}}}var oi=s(89518),ai=s(68572),hi=s(63907);class ci{static fromVertexSpec(e,t){const s=ai.q.fromVertexSpec(e,t);return new ci(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,oi.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 hi.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 hi.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 hi.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 hi.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 hi.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 hi.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 hi.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 hi.pe.HALF_FLOAT:if(1===s.count)e.setUint16(i+s.offset,(0,oi.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,oi.fw)(t[n]*r),!0)}}}(this._dataView,e,t,s)}}class li{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=ci.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 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 Ue(e)}enqueueRequest(e,t,s){this._evaluator.hasDynamicProperties&&this._evaluator.enqueueRequest(e,t,s)}write(e,t,s,i,r){this.ensurePacked(t,s,i);const n=this.evaluatedMeshParams.effects;if(!n||0===n.length)return void this._write(e,s,void 0,r);const o=this.getEffectCursor(e,s,n);if(!o)return;let a;for(;a=o.next();)a.invertY(),this._write(e,s,a,r)}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=ye.z.fromOptimizedCIM(i,t.geometryType);r.invertY();const n=e.id||"";return ni.executeEffects(s,r,n,this._preventEffectClipping)}}class ui extends li{}function di(e,t){let s;if("string"==typeof e)s=(0,_e.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 pi(e){return Math.floor(di(e,fi)*_i)}const fi=53290320,_i=10;class mi{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 >= ${Ii}) { top = ${Ii-1}; }`);return t}}let gi=128;function yi(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 xi={Linear:1,EaseIn:2,EaseOut:3,EaseInOut:4},bi={Loop:1,None:2,Oscillate:3},wi={Local:1,Global:2};function vi(e){const t=xi[e.easing],s=bi[e.repeatType],i=wi[e.timeOriginSelector];return[[e.duration,e.startTimeOffset,e.repeatDelay,i],[s,t,e.playAnimation,e.reverseAnimation]]}const Si={scalar:new class extends mi{constructor(){super(...arguments),this.opcode=++gi,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 mi{constructor(){super(...arguments),this.opcode=++gi,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 mi{constructor(){super(...arguments),this.opcode=++gi,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 mi{constructor(){super(...arguments),this.opcode=++gi,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;","{",...yi({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;","{",...yi({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;","{",...yi({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],...vi(e.translation.timing),...vi(e.rotation.timing),...vi(e.scale.timing),[e.relativeTranslation?1:0,e.absoluteScale?1:0,0,0]]}},animatedColor:new class extends mi{constructor(){super(...arguments),this.opcode=++gi,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;","{",...yi({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;","{",...yi({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]],...vi(e.color.timing),...vi(e.opacity.timing)]}},animatedShift:new class extends mi{constructor(){super(...arguments),this.opcode=++gi,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;","{",...yi({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],...vi(e.shift.timing),[e.multiplyByLineLength?1:0,0,0,0]]}},ret:new class extends mi{constructor(){super(...arguments),this.opcode=++gi,this.length=1,this.ins=0,this.outs=0,this.microcode=["break;"]}encode(){return[[this.opcode,0,0,0]]}}},Ii=4;function Pi(e){return e instanceof Mi?e:"object"==typeof e&&"type"in e?Fi[e.type].hydrate(e):new ki(e)}class Mi{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 ki extends Mi{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?Si.vector4.encode([e,t||0,s||0,i]):Si.vector3.encode([e,t||0,s||0])}return Si.scalar.encode(this.value)}}class Ci extends Mi{constructor(e,t){super([t]),this._config=e,this._parent=t}static hydrate(e){return new Ci(e,Pi(e.parent))}simplify(){if(this._config.relativeTranslation||this._config.absoluteScale)return this;const e=this._parent.simplify();if(!(e instanceof ki))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,h=this._config.scale.from;if(n===this._config.translation.to[0]&&o===this._config.translation.to[1]&&a===this._config.rotation.to&&h===this._config.scale.to){const e=i+a,c=r*h,l=Math.sin(i),u=Math.cos(i);return new ki([u*r*n-l*r*o+t,l*r*n+u*r*o+s,e,c])}return new Ci(this._config,e)}get instructions(){return Si.animatedTransform.encode(this._config)}}class Ai extends Mi{constructor(e,t){super([t]),this._config=e,this._parent=t}static hydrate(e){return new Ai(e,Pi(e.parent))}simplify(){const e=this._parent.simplify();if(!(e instanceof ki))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 h=this._config.color.from[3];const c=this._config.opacity.from;return n===this._config.color.to[0]&&o===this._config.color.to[1]&&a===this._config.color.to[2]&&h===this._config.color.to[3]&&c===this._config.opacity.to?(h*=c,new ki([t*n,s*o,i*a,r*h])):new Ai(this._config,e)}get instructions(){return Si.animatedColor.encode(this._config)}}class Ti extends Mi{constructor(e,t){super([t]),this._config=e,this._parent=t}static hydrate(e){return new Ti(e,Pi(e.parent))}simplify(){const e=this._parent.simplify();return e instanceof ki?new Ti(this._config,e):this}get instructions(){return Si.animatedShift.encode(this._config)}}const Fi={AnimatedTransform:Ci,AnimatedColor:Ai,AnimatedShift:Ti};function zi(e){return Oi(e.map(e=>Li(e)).map(e=>Pi(e).simplify()))}function Ei(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 Oi(e){const t=[],s=[];let i=0;for(const r of e){const n=[...r.encode(),...Si.ret.encode()];t.push([i+e.length,0,0,0]),s.push(...n),i+=n.length}return[...t,...s]}async function Ri(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=>Ri(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 Ri(s[e],t)}return i}function Li(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=>Li(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=Li(i.value,t,s);Ni(Array.isArray(e)&&4===e.length),r=[e[0]/255,e[1]/255,e[2]/255,e[3]]}break;case"Transparency":{const e=Li(i.value,t,s);Ni("number"==typeof e),r=1-e/100}break;case"Divide":case"Multiply":case"Add":{const e=Li(i.left,t,s);Ni("number"==typeof e);const n=Li(i.right,t,s);switch(Ni("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=Li(i.seed,t,s),n=Li(i.min,t,s),o=Li(i.max,t,s);r=n+di(pi(t.getObjectId()||0),e)*(o-n)}break;case"Cond":{const e=Li(i.condition,t,s),n=Li(i.ifTrue,t,s),o=Li(i.ifFalse,t,s);r=e?n:o}break;case"MatchWinding":{const e=Li(i.sign,t,s);let n=Li(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=ds.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]=Li(i[e],t,s)}return r}function*Di(e){const t=e;if(Array.isArray(t))for(const e of t)yield*Di(e);else if("object"==typeof t)if("type"in t&&null!=t.type&&"Process"===t.type)switch(t.op){case"ArcadeColor":case"Transparency":yield*Di(t.value);break;case"Divide":case"Multiply":case"Add":yield*Di(t.left),yield*Di(t.right);break;case"Random":yield*Di(t.seed),yield*Di(t.min),yield*Di(t.max);break;case"Cond":yield*Di(t.condition),yield*Di(t.ifTrue),yield*Di(t.ifFalse);break;case"MatchWinding":yield*Di(t.sign),yield*Di(t.angle)}else if("computed"in t)yield t.computed;else for(const e in t)yield*Di(t[e])}function Ni(e){if(!e)throw new Error("Assertion failed.")}const Gi={type:hi.pe.SHORT,count:2,packPrecisionFactor:p.fq,pack:({scaleInfo:e},{tileInfo:t})=>ps(e,t)},qi={type:hi.pe.FLOAT,count:4,packPrecisionFactor:1,packTessellation:({value1Position2Value2:e})=>(Ni(e),e)},Bi={type:hi.pe.FLOAT,count:4,packPrecisionFactor:1,packTessellation:()=>[0,0,0,1]},Wi={type:hi.pe.FLOAT,count:1,packPrecisionFactor:1,pack:()=>0},ji={type:hi.pe.FLOAT,count:1,packPrecisionFactor:1,packTessellation:({lineLength:e})=>e},Ui={type:hi.pe.UNSIGNED_SHORT,count:1,packTessellation:({distance:e})=>e},Vi={type:hi.pe.BYTE,count:2,packPrecisionFactor:16,packTessellation:({directionX:e,directionY:t})=>[e,t]},Yi={type:hi.pe.FLOAT,count:2,packPrecisionFactor:16,packTessellation:({normalX:e,normalY:t})=>[e,t]},Hi={type:hi.pe.UNSIGNED_BYTE,count:3,pack:"id"},Xi={type:hi.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|=fs(vs)),i&&(o|=fs(Ps)),t.sdf&&(o|=fs(ws)),r&&(o|=fs(Ss)),n&&(o|=fs(Ms)),o}},$i={type:hi.pe.SHORT,count:2,pack:"position",packPrecisionFactor:1},Zi={marker:{type:hi.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:hi.pe.FLOAT,count:2,packTessellation:({extrusionOffsetX:e,extrusionOffsetY:t},{baseSize:s})=>[e*s/2,t*s/2]},fill:{type:hi.pe.FLOAT,count:2,packTessellation:()=>[0,0]}},Qi={marker:{type:hi.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]]}}},Ji={type:hi.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]}},Ki={type:hi.pe.UNSIGNED_SHORT,count:4,packPrecisionFactor:4,pack:({animations:e,baseSize:t,referenceSize:s})=>[e.dataColumn,e.dataRow,t,s]},er={type:hi.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]}},tr={type:hi.pe.BYTE,count:1,packTessellation:({angle:e})=>e};function sr(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,l.Lz)(i),r=(0,l.Lz)(r),n=(0,l.Lz)(n);const a=(e.sprite.sdfDecodeCoeff??1)*o;return{...e,pixelDimensions:t,texelDimensions:s,baseSize:i,referenceSize:r,strokeWidth:n,sdfDecodeCoeff:a}}class ir extends ui{get vertexSpec(){return{createComputedParams:sr,optionalAttributes:{zoomRange:Gi,value1Position2Value2:qi,lineLength:ji},attributes:{id:Hi,bitset:Xi,pos:$i,offset:Zi.marker,uv:Qi.marker,animationPointerAndBaseSizeAndReferenceSize:Ki,sizing:er,angle:tr}}}_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=ye.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=ye.z.fromFeatureSetReaderCIM(t)?.clone();if(!s)return;const i=us.getPlacement(s,-1,this.evaluatedMeshParams.placement,(0,l.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)>be||Math.abs(s)>be){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=rr(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 h=this.evaluatedMeshParams.sprite,{rect:c}=h,l=c.x+p.hM,u=c.y+p.hM,d=c.x+c.width-p.hM,f=c.y+c.height-p.hM,_=e.vertexCount();a||e.recordBounds(s,i,64,64);const m={texXmin:l,texYmin:u,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 rr(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],h=Math.sqrt(o*o+a*a),c=o/h,l=a/h;t.push({a:{position:r,distance:s,direction:[c,l]},b:{position:n,distance:s+h,direction:[c,l]}}),s+=h}return t}class nr extends ir{constructor(){super(...arguments),this.shift=!1}}class or extends ir{constructor(){super(...arguments),this.shift=!0}}var ar=s(15585),hr=s(83773),cr=s(92722);function lr(e,t,s,i,r,n,o){Or=0;const a=(i-s)*n,h=r&&r.length,c=h?(r[0]-s)*n:a;let l,u,d,p,f,_=ur(t,s,0,0,c,n,!0);if(_&&_.next!==_.prev){if(h&&(_=function(e,t,s,i,r,n){const o=new Array;for(let r=0,a=i.length;r<a;r++){const h=ur(e,t,0,i[r]*n,r<a-1?i[r+1]*n:s*n,n,!1);h===h.next&&(h.steiner=!0),o.push(yr(h))}o.sort(kr);for(const e of o)r=xr(e,r);return r}(t,s,i,r,_,n)),a>80*n){l=d=t[0+s*n],u=p=t[1+s*n];for(let e=n;e<c;e+=n){const i=t[e+s*n],r=t[e+1+s*n];l=Math.min(l,i),u=Math.min(u,r),d=Math.max(d,i),p=Math.max(p,r)}f=Math.max(d-l,p-u),f=0!==f?1/f:0}pr(_,e,n,l,u,f,o,0)}}function ur(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=mr(s+t*n,e[s+t*n],e[s+1+t*n],a);else for(let s=r-n;s>=i;s-=n)a=mr(s+t*n,e[s+t*n],e[s+1+t*n],a);return a&&Mr(a,a.next)&&(gr(a),a=a.next),a}function dr(e,t=e){if(!e)return e;let s,i=e;do{if(s=!1,i.steiner||!Mr(i,i.next)&&0!==wr(i.prev,i,i.next))i=i.next;else{if(gr(i),i=t=i.prev,i===i.next)break;s=!0}}while(s||i!==t);return t}function pr(e,t,s,i,r,n,o,a){if(!e)return;!a&&n&&(e=br(e,i,r,n));let h=e;for(;e.prev!==e.next;){const c=e.prev,l=e.next;if(n?_r(e,i,r,n):fr(e))t.push(c.index/s+o),t.push(e.index/s+o),t.push(l.index/s+o),gr(e),e=l.next,h=l.next;else if((e=l)===h){a?1===a?pr(e=Cr(e,t,s,o),t,s,i,r,n,o,2):2===a&&Ar(e,t,s,i,r,n,o):pr(dr(e),t,s,i,r,n,o,1);break}}}function fr(e){const t=e.prev,s=e,i=e.next;if(wr(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++,Sr(t.x,t.y,s.x,s.y,i.x,i.y,r.x,r.y)&&wr(r.prev,r,r.next)>=0)return!1;r=r.next}return!0}function _r(e,t,s,i){const r=e.prev,n=e,o=e.next;if(wr(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,h=r.y<n.y?r.y<o.y?r.y:o.y:n.y<o.y?n.y:o.y,c=r.x>n.x?r.x>o.x?r.x:o.x:n.x>o.x?n.x:o.x,l=r.y>n.y?r.y>o.y?r.y:o.y:n.y>o.y?n.y:o.y,u=Pr(a,h,t,s,i),d=Pr(c,l,t,s,i);let p=e.prevZ,f=e.nextZ;for(;p&&p.z>=u&&f&&f.z<=d;){if(p!==e.prev&&p!==e.next&&Sr(r.x,r.y,n.x,n.y,o.x,o.y,p.x,p.y)&&wr(p.prev,p,p.next)>=0)return!1;if(p=p.prevZ,f!==e.prev&&f!==e.next&&Sr(r.x,r.y,n.x,n.y,o.x,o.y,f.x,f.y)&&wr(f.prev,f,f.next)>=0)return!1;f=f.nextZ}for(;p&&p.z>=u;){if(p!==e.prev&&p!==e.next&&Sr(r.x,r.y,n.x,n.y,o.x,o.y,p.x,p.y)&&wr(p.prev,p,p.next)>=0)return!1;p=p.prevZ}for(;f&&f.z<=d;){if(f!==e.prev&&f!==e.next&&Sr(r.x,r.y,n.x,n.y,o.x,o.y,f.x,f.y)&&wr(f.prev,f,f.next)>=0)return!1;f=f.nextZ}return!0}function mr(e,t,s,i){const r=zr.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 gr(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 yr(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 xr(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,h=n.x,c=n.y;let l,u=1/0;for(s=n.next;s!==a;)i>=s.x&&s.x>=h&&i!==s.x&&Sr(r<c?i:o,r,h,c,r<c?o:i,r,s.x,s.y)&&(l=Math.abs(r-s.y)/(i-s.x),(l<u||l===u&&s.x>n.x)&&Ir(s,e)&&(n=s,u=l)),s=s.next;return n}(e,t);if(!s)return t;const i=Fr(s,e);return dr(i,i.next),dr(s,s.next)}function br(e,t,s,i){let r;for(;r!==e;r=r.next){if(r=r||e,null===r.z&&(r.z=Pr(r.x,r.y,t,s,i)),r.prev.next!==r||r.next.prev!==r)return r.prev.next=r,r.next.prev=r,br(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 wr(e,t,s){return(t.y-e.y)*(s.x-t.x)-(t.x-e.x)*(s.y-t.y)}function vr(e,t,s,i){return!!(Mr(e,t)&&Mr(s,i)||Mr(e,i)&&Mr(s,t))||wr(e,t,s)>0!=wr(e,t,i)>0&&wr(s,i,e)>0!=wr(s,i,t)>0}function Sr(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 Ir(e,t){return wr(e.prev,e,e.next)<0?wr(e,t,e.next)>=0&&wr(e,e.prev,t)>=0:wr(e,t,e.prev)<0||wr(e,e.next,t)<0}function Pr(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 Mr(e,t){return e.x===t.x&&e.y===t.y}function kr(e,t){return e.x-t.x}function Cr(e,t,s,i){let r=e;do{const n=r.prev,o=r.next.next;!Mr(n,o)&&vr(n,r,r.next,o)&&Ir(n,o)&&Ir(o,n)&&(t.push(n.index/s+i),t.push(r.index/s+i),t.push(o.index/s+i),gr(r),gr(r.next),r=e=o),r=r.next}while(r!==e);return r}function Ar(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&&Tr(a,e)){let h=Fr(a,e);return a=dr(a,a.next),h=dr(h,h.next),pr(a,t,s,i,r,n,o,0),void pr(h,t,s,i,r,n,o,0)}e=e.next}a=a.next}while(a!==e)}function Tr(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&&vr(s,s.next,e,t))return!0;s=s.next}while(s!==e);return!1}(e,t)&&Ir(e,t)&&Ir(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 Fr(e,t){const s=zr.create(e.index,e.x,e.y),i=zr.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 zr{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=Or<Er.length?Er[Or++]:new zr;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 Er=[];let Or=0;for(let e=0;e<8096;e++)Er.push(new zr);const Rr=new Ee.O3(0,0,0,1,0),Lr=new Ee.O3(0,0,0,1,0);function Dr(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 Nr(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 Gr(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=Dr(s,n,o);const h=[];for(;++t<i.length;){const e=i[t],r=Dr(s,n+o,e);if(!(r>0))break;a+=r,h.push(n+o),o+=e}const c=r.length;lr(r,s,n,n+o,h,2,0);const l=Nr(r,s,c,r.length,0),u=Math.abs(a);if(Math.abs((l-u)/Math.max(1e-7,u))>1e-5)return r.length=0,!1;e=t,n+=o}return!0}function qr(e){const{coords:t,lengths:s}=e,{buffer:i}=(0,ar.QT)(t,s);return i}function Br(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;Rr.setPixelMargin(t),Rr.reset(3);const{stride:s,lengths:i,coords:r}=e;let n=0;for(const e of i){const t=n+e*s;for(Rr.moveTo(r[n],r[n+1]),n+=s;n<t;)Rr.lineTo(r[n],r[n+1]),n+=s;Rr.close()}const o=Rr.result(!1);if(!o)return null;const a=new cr.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 Wr(e,t){Lr.setPixelMargin(t);const s=Lr,i=-t,r=p.CQ+t;let n=[],o=!1;if(!e.nextPath())return null;let a=e.pathLength(),h=!0;for(;h;){e.seekPathStart();const t=[];if(!e.pathSize)return null;s.reset(2),e.nextPoint();let c=e.x,l=e.y;if(o)s.moveTo(c,l);else{if(c<i||c>r||l<i||l>r){o=!0;continue}t.push({x:c,y:l})}let u=!1;for(;e.nextPoint();)if(c=e.x,l=e.y,o)s.lineTo(c,l);else{if(c<i||c>r||l<i||l>r){u=!0;break}t.push({x:c,y:l})}if(u)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});h=e.nextPath(),a=h?e.pathLength():0,o=!1}}return n=n.filter(e=>e.line.length>1),0===n.length?null:n}Rr.setExtent(p.CQ),Lr.setExtent(p.CQ);var jr=s(23304);class Ur{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 Vr={createComputedParams:e=>e,optionalAttributes:{zoomRange:{type:hi.pe.SHORT,count:2,packPrecisionFactor:p.fq,pack:({scaleInfo:e},{tileInfo:t})=>ps(e,t)}},attributes:{id:{type:hi.pe.UNSIGNED_BYTE,count:3,pack:"id"},pos:{type:hi.pe.SHORT,count:2,pack:"position",packPrecisionFactor:10},bitset:{type:hi.pe.UNSIGNED_BYTE,count:1},color:{type:hi.pe.UNSIGNED_BYTE,count:4,normalized:!0,pack:({color:e})=>ms(e)},offset:{type:hi.pe.BYTE,count:2,packPrecisionFactor:16,packTessellation:({extrusionOffsetX:e,extrusionOffsetY:t})=>[bs(e,16),bs(t,16)]},normal:{type:hi.pe.BYTE,count:2,packPrecisionFactor:16,packTessellation:({normalX:e,normalY:t})=>[bs(e,16),bs(t,16)]},halfWidth:{type:hi.pe.HALF_FLOAT,count:1,pack:({width:e})=>(0,l.Lz)(.5*e)},referenceHalfWidth:{type:hi.pe.HALF_FLOAT,count:1,pack:({referenceWidth:e})=>(0,l.Lz)(.5*e)}}};class Yr{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 Hr=65535;class Xr extends li{constructor(e,t,s,i){super(e,t,s,i),this.vertexSpec=Vr,this._currentWrite=new Yr,this._tessellationOptions={halfWidth:0,pixelCoordRatio:1,offset:0,wrapDistance:Hr,textured:!1},this._tessParams=new Ur,this._initializeTessellator()}writeLineVertices(e,t,s){const i=this._getLines(t);null!=i&&this._writeVertices(e,s,i)}_initializeTessellator(){this._lineTessellator=new hr.i(this._writeTesselatedVertex.bind(this),this._writeTriangle.bind(this),!0)}_write(e,t,s){const i=s??ye.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 Wr(e,(0,jr.Z0)(this.evaluatedMeshParams))}_writeVertices(e,t,s){const{_currentWrite:i,_tessellationOptions:r,evaluatedMeshParams:n}=this,{width:o,capType:a,joinType:h,miterLimit:c,hasSizeVV:u}=n,d=(0,l.Lz)(.5*o);r.halfWidth=d,r.capType=gs(a),r.joinType=ys(h),r.miterLimit=c;const f=!u;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%Hr,i.pathLength=n,i.distanceOffset=Math.floor(t/Hr)*Hr,this._lineTessellator.tessellate(e,r,f)}_writeTesselatedVertex(e,t,s,i,r,n,o,a,h,c,l){const{out:u,id:d,vertexBounds:p,pathLength:f,distanceOffset:_}=this._currentWrite;return this.hasEffects&&u.recordBounds(e,t,p,p),this._tessParams.extrusionOffsetX=o,this._tessParams.extrusionOffsetY=a,this._tessParams.normalX=h,this._tessParams.normalY=c,this._tessParams.directionX=r,this._tessParams.directionY=n,this._tessParams.distance=l,this._tessParams.pathLength=f,this._tessParams.distanceOffset=_,this._writeVertex(u,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 $r extends ui{_write(e,t,s){const i=s??ye.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 Zr extends $r{constructor(){super(...arguments),this.vertexSpec={createComputedParams:sr,attributes:{id:Hi,bitset:Xi,pos:$i,offset:Zi.fill,tlbr:Ji,animationPointerAndBaseSizeAndReferenceSize:Ki,sizing:er},optionalAttributes:{zoomRange:Gi,value1Position2Value2:Bi,lineLength:Wi}}}_writePoly(e,t,s){const i=this._clip(s);if(!i)return;s=i;const r=[],n=e.vertexCount();let o;if(Gr(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,ar.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 Br(e,this.hasEffects?256:8)}}class Qr{constructor(){this.id=0,this.bitset=0,this.indexCount=0,this.vertexCount=0,this.vertexFrom=0,this.vertexBounds=0,this.pathLength=0}}class Jr extends $r{constructor(){super(...arguments),this.vertexSpec={createComputedParams:sr,attributes:{id:Hi,bitset:Xi,pos:$i,offset:Zi.line,tlbr:Ji,animationPointerAndBaseSizeAndReferenceSize:Ki,sizing:er,accumulatedDistance:Ui,normal:Yi,segmentDirection:Vi},optionalAttributes:{zoomRange:Gi,value1Position2Value2:Bi,lineLength:ji}},this._tessParams=new Ur,this._currentWrite=new Qr,this._tessellationOptions={halfWidth:0,pixelCoordRatio:1,offset:0,wrapDistance:65535,textured:!1},this._lineLength=0,this._lineTessellator=new hr.i((e,t,s,i,r,n,o,a,h,c,l)=>this._writeTesselatedVertex(e,t,s,i,r,n,o,a,h,c,l,this._lineLength),this._writeTriangle.bind(this),!1)}_writePoly(e,t,s){const i=Wr(ye.z.fromOptimized(s,"esriGeometryPolyline"),64);if(null==i)return;const{_currentWrite:r,_tessellationOptions:n}=this,{baseSize:o,capType:a,joinType:h,miterLimit:c}=this.evaluatedMeshParams,u=(0,l.Lz)(.5*o);n.halfWidth=u,n.capType=gs(a||"Round"),n.joinType=ys(h||"Round"),n.miterLimit=c||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,h,c,l,u){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=h,this._tessParams.normalY=c,this._tessParams.directionX=r,this._tessParams.directionY=n,this._tessParams.distance=l,this._tessParams.pathLength=_,this._tessParams.lineLength=u,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 Kr extends li{async loadDependencies(){await Promise.all([super.loadDependencies(),(0,ar.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.justXY()),e.recordEnd())}_clip(e){return e?Br(e,this.hasEffects?256:8):null}_writeGeometry(e,t,s){const i=function(e){const t=[];return e.maxLength>100||!Gr(t,e)?{indices:null,vertices:qr(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:h}=s;let c=0;if(h)for(const t of h){const s=a[2*t],n=a[2*t+1];o&&e.recordBounds(s,n,0,0),this._writeVertex(e,r,s,n,i),c++}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),c++}e.indexEnsureSize(c);for(let t=0;t<c;t++)e.indexWrite(t+n)}}const en={createComputedParams:e=>e,optionalAttributes:{},attributes:{id:{type:hi.pe.UNSIGNED_BYTE,count:3,pack:"id"},bitset:{type:hi.pe.UNSIGNED_BYTE,count:1},pos:{type:hi.pe.SHORT,count:2,pack:"position",packPrecisionFactor:10},inverseArea:{type:hi.pe.FLOAT,count:1,packTessellation:({inverseArea:e})=>e}}};class tn extends Kr{constructor(){super(...arguments),this.vertexSpec=en}createTesselationParams(e){return{inverseArea:1/e.readGeometryArea()}}}const sn={createComputedParams:e=>e,optionalAttributes:{zoomRange:{type:hi.pe.SHORT,count:2,packPrecisionFactor:p.fq,pack:({scaleInfo:e},{tileInfo:t})=>ps(e,t)}},attributes:{id:{type:hi.pe.UNSIGNED_BYTE,count:3,pack:"id"},bitset:{type:hi.pe.UNSIGNED_BYTE,count:1},pos:{type:hi.pe.SHORT,count:2,pack:"position",packPrecisionFactor:10},color:{type:hi.pe.UNSIGNED_BYTE,count:4,normalized:!0,pack:({color:e})=>ms(e)}}};class rn extends Kr{constructor(){super(...arguments),this.vertexSpec=sn}createTesselationParams(e){return null}}const nn={createComputedParams:e=>e,optionalAttributes:sn.optionalAttributes,attributes:{...sn.attributes,tlbr:{count:4,type:hi.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:hi.pe.BYTE,packPrecisionFactor:16,pack:({sprite:e})=>1/e.rasterizationScale}}};class on extends rn{constructor(){super(...arguments),this.vertexSpec=nn}_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 an(e){const{sprite:t,aspectRatio:s,scaleProportionally:i}=e,r=(0,l.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 hn(e){const{applyRandomOffset:t,sampleAlphaOnly:s}=e;return _s([[2,t],[4,s]])}const cn={createComputedParams:e=>e,optionalAttributes:nn.optionalAttributes,attributes:{...nn.attributes,bitset:{count:1,type:hi.pe.UNSIGNED_BYTE,pack:hn},width:{count:1,type:hi.pe.HALF_FLOAT,pack:e=>an(e).width},height:{count:1,type:hi.pe.HALF_FLOAT,pack:e=>an(e).height},offset:{count:2,type:hi.pe.HALF_FLOAT,pack:({offsetX:e,offsetY:t})=>[(0,l.Lz)(e),-(0,l.Lz)(t)]},scale:{count:2,type:hi.pe.UNSIGNED_BYTE,packPrecisionFactor:16,pack:({scaleX:e,scaleY:t})=>[e,t]},angle:{count:1,type:hi.pe.UNSIGNED_BYTE,pack:({angle:e})=>(0,ti.wV)(e)}}};class ln extends on{constructor(){super(...arguments),this.vertexSpec=cn}}const un={createComputedParams:e=>e,optionalAttributes:Vr.optionalAttributes,attributes:{...Vr.attributes,bitset:{type:hi.pe.UNSIGNED_BYTE,count:1,pack:e=>0},color:{type:hi.pe.UNSIGNED_BYTE,count:4,normalized:!0,pack:({color:e})=>ms(e)}}},dn={createComputedParams:e=>e,optionalAttributes:Vr.optionalAttributes,attributes:{...Vr.attributes,bitset:{type:hi.pe.UNSIGNED_BYTE,count:1,pack:e=>_s([[0,!0],[1,e.outlineUsesColorVV]])},color:{type:hi.pe.UNSIGNED_BYTE,count:4,normalized:!0,pack:({outlineColor:e})=>ms(e)}}};class pn extends Xr{constructor(){super(...arguments),this.vertexSpec=dn}}class fn extends rn{constructor(e,t,s,i){super(e,t,s,i),this.vertexSpec=un,this._lineMeshWriter=this._createOutlineWriter(e,t,s,i)}_createOutlineWriter(e,t,s,i){return new pn(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,ye.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,ye.z.fromOptimizedCIM(r,"esriGeometryPolyline"),t)}_clip(e){return e?Br(e,(0,jr.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 _n=cn,mn=dn,gn={createComputedParams:e=>e,optionalAttributes:_n.optionalAttributes,attributes:{..._n.attributes,bitset:{type:hi.pe.UNSIGNED_BYTE,count:1,pack:e=>hn(e)},aux1:{count:1,type:hi.pe.HALF_FLOAT,pack:e=>an(e).width},aux2:{count:1,type:hi.pe.HALF_FLOAT,pack:e=>an(e).height},aux3:{count:2,type:hi.pe.HALF_FLOAT,pack:({offsetX:e,offsetY:t})=>[(0,l.Lz)(e),(0,l.Lz)(t)]},aux4:{count:2,type:hi.pe.UNSIGNED_BYTE,pack:({scaleX:e,scaleY:t})=>[16*e,16*t]}}},yn={createComputedParams:e=>e,optionalAttributes:_n.optionalAttributes,attributes:{..._n.attributes,color:mn.attributes.color,bitset:{type:hi.pe.UNSIGNED_BYTE,count:1,pack:e=>_s([[0,!0]])},aux1:{count:1,type:hi.pe.HALF_FLOAT,pack:e=>(0,l.Lz)(.5*e.width)},aux2:{count:1,type:hi.pe.HALF_FLOAT,pack:e=>(0,l.Lz)(.5*e.referenceWidth)},aux3:{count:2,type:hi.pe.HALF_FLOAT,packTessellation:({extrusionOffsetX:e,extrusionOffsetY:t})=>[e,t]},aux4:{count:2,type:hi.pe.UNSIGNED_BYTE,packTessellation:({normalX:e,normalY:t})=>[16*e+128,16*t+128]}}};class xn extends pn{constructor(){super(...arguments),this.vertexSpec=yn}}class bn extends fn{constructor(){super(...arguments),this.vertexSpec=gn}_createOutlineWriter(e,t,s,i){return new xn(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 wn=s(13337);class vn{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===wn.h.Relative){const e=Math.min(this._size/100,1);return[e,e]}return this.calculateRelativeSizeFromAbsolute()}}class Sn extends vn{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:h}=this;e.forEachVertex((e,t)=>{const s=e*n+t*o,i=e*a+t*h;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 In extends Sn{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,l.Lz)(e)/(i-s),0]}}class Pn extends Sn{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,h=e*o+t*a,c=e*r+t*n-i[0],l=h-i[1];return[c*(2/(s.xmax-s.xmin)),-l*(2/(s.ymax-s.ymin))]}calculateRelativeSizeFromAbsolute(){const{_size:e,bounds:t}=this,{xmin:s,ymin:i,xmax:r,ymax:n}=t;return[(0,l.Lz)(2*e)/(r-s),(0,l.Lz)(2*e)/(n-i)]}}class Mn extends Sn{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,h=o-n;this.radius=Math.sqrt(a*a+h*h)/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,l.Lz)(e)/this.radius,0]}}function kn(e,t){if(null==e)return null;const s=(0,Cs.kU)(t.angle),i=t.gradientSize,r=t.gradientSizeUnits;switch(t.gradientMethod.toLowerCase()){case"linear":return new In(e,i,r,s);case"rectangular":return new Pn(e,i,r,s);case"circular":return new Mn(e,i,r);default:return Rt.A.getLogger("esri.views.2d.engine.webgl.shaderGraph.techniques.fill.GradientSizeHelper").errorOnce(`Gradient fill method "${t.gradientMethod}" currently unsupported.`),null}}const Cn={createComputedParams:e=>e,optionalAttributes:sn.optionalAttributes,attributes:{...sn.attributes,bitset:{type:hi.pe.UNSIGNED_BYTE,count:1,pack:({gradientSizeUnits:e,gradientType:t})=>{let s=0;return e===wn.h.Absolute&&(s|=fs(0)),"discrete"===t.toLowerCase()&&(s|=fs(1)),s}},tlbr:{count:4,type:hi.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:hi.pe.HALF_FLOAT,packTessellation:({gradientStats:e},t,s,i)=>e?.getRelativePosition(s,i)??[0,0]},relativeGradientSize:{count:2,type:hi.pe.HALF_FLOAT,packTessellation:({gradientStats:e})=>e?.relativeSize??[1,1]},gradientMethod:{count:1,type:hi.pe.UNSIGNED_BYTE,pack:({gradientMethod:e})=>{switch(e.toLowerCase()){case"rectangular":return 1;case"circular":return 2;default:return 0}}}}};class An extends Kr{constructor(){super(...arguments),this.vertexSpec=Cn}get _preventEffectClipping(){return!0}createTesselationParams(e){return{gradientStats:kn(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 Tn={optionalAttributes:nn.optionalAttributes,createComputedParams:e=>e,attributes:{...nn.attributes,...un.attributes}},Fn={optionalAttributes:nn.optionalAttributes,createComputedParams:e=>e,attributes:{...nn.attributes,...dn.attributes}};class zn extends pn{constructor(){super(...arguments),this.vertexSpec=Fn}}class En extends fn{constructor(){super(...arguments),this.vertexSpec=Tn}_createOutlineWriter(e,t,s,i){return new zn(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 On={createComputedParams:e=>e,optionalAttributes:{},attributes:{pos:{type:hi.pe.SHORT,count:2,pack:"position",packPrecisionFactor:10},id:{type:hi.pe.UNSIGNED_BYTE,count:3,pack:"id"},bitset:{type:hi.pe.UNSIGNED_BYTE,count:1},offset:{type:hi.pe.BYTE,count:2,packAlternating:{count:4,pack:()=>[[-1,-1],[1,-1],[-1,1],[1,1]]}}}};class Rn extends li{constructor(){super(...arguments),this.vertexSpec=On}_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 Ln=s(48163),Dn=s(90708);class Nn{constructor(e,t,s,i,r,n,o,a,h,c,l,u=[],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=h,this.minScale=c,this.referenceBounds=l,this.bounds=u,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.layerView.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.layerView.view.featuresTilingScheme.scaleToZoom(this.minScale):0,o=this.maxScale?e.layerView.view.featuresTilingScheme.scaleToZoom(this.maxScale):25,a=this.directionX*(s+i/2),h=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+h,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(),h=e.readF32(),c=e.readF32(),l=e.readF32(),u=e.readF32(),d=e.readF32(),p=e.readF32(),f=e.readF32(),_=e.readF32(),m=X(e,Vs)??[];return new Nn(t,s,i,r,a,h,c,l,u,d,{size:p,offsetX:f,offsetY:_},m,n,o)}}function Gn(e,t,s){return e[0]=t[0]-s[0],e[1]=t[1]-s[1],e}function qn(e,t){return Math.sqrt(e*e+t*t)}function Bn(e){const t=qn(e[0],e[1]);e[0]/=t,e[1]/=t}function Wn(e,t){return qn(e[0]-t[0],e[1]-t[1])}function jn(e){return e.length-1}function Un(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 Vn{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 Vn(e,0,0,e[0][0],e[0][1])}clone(){return new Vn(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<jn(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 Yn(e,t,s,i=!0){const r=function(e){let t=0;for(let s=0;s<jn(e);s++)t+=Un(e,s);return t}(e),n=Vn.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),h=Math.floor(a/t),c=o-h*t;n.seek(c);for(let e=-h;e<=h;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 Hn(e,t){const s=t;for(let t=0;t<e.length;t++){let i=e[t];Xn(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,h=o-s;r.push([a,h])}e[t]=r,i=r}return e}function Xn(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+=Wn(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],h=e[i-1][1],c=Gn([0,0],e[0],e[1]);Bn(c),e[0][0]+=t*c[0],e[0][1]+=t*c[1],Gn(c,e[i-1],e[i-2]),Bn(c),e[i-1][0]+=t*c[0],e[i-1][1]+=t*c[1];for(let e=1;e<i;e++)r[e]+=t;r[i-1]+=t;const l=.5*t;for(let n=1;n<i-1;n++){let a=0,h=0,c=0;for(let i=n-1;i>=0&&!(r[i+1]<r[n]-l);i--){const o=l+r[i+1]-r[n],u=r[i+1]-r[i],d=r[n]-r[i]<l?1:o/u;if(Math.abs(d)<s)break;const p=d*d,f=d*o-.5*p*u,_=d*u/t,m=e[i+1],g=e[i][0]-m[0],y=e[i][1]-m[1];a+=_/f*(m[0]*d*o+.5*p*(o*g-u*m[0])-p*d*u*g/3),h+=_/f*(m[1]*d*o+.5*p*(o*y-u*m[1])-p*d*u*y/3),c+=_}for(let o=n+1;o<i&&!(r[o-1]>r[n]+l);o++){const i=l-r[o-1]+r[n],u=r[o]-r[o-1],d=r[o]-r[n]<l?1:i/u;if(Math.abs(d)<s)break;const p=d*d,f=d*i-.5*p*u,_=d*u/t,m=e[o-1],g=e[o][0]-m[0],y=e[o][1]-m[1];a+=_/f*(m[0]*d*i+.5*p*(i*g-u*m[0])-p*d*u*g/3),h+=_/f*(m[1]*d*i+.5*p*(i*y-u*m[1])-p*d*u*y/3),c+=_}o.push(a/c),o.push(h/c)}o.push(a),o.push(h);for(let t=0,s=0;t<i;t++)e[t][0]=o[s++],e[t][1]=o[s++]}class $n{constructor(e){const{offsetX:t,offsetY:s,postAngle:i,fontSize:r,haloSize:n,outlineSize:o,scaleFactor:a,transforms:h}=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=h,h&&h.infos.length>1){const e=(0,Oe.zb)(r,i,!1,t,s,h,!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 Zn=28,Qn=[4,4],Jn=[16,4],Kn={topLeft:Jn,topRight:Jn,bottomLeft:Jn,bottomRight:Jn},eo=[4,2],to=[4,6],so={topLeft:eo,topRight:eo,bottomLeft:to,bottomRight:to},io={topLeft:eo,topRight:to,bottomLeft:eo,bottomRight:to},ro={topLeft:to,topRight:to,bottomLeft:Qn,bottomRight:Qn},no={topLeft:Qn,topRight:Qn,bottomLeft:to,bottomRight:to},oo={topLeft:to,topRight:Qn,bottomLeft:to,bottomRight:Qn},ao={topLeft:Qn,topRight:to,bottomLeft:Qn,bottomRight:to},ho={createComputedParams:e=>e,optionalAttributes:{zoomRange:{type:hi.pe.UNSIGNED_SHORT,count:2,packPrecisionFactor:p.fq,packTessellation:({minZoom:e,maxZoom:t})=>[e||0,t||Zn]},clipAngle:{type:hi.pe.UNSIGNED_BYTE,count:1,packTessellation:({clipAngle:e})=>lo(e||0)},referenceSymbol:{type:hi.pe.BYTE,count:4,packPrecisionFactor:1,packTessellation:(e,t)=>{const s=e.isLineLabel||!e.referenceBounds,i=function(e){switch(e){case 1:case"right":return-1;case 0:case"center":return 0;case-1:case"left":return 1;default:return console.debug(`Found invalid horizontal alignment ${e}`),0}}(s?"center":t.horizontalAlignment),r=function(e){switch(e){case 1:case"top":return 1;case 0:case"middle":return 0;case-1:case 2:case"baseline":case"bottom":return-1;default:return console.debug(`Found invalid vertical alignment ${e}`),0}}(s?"middle":t.verticalAlignment),{offsetX:n,offsetY:o,size:a}=s?{offsetX:0,offsetY:0,size:0}:e.referenceBounds;return[(0,l.Lz)(n),-(0,l.Lz)(o),Math.round((0,l.Lz)(a)),i+1<<2|r+1]}},visibility:{type:hi.pe.FLOAT,count:1,otherSource:!0}},attributes:{pos:{type:hi.pe.SHORT,count:2,pack:"position",packPrecisionFactor:10},id:{type:hi.pe.UNSIGNED_BYTE,count:3,pack:"id"},bitset:{type:hi.pe.UNSIGNED_BYTE,count:1,packTessellation:({isBackground:e,mapAligned:t})=>_s([[0,e],[3,!!t]])},offset:{type:hi.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:hi.pe.SHORT,count:2,packPrecisionFactor:4,packAlternating:{count:4,packTessellation:({texcoords:e})=>{const{bottomLeft:t,bottomRight:s,topLeft:i,topRight:r}=e;return[i,r,t,s]}}},color:{type:hi.pe.UNSIGNED_BYTE,count:4,normalized:!0,packTessellation:({color:e})=>e},fontAndReferenceSize:{type:hi.pe.UNSIGNED_SHORT,count:4,packPrecisionFactor:4,packTessellation:({fontSize:e,sdfSize:t,sdfRadius:s},{referenceSize:i})=>[Math.round((0,l.Lz)(e)),Math.round((0,l.Lz)(i??e)),t,s]},outlineColor:{type:hi.pe.UNSIGNED_BYTE,count:4,normalized:!0,pack:({outlineColor:e})=>ms(e)},haloColor:{type:hi.pe.UNSIGNED_BYTE,count:4,normalized:!0,pack:({haloColor:e})=>ms(e)},outlineAndHaloSize:{type:hi.pe.UNSIGNED_SHORT,count:2,packPrecisionFactor:4,packTessellation:({outlineSize:e,haloSize:t})=>[Math.round((0,l.Lz)(e)),Math.round((0,l.Lz)(t))]}}};class co extends li{constructor(){super(...arguments),this.vertexSpec=ho,this._textMeshParamsPropsInitialized=!1}ensurePacked(e,t,s){super.ensurePacked(e,t,s),this._textMeshParamsPropsInitialized&&!this._evaluator.hasDynamicProperties||(this._textMeshTransformProps=new $n(this.evaluatedMeshParams),this._textMeshParamsPropsInitialized=!0)}_write(e,t,s){const i=this._getShaping();if(!i)return;const r=t.getDisplayId();if(null!=this.evaluatedMeshParams.placement)return this._writePlacedTextMarkers(e,t,i,s);if(s?.nextPath())return s.nextPoint(),this._writeGlyphs(e,r,s.x,s.y,i,0);if("esriGeometryPolygon"===t.geometryType){const s=t.readCentroidForDisplay();if(!s)return;const[n,o]=s.coords;return this._writeGlyphs(e,r,n,o,i,0)}if("esriGeometryMultipoint"===t.geometryType){const s=t.readGeometryForDisplay();return void s?.forEachVertex((t,s)=>this._writeGlyphs(e,r,t,s,i,0))}const n=t.readXForDisplay(),o=t.readYForDisplay();return this._writeGlyphs(e,r,n,o,i,0)}_writePlacedTextMarkers(e,t,s,i){const r=i??ye.z.fromFeatureSetReaderCIM(t);if(!r)return;const n=us.getPlacement(r,-1,this.evaluatedMeshParams.placement,(0,l.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),a=n.next()}}_getShaping(e){const t=this._textMeshTransformProps,s=this.evaluatedMeshParams;if(!s.glyphs?.glyphs.length)return null;const i=(0,l.Lz)(t.fontSize),r=(0,l.Lz)(t.offsetX),n=(0,l.Lz)(t.offsetY),o=s.glyphs.sdfSize,a=(0,Cs.qE)((0,l.Lz)(s.lineWidth),p.GR,p.cp),h=o/24*p.DY*(0,Cs.qE)(s.lineHeightRatio,.25,4);return ei(s.glyphs,{scale:i/o,angle:t.postAngle,xOffset:r,yOffset:n,horizontalAlignment:s.horizontalAlignment,verticalAlignment:e||s.verticalAlignment,maxLineWidth:a,lineHeight:h,decoration:s.decoration,borderLineSizePx:(0,l.Lz)(s.boxBorderLineSize),hasBackground:!!s.boxBackgroundColor,useCIMAngleBehavior:s.useCIMAngleBehavior})}_writeGlyphs(e,t,s,i,r,n,o,a,h=!0){const c=this.evaluatedMeshParams,u=this._textMeshTransformProps,d=(0,l.Lz)(u.fontSize),p=u.haloSize,f=u.outlineSize,_=(0,l.Lz)(u.offsetX),m=(0,l.Lz)(u.offsetY),{sdfSize:g,sdfRadius:y}=c.glyphs,[x,b]=ps(c.scaleInfo,this.getTileInfo());0!==n&&r.setRotation(n);const w=r.bounds,v=s+w.x+_,S=i+w.y-m,I=2*(c.minPixelBuffer?c.minPixelBuffer/d:1),P=Math.max(w.width,w.height)*I;r.textBox&&(e.recordStart(this.instanceId,this.attributeLayout,r.glyphs[0].textureBinding),h&&e.recordBounds(v,S,P,P),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),h&&e.recordBounds(v,S,P,P);const{texcoords:r,offsets:l}=n;this._writeQuad(e,t,s,i,{texcoords:r,offsets:l,fontSize:d,haloSize:p,outlineSize:f,sdfSize:g,sdfRadius:y,color:ms(c.color),isBackground:!1,referenceBounds:o,minZoom:x,maxZoom:b,...a}),e.recordEnd()}0!==n&&r.setRotation(-n)}_writeTextBox(e,t,s,i,r,n,o){const a=this.evaluatedMeshParams,{fontSize:h,haloSize:c,outlineSize:l}=this._textMeshTransformProps,{boxBackgroundColor:u,boxBorderLineColor:d}=a,{sdfSize:p,sdfRadius:f}=a.glyphs,_={isBackground:!0,fontSize:h,haloSize:c,outlineSize:l,referenceBounds:n,sdfSize:p,sdfRadius:f,...o};u&&(this._writeQuad(e,t,s,i,{texcoords:Kn,offsets:r.main,color:ms(u),..._}),d||(this._writeQuad(e,t,s,i,{texcoords:ro,offsets:r.top,color:ms(u),..._}),this._writeQuad(e,t,s,i,{texcoords:no,offsets:r.bot,color:ms(u),..._}),this._writeQuad(e,t,s,i,{texcoords:oo,offsets:r.left,color:ms(u),..._}),this._writeQuad(e,t,s,i,{texcoords:ao,offsets:r.right,color:ms(u),..._}))),d&&(this._writeQuad(e,t,s,i,{texcoords:so,offsets:r.top,color:ms(d),..._}),this._writeQuad(e,t,s,i,{texcoords:so,offsets:r.bot,color:ms(d),..._}),this._writeQuad(e,t,s,i,{texcoords:io,offsets:r.left,color:ms(d),..._}),this._writeQuad(e,t,s,i,{texcoords:io,offsets:r.right,color:ms(d),..._}))}_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 lo=e=>Math.round(e*(254/360)),uo=(0,E.Bj)(e=>{let t=0;if(0===e)return 1/0;for(;!(e%2);)t++,e/=2;return t});class po extends co{constructor(){super(...arguments),this._zoomLevel=0}_write(e,t,s,i){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":{const s=t.readCentroidForDisplay();if(!s)return;const[i,r]=s.coords;this._writePoint(e,i,r,0,t);break}case"esriGeometryMultipoint":{let s=0;const i=ye.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(),h=this.evaluatedMeshParams.scaleInfo?.maxScale??0,c=this.evaluatedMeshParams.scaleInfo?.minScale??0,l=this.evaluatedMeshParams.labelClassId;return new Nn(e,l,t,s,i,r,o,a,h,c,n)}_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,h=function(e,t,s){return(0,_e.Wm)(`${e}${t}${s}`)}(this.evaluatedMeshParams.layerId,r.getObjectId(),i),c=function(e,t,s){return(0,_e.Wm)(`${e}${t}${s}`)}(r.getObjectId(),a,i),[l,u]=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 Nn(o,a,h,c,t,s,l,u,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:ps(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,Dn.kz)(o,"esriGeometryPolyline",1)??new cr.A,h=fo(a,n),c=fo(a,-n),l=(0,Dn.zv)(c,"esriGeometryPolyline",!1,!1),u=Hn((0,Dn.zv)(h,"esriGeometryPolyline",!1,!1).paths,r.bounds.width),d=Hn(l.paths,r.bounds.width);this._current.offsetDirection="above";for(let e=0;e<u.length;e++)this._current.pathIndex=e,Yn(u[e],s,t,!!i);this._current.offsetDirection="below";for(let e=0;e<d.length;e++)this._current.pathIndex=e,Yn(d[e],s,t,!!i)}_writeCenterAlong(e,t,s){const{repeatLabel:i}=this.evaluatedMeshParams,{shaping:r}=this._current,n=Hn(e.readLegacyGeometryForDisplay().paths,r.bounds.width);for(let e=0;e<n.length;e++)this._current.pathIndex=e,Yn(n[e],s,t,!!i)}_placeSubdivGlyphs(e,t,s,i){const{allowOverrun:r,labelPosition:n,repeatLabelDistance:o,layerId:a,labelClassId:h}=this.evaluatedMeshParams,{objId:c,shaping:l,pathIndex:u}=this._current,d=this._current.zoomRange[0],p=uo(t),f=this._current.shaping.bounds.width/2,_=Math.sqrt(o||128)/2,m=Math.min(s,i-s),g=l.isMultiline?Zn:Math.log2(m/(_+f/2)),y=0===t?g:Math.min(p,g),x=Math.max(d,this._zoomLevel+1-y),b=this._zoomLevel-x,w=l.bounds.width/2*2**b,v=function(e,t,s,i,r){return(0,_e.Wm)(`${e}${t}${s}${i*2**(Zn-r)}`)}(a,c,u,t,this._zoomLevel),S=function(e,t,s,i,r){return(0,_e.Wm)(`${e}${r}${t}${s*2**(Zn-i)}`)}(c,u,t,this._zoomLevel,h);this._current.shaping.isMultiline?0===t&&this._placeStraight(e,x,v,S):r&&b<0?this._placeStraightAlong(e,d,v,S):"parallel"===n?this._placeStraightAlong(e,x,v,S):"curved"===n&&this._placeCurved(e,x,w,v,S)}_placeStraight(e,t,s,i){const{out:r,id:n,shaping:o,referenceBounds:a}=this._current,{x:h,y:c}=e;r.metricStart(this._createLineLabelMetric(n,s,i,h,c)),r.metricBoxWrite(o.boundsT);const l=e.angle*(180/Math.PI)%360,u=(e.angle*(180/Math.PI)+180)%360;if(!this._verticalPlacement||this._verticalPlacement===this._current.offsetDirection){const e={clipAngle:l,mapAligned:!0,isLineLabel:!0,minZoom:t};this._writeGlyphs(r,n,h,c,o,0,a,e,!1)}if(!this._verticalPlacement||this._verticalPlacement!==this._current.offsetDirection){const e={clipAngle:u,mapAligned:!0,isLineLabel:!0,minZoom:t};this._writeGlyphs(r,n,h,c,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(),h=e.angle*(180/Math.PI)%360,c=(e.angle*(180/Math.PI)+180)%360;this._verticalPlacement&&this._verticalPlacement!==this._current.offsetDirection||(this._placeFirst(a,t,1,h),this._placeBack(e,a,t,s,1,h),this._placeForward(e,a,t,s,1,h)),this._verticalPlacement&&this._verticalPlacement===this._current.offsetDirection||(this._placeFirst(a,t,0,c),this._placeBack(e,a,t,s,0,c),this._placeForward(e,a,t,s,0,c)),n.metricEnd()}_placeStraightAlong(e,t,s,i){const{out:r,id:n,shaping:o,zoomRange:a,referenceBounds:h}=this._current,{boxBorderLineColor:c,boxBackgroundColor:u}=this.evaluatedMeshParams,d=e.clone(),p=e.angle*(180/Math.PI)%360,f=(e.angle*(180/Math.PI)+180)%360,_=o.glyphs.length>0&&!(!c&&!u);if(r.metricStart(this._createLineLabelMetric(n,s,i,e.x,e.y)),_){const s=Math.max(t,a[0],0),i=Math.min(Zn,a[1]),c=Ls(qs(),-e.angle),u={minZoom:s,maxZoom:i,clipAngle:p,mapAligned:!0,isLineLabel:!0},d=(0,l.Lz)(this.evaluatedMeshParams.offsetX),_=(0,l.Lz)(this.evaluatedMeshParams.offsetY);if(!this._verticalPlacement||this._verticalPlacement===this._current.offsetDirection){const t=(0,js.fA)(d,-1*_),[s,i]=o.shapeBackground(Rs(qs(),c,t));r.recordStart(this.instanceId,this.attributeLayout,o.glyphs[0].textureBinding),this._writeTextBox(r,n,e.x,e.y,i,h,u),r.recordEnd()}if(!this._verticalPlacement||this._verticalPlacement!==this._current.offsetDirection){const t=(0,js.fA)(d,_),[s,i]=o.shapeBackground(Rs(qs(),c,t));u.clipAngle=f,r.recordStart(this.instanceId,this.attributeLayout,o.glyphs[0].textureBinding),this._writeTextBox(r,n,e.x,e.y,i,h,u),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:h,referenceBounds:c}=this._current,u=a.glyphs,d=(0,l.Lz)(this.evaluatedMeshParams.offsetX),p=(0,l.Lz)(this.evaluatedMeshParams.offsetY),f=(0,js.fA)(d,p),_=Ls(qs(),-e.angle);(0,L.l0)(f,f,_);for(const l of u){const u=l.x>a.bounds.x?s:1-s,d=u*e.remainingLength+(1-u)*e.backwardLength,p=Math.abs(l.x+l.width/2-a.bounds.x),_=Math.max(0,this._zoomLevel+Math.log2(p/(d+0))),m=Math.max(t,r?0:_);if(l.maxZoom=Math.min(h[1],Zn),l.angle=e.angle+(1-s)*Math.PI,l.minZoom=Math.max(h[0],m),this._writeLineGlyph(n,o,e.x,e.y,l,i,c,!0),(s||this._current.offsetDirection)&&this._isVisible(l.minZoom,l.maxZoom)){const e=new Vs(l.bounds.x+f[0],l.bounds.y+f[1],l.bounds.width,l.bounds.height);n.metricBoxWrite(e)}}}_placeOnSegment(e,t,s,i,r,n,o){const{out:a,id:h,shaping:c,referenceBounds:u}=this._current,d=c.glyphs,p=e.dx/e.length,f=e.dy/e.length,_={x:e.x+s*-r*p,y:e.y+s*-r*f},m=(0,l.Lz)(this.evaluatedMeshParams.offsetX),g=(0,l.Lz)(this.evaluatedMeshParams.offsetY),y=(0,js.fA)(m,g),x=Ls(qs(),-e.angle);(0,L.l0)(y,y,x);for(const t of d){const l=t.x>c.bounds.x?n:1-n;if(!(l&&1===r||!l&&-1===r))continue;const d=Math.abs(t.x+t.width/2-c.bounds.x),p=Math.max(0,this._zoomLevel+Math.log2(d/s)-.1),f=Math.max(i,this._zoomLevel+Math.log2(d/(s+e.length+0)));if(0!==p&&(t.angle=e.angle+(1-n)*Math.PI,t.minZoom=f,t.maxZoom=p,this._writeLineGlyph(a,h,_.x,_.y,t,o,u,!0),(n||this._current.offsetDirection)&&this._isVisible(t.minZoom,t.maxZoom))){const e=new Vs(t.bounds.x+y[0],t.bounds.y+y[1],t.bounds.width,t.bounds.height);a.metricBoxWrite(e)}}}_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:h,offsets:c}=r,{fontSize:l,haloSize:u,outlineSize:d}=this._textMeshTransformProps,{sdfSize:f,sdfRadius:_}=this.evaluatedMeshParams.glyphs;this._writeQuad(e,t,s,i,{sdfSize:f,sdfRadius:_,texcoords:h,offsets:c,fontSize:l,haloSize:u,outlineSize:d,color:ms(this.evaluatedMeshParams.color),isBackground:!1,referenceBounds:o,minZoom:Math.max(this._current.zoomRange[0],r.minZoom),maxZoom:Math.min(this._current.zoomRange[1],r.maxZoom),clipAngle:n,mapAligned:a,isLineLabel:!0}),e.recordEnd()}_packedZoom(e){return Math.floor(e*p.fq)/p.fq}_isVisible(e,t){let s=Math.max(this._current.zoomRange[0],e),i=Math.min(this._current.zoomRange[1],t);s=this._packedZoom(s),i=this._packedZoom(i);const r=this._packedZoom(this._zoomLevel);return s<=r&&r<=i}}function fo(e,t){const s=new cr.A,{coords:i,lengths:r}=e,n=(0,Ln.vt)(),o=(0,Ln.vt)(),a=(0,Ln.vt)(),h=(0,Ln.vt)(),c=(0,Ln.vt)(),l=(0,Ln.vt)();let u=0;for(let e=0;e<r.length;e++){const d=r[e];for(let e=0;e<d;e++){const r=2*(e+u-1),p=2*(e+u),f=2*(e+u+1);e>0?(0,L.hZ)(n,i[r],i[r+1]):(0,L.hZ)(n,0,0),(0,L.hZ)(o,i[p],i[p+1]),e<d-1?(0,L.hZ)(a,i[f],i[f+1]):(0,L.hZ)(a,0,0),0===e?(0,L.hZ)(h,0,0):((0,L.jb)(h,o,n),(0,L.S8)(h,h),(0,L.hZ)(h,h[1],-h[0])),e===d-1?(0,L.hZ)(c,0,0):((0,L.jb)(c,a,o),(0,L.S8)(c,c),(0,L.hZ)(c,c[1],-c[0])),(0,L.WQ)(l,h,c),(0,L.S8)(l,l);const _=l[0]*c[0]+l[1]*c[1];0!==_&&(0,L.hs)(l,l,_),(0,L.hs)(l,l,t),s.coords.push(o[0]+l[0],o[1]+l[1])}s.lengths.push(d),u+=d}return s}const _o={createComputedParams:e=>e,optionalAttributes:Vr.optionalAttributes,attributes:{...Vr.attributes,bitset:{type:hi.pe.UNSIGNED_BYTE,count:1,pack:({gradientMethod:e,gradientSizeUnits:t,gradientType:s})=>_s([[0,"alongline"===e.toLowerCase()],[1,t===wn.h.Absolute],[2,"discrete"===s.toLowerCase()]])},tlbr:{type:hi.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:hi.pe.HALF_FLOAT,count:1,packTessellation:({distance:e,pathLength:t,distanceOffset:s})=>(s+e)/t},gradientSize:{type:hi.pe.HALF_FLOAT,count:1,pack:({gradientSize:e,gradientSizeUnits:t})=>t===wn.h.Relative?e/100:(0,l.Lz)(e)},totalLength:{type:hi.pe.HALF_FLOAT,count:1,packTessellation:({pathLength:e})=>e},segmentDirection:{type:hi.pe.BYTE,count:2,packPrecisionFactor:16,packTessellation:({directionX:e,directionY:t})=>[e,t]}}};class mo extends Xr{get _preventEffectClipping(){return!0}constructor(e,t,s,i){super(e,t,s,i),this.vertexSpec=_o,this._tessellationOptions.textured=!0}_write(e,t,s){const i=s??ye.z.fromFeatureSetReaderCIM(t);if(!i)return;const{sprite:r}=this.evaluatedMeshParams;this._writeGeometry(e,t,i,r?.textureBinding)}}const go={createComputedParams:e=>e,optionalAttributes:Vr.optionalAttributes,attributes:{...Vr.attributes,bitset:{type:hi.pe.UNSIGNED_BYTE,count:1,pack:({shouldSampleAlphaOnly:e,shouldScaleDash:t,isSDF:s})=>_s([[4,e],[2,t],[3,s]])},tlbr:{type:hi.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:hi.pe.UNSIGNED_SHORT,count:1,packTessellation:({distance:e})=>e},segmentDirection:{type:hi.pe.BYTE,count:2,packPrecisionFactor:16,packTessellation:({directionX:e,directionY:t})=>[e,t]},offsetAlongLine:{type:hi.pe.HALF_FLOAT,count:1,pack:({offsetAlongLine:e})=>(0,l.Lz)(e)},capType:{type:hi.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 yo extends Xr{constructor(e,t,s,i){super(e,t,s,i),this.vertexSpec=go,this._tessellationOptions.textured=!0}_write(e,t,s){const i=s??ye.z.fromFeatureSetReaderCIM(t);if(!i)return;const{sprite:r}=this.evaluatedMeshParams;this._writeGeometry(e,t,i,r?.textureBinding)}}class xo{static from(e){return"width"in e?this.fromSimpleMeshParams(e):this.fromComplexMeshParams(e)}static fromSimpleMeshParams(e){const t=new xo(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:h,sprite:c,overrideOutlineColor:u}=e;return t.rawWidth=(0,l.Lz)(i),t.rawHeight=(0,l.Lz)(r),t.angle=n,t.alignment=o,t.outlineSize=(0,l.Lz)(a),t.referenceSize=(0,l.Lz)(h),t.overrideOutlineColor=u,t.offsetX=(0,l.Lz)(e.offsetX),t.offsetY=(0,l.Lz)(e.offsetY),"simple"!==s||c.sdf||(t.rawWidth=c.width,t.rawHeight=c.height),t._computeSize(e,!1),t}static fromComplexMeshParams(e){const t=new xo(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:h,colorLocked:c,frameHeight:u,widthRatio:d,offsetX:p,offsetY:f,outlineSize:_,referenceSize:m,scaleFactor:g,sizeRatio:y,isAbsoluteAnchorPoint:x,rotateClockwise:b,scaleSymbolsProportionally:w,sprite:v}=e;if(i&&i.infos.length>0){const e=(0,Oe.zb)(r,h,b,p,f,i);r=e.size,h=e.rotation,p=e.offsetX,f=e.offsetY,b=!1}g&&(r*=g,p*=g,f*=g);const S=n*(v.width/v.height);t.alignment=s,t.rawHeight=(0,l.Lz)(r),t.rawWidth=t.rawHeight*S,t.referenceSize=(0,l.Lz)(m),t.sizeRatio=y,t.sdfDecodeCoeff=(v.sdfDecodeCoeff??1)*y,t.angle=h,t.rotateClockwise=b,t.anchorX=o,t.anchorY=a,t.offsetX=(0,l.Lz)(p),t.offsetY=(0,l.Lz)(f),x&&r&&(v.sdf?t.anchorX=o/(r*d):t.anchorX=o/(r*S),t.anchorY=a/r);const I=w&&u?r/u:1;return t.outlineSize=0===_||isNaN(_)?0:(0,l.Lz)(_)*I,t.scaleSymbolsProportionally=w,t.colorLocked=c,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:h,outlineSize:c}=this,l=s.rect;let u=o*h,d=a*h,f=0,_=0;if(r){const e=1/(1-n);if(u*=e,d*=e,i)this.computedWidth=u,this.computedHeight=d;else{const e=t&&o>a?u:o,i=a,r=c+2;this.computedWidth=Math.min(e+r,u),this.computedHeight=Math.min(i+r,d);const n=Math.max(s.width,s.height)/Math.max(u,d);f=(this.computedWidth-u)*n,_=(this.computedHeight-d)*n}}else this.computedWidth=u*(l.width/s.width),this.computedHeight=d*(l.height/s.height),f=2*p.hM,_=2*p.hM;const m=l.x+p.hM-f/2,g=l.y+p.hM-_/2,y=m+s.width+f,x=g+s.height+_;this.texXmin=bo(m),this.texYmin=bo(g),this.texXmax=wo(y),this.texYmax=wo(x),this.computedWidth*=(this.texXmax-this.texXmin)/(y-m),this.computedHeight*=(this.texYmax-this.texYmin)/(x-g),this.anchorX*=u/this.computedWidth,this.anchorY*=d/this.computedHeight}}function bo(e,t=1e-7){const s=Math.ceil(e);return s-e<t?s:Math.floor(e)}function wo(e,t=1e-7){const s=Math.floor(e);return e-s<t?s:Math.ceil(e)}const vo=128/Math.PI;const So={createComputedParams:e=>xo.from(e),optionalAttributes:{zoomRange:{type:hi.pe.SHORT,count:2,packPrecisionFactor:p.fq,pack:({scaleInfo:e},{tileInfo:t})=>ps(e,t)}},attributes:{pos:{type:hi.pe.SHORT,count:2,pack:"position",packPrecisionFactor:10},id:{type:hi.pe.UNSIGNED_BYTE,count:3,pack:"id"},bitset:{type:hi.pe.UNSIGNED_BYTE,count:1,pack:({sprite:e,alignment:t,scaleSymbolsProportionally:s,overrideOutlineColor:i,colorLocked:r})=>{let n=0;return e.sdf&&(n|=fs(ws)),1===t&&(n|=fs(vs)),s&&(n|=fs(Ss)),i&&(n|=fs(Is)),r&&(n|=fs(Ps)),n}},offset:{type:hi.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 h=function(e,t,s,i,r=!1){const n=qs(),o=r?1:-1;return zs(n),(t||s)&&Rs(n,n,[t,-s]),i&&Os(n,n,.017453292519944444*o*-i),n}(0,n,o,-e,a),c=-(.5+i)*t,l=-(.5-r)*s,u=[c,l],d=[c+t,l],p=[c,l+s],f=[c+t,l+s];return(0,L.l0)(u,u,h),(0,L.l0)(d,d,h),(0,L.l0)(p,p,h),(0,L.l0)(f,f,h),[u,d,p,f]}}},textureUV:{type:hi.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:hi.pe.UNSIGNED_BYTE,count:4,normalized:!0,pack:({color:e})=>ms(e)},outlineColor:{type:hi.pe.UNSIGNED_BYTE,count:4,normalized:!0,pack:({outlineColor:e})=>ms(e)},sizing:{type:hi.pe.UNSIGNED_BYTE,count:4,pack:({rawWidth:e,rawHeight:t,outlineSize:s,referenceSize:i})=>[xs(Math.max(e,t),128),xs(s,128),xs(i,128),0]},placementAngle:{type:hi.pe.UNSIGNED_BYTE,count:1,packTessellation:({placementAngle:e})=>function(e){return function(e){return e%=256,Math.abs(e>=0?e:e+256)}(e*vo)}(e)},sdfDecodeCoeff:{type:hi.pe.UNSIGNED_SHORT,count:1,packPrecisionFactor:64,pack:({sdfDecodeCoeff:e})=>e}}};class Io extends li{constructor(){super(...arguments),this.vertexSpec=So}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),h=-this.evaluatedMeshParams.anchorX*this.evaluatedMeshParams.computedWidth,c=this.evaluatedMeshParams.anchorY*this.evaluatedMeshParams.computedHeight,l=this.evaluatedMeshParams.offsetX+h,u=-this.evaluatedMeshParams.offsetY+c;if(null!=this.evaluatedMeshParams.placement){let i=null;if(null!=s&&(i=Ye(s,2*Math.max(this.evaluatedMeshParams.computedWidth,this.evaluatedMeshParams.computedHeight),!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+l,i+u,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+l,n+u,o,a),this._writeQuad(e,r,i,n)}else if("esriGeometryPoint"===t.geometryType){const s=t.readXForDisplay(),i=t.readYForDisplay();e.recordBounds(s+l,i+u,o,a),this._writeQuad(e,r,s,i)}else{const s=t.readGeometryForDisplay();s?.forEachVertex((t,s)=>{e.recordBounds(t+l,s+u,o,a),Math.abs(t)>be||Math.abs(s)>be||this._writeQuad(e,r,t,s)})}e.recordEnd()}_writePlacedMarkers(e,t,s,i,r){const n=s??ye.z.fromFeatureSetReaderCIM(t);if(!n)return;const o=us.getPlacement(n,-1,this.evaluatedMeshParams.placement,(0,l.Lz)(1),e.id);if(!o)return;const a=t.getDisplayId();let h=o.next();const c=this.evaluatedMeshParams.offsetX,u=-this.evaluatedMeshParams.offsetY;for(;null!=h;){const t=h.tx,s=-h.ty;if(Math.abs(t)>be||Math.abs(s)>be){h=o.next();continue}const n=-h.getAngle();e.recordBounds(t+c,s+u,i,r),this._writeQuad(e,a,t,s,n),h=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 Po=s(4576),Mo=s(55674);class ko{destroy(){}}class Co extends ko{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 Ao=()=>Rt.A.getLogger("esri.views.2d.engine.webgl.shaderGraph.techniques.mesh.MeshWriterInputEvaluator");async function To(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 Co(o),defaultValue:r}}async function Fo(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 zo(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 Eo(e){if(Array.isArray(e))for(const t of e)if(Eo(t))return!0;if("object"==typeof e){if(zo(e))return!0;for(const t in e)if(Eo(e[t]))return!0}return!1}class Oo{static async create(e,t,s,i){const r={},n=new Map,o=new Map,a=new Map,h=new Map,c=new Map,l=new Map;for(const u in s){const d=s[u];if(null!=d&&"object"==typeof d)if(Array.isArray(d)){if("object"==typeof d[0])throw new Error(`InternalError: Cannot handle ${u}. Nested array params are not supported`);r[u]=d}else{if("valueExpressionInfo"in d){if(d.value){r[u]=d.value;continue}const t=await Fo(e,d,i);if(!t){r[u]=d.defaultValue;continue}n.set(u,t),r[u]=null;continue}switch(d.type){case"cim-effect-infos":if(d.effectInfos.some(e=>e.overrides.length)){o.set(u,{effects:await Promise.all(d.effectInfos.map(async t=>{const s=t.overrides.map(t=>To(e,t,i,!1));return{effect:t.effect,compiledOverrides:(await Promise.all(s)).filter(Po.Ru)}}))});break}r[u]=d.effectInfos.map(e=>e.effect);break;case"cim-marker-placement-param":d.overrides.length&&a.set(u,{placementInfo:d,compiledOverrides:(await Promise.all(d.overrides.map(t=>To(e,t,i,!1)))).filter(Po.Ru)}),r[u]=d.placement;break;case"text-rasterization-param":{if(d.overrides.length){const t=d.overrides.map(t=>To(e,t,i,d.useLegacyLabelEvaluationRules??!1));h.set(u,{compiledOverrides:(await Promise.all(t)).filter(Po.Ru),rasterizationParam:d,objectIdToResourceId:new Map});continue}const s={type:"cim-rasterization-info",resource:d.resource};r[u]=await t.fetchResourceImmediate(s)??null;break}case"sprite-rasterization-param":{if(d.overrides.length){const t=d.overrides.map(t=>To(e,t,i,!1));h.set(u,{compiledOverrides:(await Promise.all(t)).filter(Po.Ru),rasterizationParam:d,objectIdToResourceId:new Map});continue}if("animated"===d.resource.type){h.set(u,{compiledOverrides:[],rasterizationParam:d,objectIdToResourceId:new Map});continue}const s={type:"cim-rasterization-info",resource:d.resource};r[u]=await t.fetchResourceImmediate(s)??null;break}case"cim-marker-transform-param":{const{params:t}=d;if(Eo(t)){const s={compiledMarkerInfos:[]};await Promise.all(t.map(async t=>{const r={props:{}};for(const s in t)if(zo(t[s])){const n=await Fo(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)})),c.set(u,s)}else r[u]={type:"cim-marker-transform-info",infos:t};break}case"animation-params":{const{params:s}=d,i=Ei(s);if(Eo(i)){const t=await Promise.all(i.map(t=>Ri(t,e)));l.set(u,{params:t,propertyIdToResourceId:new Map,key:u})}else{const e=zi(i),s=await t.fetchResourceImmediate({type:"animation-info",resource:e});null!=s&&"sprite"===s.type&&(r[u]={dataRow:s.rect.y,dataColumn:s.rect.x})}break}default:r[u]=d}}else r[u]=d}return new Oo(s,r,n,o,a,h,c,l)}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,Mo.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,ks.o8)(r.rasterizationParam.resource);"animated"===r.rasterizationParam.resource.type&&r.rasterizationParam.resource.randomizeStartTime&&(n.primitiveName="__RESERVED__PRIMITIVE__NAME__",n.startGroup=pi(t.getObjectId()||0));for(const{primitiveName:e,propertyName:o,computed:a,defaultValue:h,valueExpressionInfo:c}of r.compiledOverrides)try{const i="animated"===r.rasterizationParam.resource.type?n.primitiveName:e;(0,jr.Ph)(n,i,o,a,t,s,h)}catch(e){Ao().errorOnce(new i.A("invalid-arcade-expression","Encountered an error when evaluating the arcade expression",{error:e,valueExpressionInfo:c}))}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=>Li(e,t,s)).map(Pi).map(e=>e.simplify()),n=Oi(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*Di(t)}}const Ro={createComputedParams:e=>e,optionalAttributes:{},attributes:{pos:{type:hi.pe.SHORT,count:2,packPrecisionFactor:10,pack:"position"},id:{type:hi.pe.UNSIGNED_BYTE,count:3,pack:"id"},bitset:{type:hi.pe.UNSIGNED_BYTE,count:1,pack:e=>0},offset:{type:hi.pe.SHORT,count:2,packPrecisionFactor:16,packAlternating:{count:4,pack:({size:e})=>{const t=(0,l.Lz)(e),s=-t/2,i=-t/2;return[[s,i],[s+t,i],[s,i+t],[s+t,i+t]]}}},texCoords:{type:hi.pe.SHORT,count:2,packPrecisionFactor:4,packAlternating:{count:4,pack:()=>[[0,1],[1,1],[0,0],[1,0]]}},size:{type:hi.pe.UNSIGNED_BYTE,count:2,pack:({size:e})=>[e,e]},referenceSize:{type:hi.pe.UNSIGNED_BYTE,count:1,pack:({size:e})=>(0,l.Lz)(e)},zoomRange:{type:hi.pe.UNSIGNED_BYTE,count:2,pack:({scaleInfo:e},{tileInfo:t})=>ps(e,t)}}};class Lo extends li{constructor(){super(...arguments),this.vertexSpec=Ro}_write(e,t){const s=t.getDisplayId(),i=this.evaluatedMeshParams.minPixelBuffer,r=Math.max((0,l.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 Do{async createMeshWriter(e,t,s,i,r){const n=this._getMeshWriter(i.techniqueType),o=await Oo.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 14:return rn;case 12:return tn;case 10:return ln;case 27:return on;case 15:return An;case 25:return fn;case 28:return En;case 11:return bn;case 22:return Io;case 29:return Lo;case 31:return co;case 20:return Xr;case 32:return yo;case 16:return mo;case 18:return Rn;case 19:return po;case 2:return nr;case 3:return or;case 0:return Zr;case 1:return Jr;default:throw new Error("Internal Error: Mesh writer not in the registry")}}}class No{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 Go=s(563);class qo{constructor(e){this._outstandingMessages=[],this._queue=new Go.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 Bo=s(43334),Wo=s(31464),jo=s(95466);class Uo{static async create(e,t){if("count"===t.statisticType){const e=new Co(1);return new Uo(t.name,t.alias,t.type,t.statisticType,e)}const s=await e.createComputedField({expression:t.onStatisticExpression?.expression,field:t.onStatisticField});return new Uo(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 Vo=s(65529),Yo=s(70328),Ho=s(37730),Xo=s(56390);class $o{constructor(e){this.subscription=e,this.handledChunks=new Set}destroy(){}}class Zo{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}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 Qo extends Zo{constructor(e,t,s,i,r){super(e,t,r),this.spatialReference=s,this.aggregateFields=i,this._arcadeDependencies=new Set,this.events=new Vo.bk,this.featureAdapter=Ho.T;for(const e of i)(0,Mo.QY)(this._arcadeDependencies,e.computed)}get aggregateQueryEngine(){return this._aggregateQueryEngine||(this._aggregateQueryEngine=new Xo.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,Yo.vt)();for(const i of e){const e=(0,Dn.jQ)(s,i.geometry);e&&t(e)}}}class Jo{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 Ko{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 ea=8388607,ta=e=>e&ea;class sa extends ko{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 ia=s(50115);class ra extends ko{static async create(e,t){const s=await(0,Mo.Ad)(e,t.spatialReference),i=(0,_e.Wm)(e);return new ra(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,ia.V4)(this._compiled,e,t):this._readCached(e,t)}readWithDefault(e,t,s){return this.hasArcadeDependency("scale")||"system"!==t.$view.timeZone?(0,ia.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,ia.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,ia.OP)(this._compiled,e,t,s);return e.setCachedValue(i),i}}var na=s(97770),oa=s(18047),aa=s(68463),ha=s(30524),ca=s(32730);class la extends ko{static async create(e,t){const s=(0,ca.lc)(e);return new la(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,aa.A5)(t),n=+e;if(null!=r&&null!=i&&r<=n&&n<=i)return s.name}let i=e;return(0,ha.vE)(t)?i=(0,na.Yq)(i,(0,na.J2)("short-date")):(0,ha.WA)(t)&&(i=(0,oa.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,ia.rZ)(i)?s:i}hasArcadeDependency(e){return!1}}class ua extends ko{constructor(e,t){super(),this._template=e,this._parts=(0,Oe.gQ)(e.template,t)}resize(e){}read(e,t){return(0,Oe._h)(e,this._parts,this._template.textCase)}readWithDefault(e,t,s){return(0,Oe._h)(e,this._parts,this._template.textCase)}hasArcadeDependency(e){return!1}}class da extends ko{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 pa=s(73250),fa=s(39516);const _a=()=>Rt.A.getLogger("esri.views.2d.layers.FeatureLayerView2D"),ma={getAttribute:(e,t)=>e.readAttribute(t)};async function ga(e,t){try{const s=await(0,fa.GP)(e,t);return s.isStandardized||_a().error(new i.A("sql-parse-error","expression is not standardized",{where:e})),(t,r)=>{const n=t.readArcadeFeature();try{return s.testFeatureCompiled(n,ma,r.currentUser)}catch(t){return _a().warn(new i.A("sql-runtime-error","Encountered an error when evaluating where clause",{where:e,error:t})),!0}}}catch(t){return _a().warn(new i.A("sql-runtime-error","Encountered an error when evaluating where clause",{where:e,error:t})),e=>!0}}const ya=()=>Rt.A.getLogger("esri.views.2d.layers.features.support.ComputedAttributeStorage"),xa=4294967295;function ba(e,t,s){if(!(e.length>t))for(;e.length<=t;)e.push(s)}class wa{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(pa.y.create(this._allocatedSize,ea)),e+1}createDictionaryTemplateField(e,t){return new ua(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 la.create(e.expression,this.compilationOptions):await ra.create(e.expression,this.compilationOptions)}catch(t){const s=new i.A("featurelayer","Failed to compile arcade expression",{error:t,expression:e.expression});return ya().error(s),null}if(e.normalizationType||e.normalizationField)return new da(e.field,e);if(e.field)return new sa(e.field);const s=new i.A("featurelayer","Unable to create computed field. No expression or field found",{info:e});return ya().error(s),null}async createWhereClause(e){return e?ga(e,this.compilationOptions.fields):null}getBitset(e){return this._bitsets[e-1]}getComputedNumeric(e,t){return this.getComputedNumericAtIndex(e&ea,0)}setComputedNumeric(e,t,s){return this.setComputedNumericAtIndex(e&ea,s,0)}getComputedString(e,t){return this.getComputedStringAtIndex(e&ea,0)}setComputedString(e,t,s){return this.setComputedStringAtIndex(e&ea,0,s)}getComputedNumericAtIndex(e,t){const s=e&ea;return this._ensureNumeric(t,s),this._numerics[t][s]}setComputedNumericAtIndex(e,t,s){const i=e&ea;this._ensureNumeric(t,i),this._numerics[t][i]=s}getPackedChunkId(e){const t=e&ea;return this._ensureInstanceId(t),this._instanceIds[t]}setPackedChunkId(e,t){const s=e&ea;this._ensureInstanceId(s),this._instanceIds[s]=t}getComputedStringAtIndex(e,t){const s=e&ea;return this._ensureString(t,s),this._strings[t][s]}setComputedStringAtIndex(e,t,s){const i=e&ea;this._ensureString(t,i),this._strings[t][i]=s}getXMin(e){return this._bounds[4*(e&ea)]}getYMin(e){return this._bounds[4*(e&ea)+1]}getXMax(e){return this._bounds[4*(e&ea)+2]}getYMax(e){return this._bounds[4*(e&ea)+3]}setBounds(e,t,s=!1){const i=e&ea;if(!s&&!this._dirtyBitset.has(e))return this._bounds[4*i]!==xa;this._dirtyBitset.unset(e);const r=t.readGeometryWorldSpace();if(ba(this._bounds,4*i+4,0),!r||!r.coords.length)return this._bounds[4*i]=xa,this._bounds[4*i+1]=xa,this._bounds[4*i+2]=xa,this._bounds[4*i+3]=xa,!1;let n=1/0,o=1/0,a=-1/0,h=-1/0;return r.forEachVertex((e,t)=>{n=Math.min(n,e),o=Math.min(o,t),a=Math.max(a,e),h=Math.max(h,t)}),this._bounds[4*i]=n,this._bounds[4*i+1]=o,this._bounds[4*i+2]=a,this._bounds[4*i+3]=h,!0}getBounds(e,t){const s=this.getXMin(t),i=this.getYMin(t),r=this.getXMax(t),n=this.getYMax(t);return(0,Yo.BI)(e,s,i,r,n),s!==xa}_ensureNumeric(e,t){this._numerics[e]||(this._numerics[e]=[]),ba(this._numerics[e],t,0)}_ensureInstanceId(e){ba(this._instanceIds,e,0)}_ensureString(e,t){this._strings[e]||(this._strings[e]=[]),ba(this._strings[e],t,null)}}var va=s(58727),Sa=s(62660),Ia=s(86420),Pa=s(61956),Ma=s(30661);class ka{constructor(e){this._geometryBounds=(0,V.vt)(),this._idToVisibility=new Map,this._serviceInfo=e}static async create(e){const t=new ka(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 Pa.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,va.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 ga(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,Sa.xt)(s,t,this._serviceInfo.geometryType);(0,ht.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 Rt.A.getLogger("esri.views.2d.layers.features.controllers.FeatureFilter").error(t)}this.timeExtent=e.timeExtent,this._timeOperator=(0,Ia.I)(this._serviceInfo.timeInfo,e.timeExtent,Ma.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 Ca=s(35258),Aa=s(8446);class Ta extends $o{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,Dn.aQ)(t.geometry,this.subscription.tile.transform),yield t}}}class Fa extends Qo{static async create(e,t,s,i,r){const n=t.metadata.outSpatialReference,o=new wa({spatialReference:n}),a=await Promise.all(e.fields.map(async e=>Uo.create(o,e))),h=e.featureFilter?await ka.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,Wo.Nk)(n,ze.A.WGS84),new Fa(e,h,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=Ca.i.createFeature({geometryType:"esriGeometryPolygon",featureIdInfo:{type:"object-id",fieldName:"aggregateId"},fieldsIndex:new jo.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 Ta(e,this._attributeStore)}async*applyOverrideUpdate(e){for(const e of this._sendStates.values()){e.reset();const t=new Jo(e.subscription,Aa.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,Dn.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 x.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=[],h=i.tile.transform,c=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,h);t=new Bo.Om(s,e.getAttributes(),null,e.id),s||(t.centroid=e.getGeometricCentroid(this.spatialReference,h)),t.displayId=this._attributeStore.createDisplayIdForObjectId(`${t.objectId}.${c}`),n.set(e.id,t)}a.push(t)}this.events.emit("changed"),e.done=!t.updateTracking.updating;const l=Aa.K.fromOptimizedFeatures(a,this._metadata,h),u=l.getCursor(),d=e.subscription.tile.createArcadeEvaluationOptions(this._arcadeContextInfo);for(;u.next();)this._attributeStore.setAttributeData(u.getDisplayId(),u,d,this._sqlOptions);const p=new Ko(e.subscription,l,[],e.done,{});yield p}}var za=s(75538),Ea=s(68974);class Oa{constructor(e,t){this.inner=e,this.displayId=t}}class Ra extends $o{constructor(e){super(e),this.didSend=!1,this.done=!1}}class La{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 Bo.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 x.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,Ea.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),h=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,h)}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,h=1===e.inner.count?e.inner.firstObjectId:e.inner.id,c=e.displayId;if(null!=a)if(1===a){const s=new cr.A([],[t,n]),r=new Bo.Om(s,e.inner.getAttributes(),null,h,c);r.geometry.coords[0]-=p.CQ,i.push(r);const o=new cr.A([],[t,n]),a=new Bo.Om(o,e.inner.getAttributes(),null,h,c);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 cr.A([],[t,n]),r=new Bo.Om(s,e.inner.getAttributes(),null,h,c);i.push(r)}}return Aa.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,Ea.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 Oa(s.clone(),t);n.add(s.id),this._clusters.set(s.id,o);const a=s.centroidXWorld,h=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(za.L.createId(t,e));if(!r||n.has(r.id))continue;const c=Math.abs(r.centroidXWorld-a),l=Math.abs(r.centroidYWorld-h);c<i&&l<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 Da extends Qo{static async create(e,t,s,i,r,n){const o=s.metadata.outSpatialReference,a=new wa({spatialReference:o}),h={type:"grid",fields:await Promise.all(t.fields.map(async e=>Uo.create(a,e))),spatialReference:o,featureFilter:t.featureFilter?await ka.create({geometryType:s.metadata.geometryType,hasM:!1,hasZ:!1,timeInfo:s.metadata.timeInfo,fieldsIndex:s.metadata.fieldsIndex,spatialReference:o,filterJSON:t.featureFilter}):null,cellSize:t.clusterRadius/4,arcadeContextInfo:r,sqlOptions:n};return new Da(e,t.clusterRadius,h,t.fields,s,i,n)}constructor(e,t,s,i,r,n,o){super(r,n,s.spatialReference,s.fields,o),this._connection=e,this._clusterRadius=t,this._indexOptions=s,this._cellsPerScale=new Map,this._metadata=Ca.i.createFeature({geometryType:"esriGeometryPoint",featureIdInfo:{type:"object-id",fieldName:"aggregateId"},fieldsIndex:new jo.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()}onSubscribe(e){super.onSubscribe(e),this._requiredLevel=e.tile.level,this._requiredScale=e.tile.scale}createState(e){return new Ra(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,Dn.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 La(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 Jo(e.subscription,i,!0,e.done,{});yield o}}var Na=s(5162),Ga=s(9012);class qa extends $o{}class Ba extends Zo{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,Ga.N)(this._evalOptions.$view.scale,e))}onSubscribe(e){super.onSubscribe(e),this._evalOptions=e.tile.createArcadeEvaluationOptions(this._arcadeContextInfo)}createState(e){return new qa(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=Aa.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=Na.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 Ko(e.subscription,null,t,!1,r.queryInfo);for(const e of this._sendStates.values()){const t=r.getTileReader(e.subscription.tile);yield new Ko(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 Jo(e.subscription,n,!1,i.end,i.queryInfo))}}}var Wa=s(77085),ja=s(5808),Ua=s(17136),Va=s(89056),Ya=s(92029),Ha=s(52350);let Xa;class $a{constructor(e,t,s,i,r){this.chunkIndex=e,this.featureIndex=t,this.objectId=s,this.displayId=i,this.time=r}}class Za{static getOid(e){return ie.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 cr.A}get _trackLineAttributes(){const e={...this._latestObservationFeature?.attributes,aggregateId:this.objectId,[ie.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 $a(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?ie.Aw:null}o=this._isStream?s?.end??Date.now():s?.end??-1/0;const a=t.map(e=>e.reader.getCursor());let h;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),h??=t)}if(null!=h){const{chunkIndex:t,featureIndex:s}=h,i=`${h.objectId}.latest`,n=e.createDisplayIdForObjectId(i),o=a[t];(0,_.Lw)(o),o.setIndex(s);const c=new Bo.Om(o.readGeometryWorldSpace(),{...o.readAttributes(),[ie.EA]:1},null,i,n);this._latestObservationFeature&&r.push(this._latestObservationFeature.objectId),this._latestObservationFeature=c,this._latestObservationRecord=h}else this._latestObservationFeature=null;return this._trackLineGeometry=function(e,t){if(e.length<2)return(0,Dn.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,Ua.O7)(r,e[i-1][0],t);r!==n&&(e[i][0]=n,s=!0)}if(s){const s=(0,Va.b3)({paths:[e],spatialReference:t});if(null!=s)return(0,Dn.Ap)({paths:s.paths},!1,!1)}return(0,Dn.Ap)({paths:[e]},!1,!1)}const s=Xa.fromGeometryToGXGeometry({hasM:!1,hasZ:!1,paths:[e]}),i=Xa.fromSpatialReference(t);if(null!=i){const e=(0,Wa.g7)(s,1e6,i,ja.O.geodesic);if(null!=e){const t=Xa.toGeometry(e,i);if(null!=t&&"paths"in t)return(0,Dn.Ap)({paths:t.paths},!1,!1)}}return(0,Dn.Ap)({paths:[e]},!1,!1)}(this._trackLinePath,this._spatialReference),this._bounds=function(e){const{lengths:t,coords:s}=e;if(!t.length)return[(0,V.Ie)()];const i=[];let r=0;for(let e=0;e<t.length;e++){const n=t[e],o=(0,V.Ie)();i.push(o);for(let e=0;e<n;e++){const t=s[2*(e+r)],i=s[2*(e+r)+1];(0,V.tK)(o,[t,i])}r+=n}return i}(this._trackLineGeometry),this._nextObservationRecords=[],r}updateStatistics(e,t){this._statistics=Ya.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,V.$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,Dn.Nl)(i,this._metadata.geometryType,e.subscription.tile.transform)??new cr.A,o=(0,V.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,V.tK)(o,[e,t])),(0,V.HY)(o,(0,V.fA)(0,0,p.CQ,p.CQ))?new Bo.Om(n,r,null,t,s):null}getTrackLineFeatureForTile(e){const t=(0,Dn.Nl)(this._trackLineGeometry,"esriGeometryPolyline",e.subscription.tile.transform)??new cr.A;return new Bo.Om(t,this._trackLineAttributes,null,this.objectId,this.displayId)}getTrackLineOptimizedFeature(){return new Bo.Om(this._trackLineGeometry,this._trackLineAttributes,null,this.objectId,this.displayId)}getTrackLineDisplayFeature(){const{_trackLineGeometry:e,_trackLineAttributes:t,displayId:s}=this;return{geometry:(0,Dn.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 Qa extends $o{constructor(e){super(e),this.done=!1}}class Ja extends Qo{static async create(e,t,i,r,n){const o=t.metadata.outSpatialReference,a=new wa({spatialReference:o}),h=await Promise.all(e.fields.map(async e=>Uo.create(a,e))),c=e.featureFilter?await ka.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,Wa.s1)()||await Promise.all([Promise.all([s.e(3661),s.e(1878),s.e(5756),s.e(3299),s.e(8125)]).then(s.bind(s,78125)),Promise.all([s.e(3661),s.e(1878),s.e(5756),s.e(3299)]).then(s.bind(s,83299)),(0,Wa.Hh)()]).then(([e,t,s])=>{Xa={fromGeometryToGXGeometry:t.fromGeometryToGXGeometry,toGeometry:t.toGeometry,fromSpatialReference:e.fromSpatialReference}}),new Ja(e,t,i,o,h,c,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:ie.EA,alias:"trackPart",type:"esriFieldTypeSmallInteger"}]),this._trackLineMetadata=Ca.i.createFeature({geometryType:"esriGeometryPolyline",featureIdInfo:{type:"object-id",fieldName:"aggregateId"},fieldsIndex:{fields:[...this._source.metadata.fieldsIndex.fields,...this.aggregateFields,{name:ie.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})}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 Qa(e)}async*applyOverrideUpdate(e){Rt.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=Za.getOid(r),t=this._attributeStore.createDisplayIdForObjectId(e),s=new Za(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,Ga.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=Aa.K.fromOptimizedFeatures(t,this._metadata,e.subscription.tile.transform),r=Aa.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=Ha.e.from(r,t[i]);return n.setProcessorAttributes({[ie.EA]:2}),"esriGeometryPoint"!==n.geometryType&&null!=n.getInTransform()||n.setTransformForDisplay(e.subscription.tile.transform),n}).filter(Po.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 h=i.getCursor();for(;h.next();)this._attributeStore.setAttributeData(h.getDisplayId(),h,o,this._sqlOptions);yield new Jo(e.subscription,r,!1,!1,{});for(const t of n)yield new Jo(e.subscription,t,!1,!1,{});yield new Jo(e.subscription,i,!1,e.done,{})}}new Map;var Ka=s(69397);class eh{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 th{constructor(){this._freeIdsGenerationA=[],this._freeIdsGenerationB=[],this._idCounter=1,this._freeIds=this._freeIdsGenerationA,this._objectIdToDisplayId=new Map}get usedMemory(){let e=0;return e+=(0,Ka.Qf)(this._freeIdsGenerationA),e+=(0,Ka.Qf)(this._freeIdsGenerationB),e+=this._objectIdToDisplayId.size*(eh.estimatedMemory+8),e}createIdForObjectId(e){let t=this._objectIdToDisplayId.get(e);return t?t.increment():(t=new eh((0|this._getFreeId())>>>0),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 sh=()=>Rt.A.getLogger("esri.views.layers.2d.features.support.AttributeStore"),ih=(sh(),()=>null),rh=(0,n.A)("esri-shared-array-buffer");(0,n.A)("esri-atomics");class nh{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=ta(e);return this.data[s*this.texelSize+t]}setData(e,t,s){const i=ta(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)):sh().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 hi.ld.UNSIGNED_BYTE:return Uint8Array;case hi.ld.UNSIGNED_SHORT_4_4_4_4:return Uint16Array;case hi.ld.FLOAT:return Float32Array;default:return void Rt.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 oh{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 th,this._epoch=1}destroy(){this._abortController.abort()}_initialize(){if(null!=this._blockDescriptors)return;const e=hi.ld.FLOAT;ih(`Creating AttributeStore ${rh?"with":"without"} shared memory`),this._blockDescriptors=[{pixelType:hi.ld.UNSIGNED_BYTE,layout:1},{pixelType:hi.ld.UNSIGNED_BYTE,layout:15,textureOnly:!0},{pixelType:hi.ld.UNSIGNED_BYTE,layout:15,textureOnly:!0},{pixelType:e,layout:15},{pixelType:e,layout:15},{pixelType:e,layout:15},{pixelType:e,layout:15},{pixelType:hi.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,g.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?ka.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=ta(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=ta(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=ta(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=ta(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 h=e.field?.read(t,s);e.valueRepresentation&&(h=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}(h,e.valueRepresentation)),(null===h||isNaN(h)||h===1/0||h===-1/0)&&(h=1e-30),a.setData(r,n,h)}))}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;ih(`Initializing AttributeBlock at index ${e}`);const s=new nh(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;ih("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 sh().error(new i.A("mapview-limitations","Maximum number of onscreen features exceeded.")),-1}_updateReferences(e){(0,Mo.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 ah{constructor(e,t){this._connection=e,this._source=t,this._version=1,this._registry=new Do,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 oh({isLocal:!1,update:e=>(0,u.oV)(this._connection.container.updateAttributeView(e))})}destroy(){this._proxy.destroy(),this._strategy?.destroy(),this._attributeStore.destroy()}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}async update(e,t,s,i,r){const o=e.processor,a=(0,m.i8)(this._schema?.storage,o.storage),h=(0,m.i8)(this._schema?.mesh.properties,o.mesh.properties),c=(0,m.i8)(this._schema?.mesh.factory,o.mesh.factory),l=(0,m.i8)(this._schema?.mesh.strategy,o.mesh.strategy),u=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=u.some(e=>this._attributeStore.hasArcadeDependency(e)),p=u.some(e=>this._factory?.hasArcadeDependency(e)??!1),f=u.some(e=>this._strategy?.hasArcadeDependency(e))||this._strategy?.isAggregate&&d,_=p||f,y=h||c||l;if(!(a||y||p||d||f||i))return!1;(0,n.A)("esri-2d-update-debug")&&console.debug(`Version[${this._version}] SymbolProcessor.update`,{changes:(0,g.Ui)(this._schema,o),schema:o}),this._schema=o;const x=new wa({fields:this._source.metadata.fieldsIndex,spatialReference:this._source.metadata.outSpatialReference}),b={currentUser:o.mesh.properties.currentUser};if((a||y||d)&&(await this._attributeStore.update(o.storage,x,this._source.metadata,t),this._strategy?.invalidateAttributeData(hh(o))),!i&&!y&&!_)return!1;(l||h||_)&&await this._updateStrategy(o.mesh.strategy,r,hh(o),b),this._updateSortKey(x,"sortKey"in o.mesh.properties?o.mesh.properties.sortKey:null);const w="dictionary"===o.mesh.factory.symbology.type?o.mesh.factory.symbology.fieldMap:null,v=new No(x,this._proxy,s,this._registry,w);return(c||"dictionary"===o.mesh.factory.symbology.type)&&(this._factory=await fe.create(v,o.mesh.factory)),this._version=t,!0}async applyOverrideUpdate(e){if(!this._strategy)return;const t=this._strategy.applyOverrideUpdate(e);for await(const e of t)try{await this._process(e)}catch(e){}}async updateChunks(){await this._doUpdateChunks(),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(){if(!this._strategy)return;const e=this._strategy.updateChunks(),t=[],s=new Map;for await(const i of e){let e=s.get(i.id);null==e&&(e=new qo({concurrency:16,process:e=>this._process(e)}),s.set(i.id,e));const r=e.push(i).catch(e=>(0,a.jH)(e));t.push(r)}try{await Promise.all(t)}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 Ba(this._source,this._attributeStore,s,i);break;case"binning":this._strategy=await Fa.create(e,this._source,this._attributeStore,s,i);break;case"cluster":this._strategy=await Da.create(this._connection,e,this._source,this._attributeStore,s,i);break;case"track":this._strategy=await Ja.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){const t=e.subscription;if((0,n.A)("esri-2d-update-debug")){const s=t.tile;console.debug(`Version[${this._version}] Tile[${s.key.id}, end=${e.end}] Processor._process`)}const s={currentUser:this._schema?.mesh.properties.currentUser};await this._fetchResources(e,s),(0,a.Te)(t.signal);const i=await this._write(e,t.tile.createArcadeEvaluationOptions(hh(this._schema)),s),r=t.tile.tileInfoView.getLODInfoAt(t.tile.key);(0,a.Te)(t.signal);const{message:o,transferList:h}=i.serialize(r),c={objectIdMap:null,inner:e.createMessage(o,this._version,this._attributeStore.epoch)};if(this._schema?.mesh.properties.returnMeshObjectId){c.objectIdMap={};const t=e.reader?.getCursor();if(t)for(;t.next();)c.objectIdMap[t.getDisplayId()]=t.getObjectId()}if((0,a.Te)(t.signal),await this._connection.container.onMessage(c,{signal:t.signal,transferList:h}),this._attributeStore.sendUpdates(),(0,n.A)("esri-2d-update-debug")){const s=t.tile;console.debug(`Version[${this._version}] Tile[${s.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(hh(this._schema));for(;s.next();)this._factory.enqueueWriterRequests(this._proxy,s,i,t);await this._proxy.fetchEnqueuedResources()}async _write(e,t,s){const i=e.subscription.tile,r=e.reader?.getCursor(),n=r?.getSize()??0,o=i.tileInfoView.tileInfo.isWrappable,h=i.tileInfoView.tileInfo.spatialReference.isWGS84,c=new te(i.key,this._strategy.enablePixelBuffering,o,h,n);if(!r)return c;const l=i.createArcadeEvaluationOptions(hh(this._schema));let u=0;for(;r.next();){++u%1e3||(await(0,a.Pl)(0),(0,a.Te)(e.subscription));const n=this._getSortKeyValue(r,t);c.entityStart(r.getDisplayId(),n);try{this._factory.write(c,this._proxy,r,l,s,i.level)}catch(e){}c.entityEnd()}return c}_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 hh(e){const{timeZone:t}=e?.mesh.properties??{},{timeExtent:s}=e?.expressionProperties??{};return{timeZone:t,timeExtent:s}}class ch{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 ch(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 lh=class extends z.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,c.wB)(()=>this._strategy?.connectionStatus??"disconnected",e=>{this._layerView.setProperty({propertyName:"pipelineConnectionStatus",value:e})},{initial:!0}),(0,c.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,F.Cg)([(0,R.MZ)()],lh.prototype,"_strategy",void 0),lh=(0,F.Cg)([(0,R.$K)("esri.views.2d.layers.features.sources.StreamMessenger")],lh);class uh{constructor(){this._requiresInvalidation=!1}get requiresInvalidation(){return this._requiresInvalidation}requireInvalidation(){this._requiresInvalidation=!0}}class dh{constructor(e,t,s){this._context=s,this._controller=new AbortController,this.metadata=Ca.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 ph=s(13069),fh=s(28923);class _h{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&&Rt.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 fh.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,ph.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 mh=s(11254),gh=s(41560),yh=s(79677);class xh{static create(e,t,s){const i=t.queryScaleRanges,r=t.displayFilterInfo;return new xh(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,timeReferenceUnknownClient:s.timeReferenceUnknownClient??void 0,outSpatialReference:ze.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?yh.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}get pageSize(){if(null==this._queryMetadata)throw new Error("InternalError: Service does not support paged queries");const e=this._queryMetadata.supportsMaxRecordCountFactor?4:null,t=(this._queryMetadata.maxRecordCount??8e3)*(e??1);return Math.min(8e3,t)}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 Pa.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,fa.mA)(i.where,e)}}if(this._displayFilter&&(i.where=(0,fa.mA)(i.where,(0,gh.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.pageSize;return this.createTileQuery(e,{start:s*t,num:s,returnExceededLimitFeatures:!0})}createPagedQuery(e,t){const s=this.pageSize;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 bh=s(10382),wh=s(62577),vh=s(75321),Sh=s(80893),Ih=s(51624),Ph=s(97633),Mh=s(99996),kh=s(53655);const Ch=268435455;class Ah{constructor(){this.hasFeatures=!1,this.exceededTransferLimit=!1,this.fieldCount=0,this.featureCount=0,this.idFieldIndices=[],this.vertexCount=0,this.offsets={attributes:new Array,geometry:new Array},this.centroid=new Array}get usedMemory(){let e=0;return e+=(0,Ka.Qf)(this.idFieldIndices),e+=(0,Ka.Qf)(this.offsets.attributes),e+=(0,Ka.Qf)(this.offsets.geometry),e+=(0,Ka.Qf)(this.centroid),this.displayIds&&(e+=(0,Ka.Qf)(this.displayIds)),this.groupIds&&(e+=(0,Ka.Qf)(this.groupIds)),e}}const Th=268435455,Fh=128e3,zh={small:{delta:new Int32Array(128),decoded:new Int32Array(128)},small64:{delta:new Float64Array(0),decoded:new Float64Array(0)},large:{delta:new Int32Array(Fh),decoded:new Int32Array(Fh)},large64:{delta:new Float64Array(0),decoded:new Float64Array(0)}};function Eh(e,t){return t?e<=zh.small64.delta.length?zh.small64:(e<=zh.large64.delta.length||(zh.large64.delta=new Float64Array(Math.round(1.25*e)),zh.large64.decoded=new Float64Array(Math.round(1.25*e))),zh.large64):e<=zh.small.delta.length?zh.small:(e<=zh.large.delta.length||(zh.large.delta=new Int32Array(Math.round(1.25*e)),zh.large.decoded=new Int32Array(Math.round(1.25*e))),zh.large)}function Oh(e){for(;e.next();){if(1===e.tag())return e.getMessage();e.skip()}return null}function Rh(e,t,s,i,r){return!!e&&0===t*r-i*s&&t*i+s*r>0}class Lh extends Mh.Y{static fromBuffer(e,t,s=!1){const r=t.geometryType,n=function(e){try{const t=2,s=new Ih.A(new Uint8Array(e),new DataView(e));for(;s.next();){if(s.tag()===t)return Oh(s.getMessage());s.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,i=!1){const r=e.asUnsafe(),n=r.pos(),o=new Ah;let a=0,h=0,c=null,l=!1;const u=[];for(;r.next();)switch(r.tag()){case 12:c=r.processMessage(kh.ae);break;case 9:if(o.exceededTransferLimit=r.getBool(),o.exceededTransferLimit){o.offsets.geometry=i?new Float64Array(8e3):new Int32Array(8e3),o.centroid=i?new Float64Array(16e3):new Int32Array(16e3);for(let e=0;e<o.centroid.length;e++)o.centroid[e]=Ch}break;case 13:{const e=r.processMessage(kh.cn);e.index=a++,u.push(e);break}case 15:{const e=r.getLength(),s=r.pos()+e;if(!o.exceededTransferLimit){const e=o.offsets.geometry,t=o.centroid;e.push(0),t.push(Ch),t.push(Ch)}!l&&o.exceededTransferLimit&&(l=!0,o.offsets.attributes=i?new Float64Array(8e3*a):new Uint32Array(8e3*a));let n=h*a;for(;r.pos()<s&&r.next();)switch(r.tag()){case 1:{l?o.offsets.attributes[n++]=r.pos():o.offsets.attributes.push(r.pos());const e=r.getLength();r.skipLen(e);break}case 2:if(t){const e=r.getLength(),t=r.pos()+e;for(;r.pos()<t&&r.next();)switch(r.tag()){case 3:{r.getUInt32();const e=r.getSInt64(),t=r.getSInt64();o.centroid[2*h]=e,o.centroid[2*h+1]=t;break}default:r.skip()}}else{o.offsets.geometry[h]=r.pos();const e=r.getLength();o.vertexCount+=e,r.skipLen(e)}break;case 4:{const e=r.getLength(),t=r.pos()+e;for(;r.pos()<t&&r.next();)switch(r.tag()){case 3:{r.getUInt32();const e=r.getSInt64(),t=r.getSInt64();o.centroid[2*h]=e,o.centroid[2*h+1]=t;break}default:r.skip()}break}default:r.skip()}h++,o.hasFeatures=!0;break}default:r.skip()}o.fields=new jo.A(u),o.featureCount=h,o.fieldCount=a;const d=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 o.idFieldIndices=Array.from(d,e=>o.fields.get(e)?.index),o.transform=c,o.displayIds=new Uint32Array(o.featureCount),o.groupIds=new Uint16Array(o.featureCount),r.move(n),o}(n,"esriGeometryPoint"===r,t.featureIdInfo,s);return new Lh(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!1}get hasM(){return!1}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 Lh(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 Ka.qK+(this._cache.geometry?.usedMemory??0)}get underlyingMemory(){return super.underlyingMemory+this._reader.usedMemory+this._header.usedMemory}_readX(){return this._header.centroid[2*this._featureIndex]}_readY(){return this._header.centroid[2*this._featureIndex+1]}_readServerCentroid(){const e=this._header.centroid[2*this._featureIndex],t=this._header.centroid[2*this._featureIndex+1];return e===Th?null:new cr.A([],[e,t])}_readGeometry(e=!1){if(void 0===this._cache.geometry){let t=null;if(this._isPoints){if(this._header.centroid[2*this._featureIndex]===Th)return null;const e=this._header.centroid[2*this._featureIndex],s=this._header.centroid[2*this._featureIndex+1];t=new cr.A([],[e,s])}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 Ph.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=!1){if(void 0===this._cache.unquantGeometry){const t=this._readGeometry(e);if(!t)return this._cache.unquantGeometry=void 0,null;if(!this.getInTransform())return this._cache.unquantGeometry=t,t;const s=Eh(t.coords.length,this._use64Bit).decoded,i=t.clone(s),r=i.coords;let n=0;for(const e of i.lengths){for(let t=1;t<e;t++){const e=2*(n+t),s=2*(n+t-1);r[e]+=r[s],r[e+1]+=r[s+1]}n+=e}return this._cache.unquantGeometry=i,i}return this._cache.unquantGeometry}_parseGeometry(e){const t=e.asUnsafe(),s=t.getLength(),i=t.pos()+s,r=[],n=[];for(;t.pos()<i&&t.next();)switch(t.tag()){case 2:{const e=t.getUInt32(),s=t.pos()+e;for(;t.pos()<s;)n.push(t.getUInt32());break}case 3:{const e=t.getUInt32(),s=t.pos()+e;for(r.push(t.getSInt64()),r.push(t.getSInt64()),this.hasZ&&t.getSInt64(),this.hasM&&t.getSInt64();t.pos()<s;)r.push(t.getSInt64()),r.push(t.getSInt64()),this.hasZ&&t.getSInt64(),this.hasM&&t.getSInt64();break}default:t.skip()}return new cr.A(n,r,this.hasZ,this.hasM)}_parseGeometryForDisplay(e){const t=e.asUnsafe(),s=t.getLength(),i=t.pos()+s,r=[],n=[];let o=0,a=0,h=null,c=0;const l="esriGeometryPolygon"===this.geometryType,u="esriGeometryPolyline"===this.geometryType,d=l?3:u?2:1,p=l||u;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}h=Eh(2*o,this._use64Bit).delta;break}case 3:{t.getUInt32();const e=2+(this.hasZ?1:0)+(this.hasM?1:0);(0,_.Lw)(h);for(const s of r){if(a+e*s>h.length){for(let e=0;e<s;e++)t.getSInt64(),t.getSInt64(),this.hasZ&&t.getSInt64(),this.hasM&&t.getSInt64();continue}let i=0,r=t.getSInt64(),o=t.getSInt64();this.hasZ&&t.getSInt64(),this.hasM&&t.getSInt64(),h[a++]=r,h[a++]=o,i+=1;for(let e=1;e<s;e++){const e=t.getSInt64(),s=t.getSInt64(),n=r+e,l=o+s;c+=-.5*(n-r)*(l+o),this.hasZ&&t.getSInt64(),this.hasM&&t.getSInt64(),0===e&&0===s||Rh(p,h[a-2],h[a-1],e,s)?(h[a-2]+=e,h[a-1]+=s):(h[a++]=e,h[a++]=s,i+=1),r=n,o=l}i>=d?n.push(i):a-=i*e}break}default:t.skip()}return this._cache.area=c,n.length?new cr.A(n,h,this.hasZ,this.hasM):null!=h?this._createDeltaQuantizedExtrudedGeometry(h[0],h[1]):null}}class Dh{constructor(e,t){this.service=e,this._metadata=t}destroy(){}}class Nh extends Dh{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 bh.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 Aa.K.fromFeatureSet(s,this._metadata)}}class Gh extends Dh{async executeQuery(e,t){const s=await(0,Sh.kS)(this.service.source,e,t),r=!e.quantizationParameters;try{return Lh.fromBuffer(s,this._metadata,r)}catch(s){const r=await(0,Sh.LT)(this.service.source,e,"pbf",t??{}),{data:{url:n}}=await(0,mh.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 qh extends Dh{async executeQuery(e,t){const{source:s,queryMetadata:i}=this.service;if(null!=e.quantizationParameters&&!i.supportsQuantization){const i=e.clone(),r=(0,wh.VV)(i.quantizationParameters);i.quantizationParameters=null;const n=await(0,Sh.eW)(s,i,this._metadata.spatialReference,t),o=(0,Dn.q3)(n,this._metadata.featureIdInfo);return(0,Dn.jH)(r,o),Aa.K.fromOptimizedFeatureSet(o,this._metadata)}const r=await(0,Sh.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})),Aa.K.fromFeatureSet(r,this._metadata)}}class Bh extends Dh{async executeQuery(e,t){if(e.quantizationParameters&&!this.service.queryMetadata.supportsQuantization){const s=e.clone(),i=(0,wh.VV)(s.quantizationParameters);s.quantizationParameters=null;const r=await(0,vh.I)(this.service.source,e,t);return(0,Dn.jH)(i,r),Aa.K.fromOptimizedFeatureSet(r,this._metadata)}const s=await(0,vh.I)(this.service.source,e,t);return Aa.K.fromOptimizedFeatureSet(s,this._metadata)}}class Wh extends dh{constructor(e,t,s){super(e.metadata,t,s),this._service=e,this._didApplyOverride=!1,this._queue=new Go.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=xh.create(e,{...t.full,...t.partial},this.metadata),this._adapter=function(e,t,s){switch(e.type){case"memory":return new Nh(e,t,s);case"ogc":return new Bh(e,t);case"feature-service":return e.queryMetadata.supportsFormatPBF&&(0,n.A)("featurelayer-pbf")?new Gh(e,t):new qh(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 Aa.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=Pa.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,mh.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):Rt.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 jh extends Wh{constructor(e,t,s){super(e,t,s),this._chunksById=new Map,this._featureCache=new _h(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 Uh=s(70300);class Vh extends Uh.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 Yh=(0,n.A)("featurelayer-query-max-depth");class Hh{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 Xh extends jh{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 Hh(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,h=new Vh(i,e,o,r,n,!1);(0,a.Te)(t.options),this._addChunk(h)}}catch(e){s=e}(0,a.Te)(t.options);const i=new Vh(Aa.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===Yh,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 $h extends Uh.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 Zh{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 Qh extends jh{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,E.tE)(this._loadStates,e.key.id,()=>new Zh(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 $h(Aa.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.pageSize);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 $h(r,i.inner.toJSON(),s,e,!1)}}var Jh=s(27348);class Kh extends Wh{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 Jh.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 fh.j(Aa.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.pageSize);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 fh.j(i,s.inner.toJSON(),e,!1);return(0,a.Te)(this._options),r}}var ec=s(39412),tc=s(63892),sc=s(16630);class ic extends dh{constructor(e,t,s){super(e.metadata,t,s),this._service=e,this._chunkId=0,this._files=new Map,this._chunksByFile=new Map}destroy(){super.destroy();for(const{file:e}of this._files.values())e.free();this._files.clear()}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((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._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,!0}async load(e){return null==this._promise&&(this._promise=this._download()),this._promise}unload(e){}_onOverride(){}async _updateFields(e){await this._promise;const t=new Set(e),s=(0,O.iv)(t,new Set(this.availableFields));if(null!=this._fieldsIndex&&s.size){const e=Array.from(s),t=[];for(const[s,i]of this._chunksByFile.entries()){const{file:r}=this._files.get(s);for(const s of i)t.push(r.updateChunkFields(s,e))}await Promise.all(t)}}_ensureFieldsIndex(e){if(!this._fieldsIndex){const t=e.fields(!1).map(t=>({name:t.name,alias:t.name,type:t.type,column:e.columnForFieldName(t.name)})),{timeZoneByFieldName:s}=this._service.metadata.fieldsIndex,i=jo.A.fromJSON({fields:t,timeZoneByFieldName:s});this._fieldsIndex=i}return this._fieldsIndex}async _insert(e){const t=await(0,ec.N)(),s=await(0,tc.DV)(e,{geometryInfo:this._service.geometryInfo,getCustomParameters:()=>this._schema.full.customParameters}),i=this._files.size;this._files.set(e,{file:s,fileId:i}),(0,a.Te)(this._options);const r=this._ensureFieldsIndex(s),n=t.Query.new();n.setOutFields(this.availableFields.filter(e=>null!=r.get(e)?.column)),n.setReturnGeometry(!0),n.setOutSpatialReference(this.metadata.outSpatialReference.toJSON().wkid);const o=await s.executeQuery(n,this._signal);(0,a.Te)(this._signal);const h=[],c=o.next(this._signal);for(let e=0;e<12;e++)h.push(o.next(this._signal));const l=[];this._chunksByFile.set(e,l);let u=await c;for(;null!=u;){(0,a.Te)(this._signal),l.push(u);const e=this._chunkId++,t=new sc.s(this.metadata,r,u,i),s=new fh.j(t,null,e,!1);this.store.insert(s);const n=h.shift();h.push(o.next(this._signal)),u=await n}}async _download(){try{await Promise.all(this._schema.partial.urls.map(e=>this._insert(e)));const e=new fh.j(Aa.K.empty(this.metadata),null,-1,!0);this.store.insert(e)}catch(e){throw console.error(e),e}}}class rc extends Uh.K{constructor(e,t,s,i,r){super(),this._metadata=e,this._reader=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 reader(){return this._reader??Aa.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}getTileReader(e){return this._tile.key.id===e.key.id?this.reader:null}}class nc{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 oc extends dh{constructor(e,t,s){if(super(e.metadata,t,s),this._service=e,this._loadStates=new Map,this._files=new Map,this._queue=new Go.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()}destroy(){super.destroy();for(const{file:e}of this._files.values())e.free()}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,E.tE)(this._loadStates,e.key.id,()=>new nc(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(){const e=this._schema.partial.urls;await Promise.all(e.map(e=>this._insert(e)))}async _insert(e){const t=await(0,tc.DV)(e,{geometryInfo:this._service.geometryInfo,getCustomParameters:()=>this._schema.full.customParameters}),s=this._files.size;this._ensureFieldsIndex(t),this._files.set(e,{file:t,fileId:s})}_onOverride(){}async _updateFields(e){const t=new Set(e),s=(0,O.iv)(t,new Set(this.availableFields));if(null!=this._fieldsIndex&&s.size){const e=Array.from(s),t=[];for(const s of this._loadStates.values())for(const{fileUrl:i,data:r}of s.chunks){const{file:n}=this._files.get(i);t.push(n.updateChunkFields(r,e,s.options.signal))}await Promise.all(t)}}_ensureFieldsIndex(e){if(!this._fieldsIndex){const t=e.fields(!1).map(t=>({name:t.name,alias:t.name,type:t.type,column:e.columnForFieldName(t.name)})),{timeZoneByFieldName:s}=this._service.metadata.fieldsIndex,i=jo.A.fromJSON({fields:t,timeZoneByFieldName:s});this._fieldsIndex=i}return this._fieldsIndex}async _loadTile(e){const t=await(0,ec.N)(),s=e.tile,i=e.signal,{scale:r,translate:n}=s.normalizedTransform,o=t.Query.new();o.setExtent(s.extent),o.setQuantizationTransform({scale:r,translate:n}),o.setScale(s.scale),o.setOutFields(Array.from(this.availableFields).filter(e=>null!=this._fieldsIndex.get(e)?.column)),o.setOutSpatialReference(this.metadata.outSpatialReference.toJSON().wkid),o.setReturnGeometry(!0);const h=this._loadStates.get(s.id);let c=0;for(const[e,{file:t,fileId:r}]of this._files.entries()){const n=await t.executeQuery(o,i),l=[],u=n.next(i);for(let e=0;e<4;e++)l.push(n.next(i));let d=await u;for(;null!=d;){(0,a.Te)(i);const t=new sc.s(this.metadata,this._fieldsIndex,d,r),o=new rc(this.metadata,t,s,c++,!1);h.addBinaryData({data:d,fileUrl:e}),h.addSourceChunkId(o.chunkId),this.store.insert(o);const u=l.shift();l.push(n.next(i)),d=await u}}(0,a.Te)(i);const l=new rc(this.metadata,null,s,c++,!0);h.addSourceChunkId(l.chunkId),this.store.insert(l)}}class ac{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 hc{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===ie.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 ac(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,Cs.qE)(e,0,1e3);this._trackIdToObservations.set(s,new ac(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[ie.Gm]=s,t.attributes[ie.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[ie.Gm]<s&&this._removed.push(e.objectId)})}_purgeTracks(){this._trackIdToObservations.forEach((e,t)=>{0===e.size&&this._trackIdToObservations.delete(t)})}}var cc=s(30624),lc=s(10107),uc=s(64108);let dc=class extends z.A{constructor(e){super(e)}get connectionStatus(){return this.connection?.connectionStatus}get errorString(){return this.connection?.errorString}};(0,F.Cg)([(0,lc.MZ)()],dc.prototype,"connection",void 0),(0,F.Cg)([(0,lc.MZ)()],dc.prototype,"connectionStatus",null),(0,F.Cg)([(0,lc.MZ)()],dc.prototype,"errorString",null),dc=(0,F.Cg)([(0,uc.$)("esri.views.2d.layers.features.sources.StreamConnectionState")],dc);class pc{constructor(e,t){this._metadata=e,this._onUpdate=t,this._objectIdToFeature=new Map}get size(){return this._objectIdToFeature.size}get reader(){return Aa.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 fc extends Uh.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 _c extends dh{constructor(e,t,s){super(e.metadata,t,s),this._service=e,this._connectionState=new dc,this._forceRefresh=!1,this.events=new Vo.bk;const{timeInfo:i}=this.metadata,{purgeOptions:r}=t.full;this._stagingStore=new pc(this.metadata.weakCloneWithAdditionalFields([{name:ie.Aw,alias:"timeReceived",type:"esriFieldTypeDate"}]),e=>this.events.emit("features-updated",e)),this._manager=new hc(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 fc(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,cc.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 mc=s(44320),gc=s(79897);let yc=class extends z.A{constructor(e){super(e),this.debugName="",this._updatingHandles=new gc.U,this._idToUpdatingState=new N.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,c.wB)(()=>t.updating,t=>this._idToUpdatingState.set(e,t),{sync:!0});this.addHandles(s)}addPromise(e){return this._updatingHandles.addPromise(e)}};(0,F.Cg)([(0,R.MZ)({constructOnly:!0})],yc.prototype,"debugName",void 0),(0,F.Cg)([(0,R.MZ)({readOnly:!0})],yc.prototype,"updating",null),yc=(0,F.Cg)([(0,uc.$)("esri.views.2d.layers.support.UpdateTracking2D")],yc);class xc{constructor(e,t,s,i){this._aggregateAdapter=e,this._subscriptions=t,this._connection=s,this._cachedObjectIds=i,this._updateTracking=new yc({debugName:"FeatureSource"}),this.store=new mc.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 ch.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 Xo.do({featureStore:this.store,fieldsIndex:this.metadata.fieldsIndex,geometryType:this.metadata.geometryType,featureIdInfo:this.metadata.featureIdInfo,hasM:!1,hasZ:!1,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.addPromise(t)}onResume(e){this._updateTracking.addPromise((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 uh;return!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),await this.store.update({metadata:this.metadata,definitionExpression:this._schema.strategy.full.definitionExpression}),!0):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 lh(this._connection))}async normalizeOverrides(e){const t={historicMoment:e.historicMoment,commands:{updateWeak:e.commands.updateWeak.map(Bo.Om.fromJSON),removeWeak:e.commands.removeWeak,update:e.commands.update.map(Bo.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 h=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.addPromise(h),this._strategy.prepareCacheUpdate(this._cachedObjectIds);try{r&&await h}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 Xh(e,t,s);case"paged-tile":return new Qh(e,t,s);case"snapshot":return new Kh(e,t,s)}}_createParquetLoadStrategy(e,t,s){switch(t.type){case"xz":return new oc(e,t,s);case"snapshot":return new ic(e,t,s)}}_createStreamLoadStrategy(e,t,s){const i=new _c(e,t,s);return this.streamMessenger.strategy=i,i}}class bc{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 wc=s(98291);class vc{constructor(e,t){this.key=new x.A(0,0,0,0),this.bounds=(0,V.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,V.w1)(this.bounds,this.tileInfoView.tileInfo.spatialReference)}get transform(){return{originPosition:"upperLeft",scale:[this.resolution,this.resolution],translate:[this.bounds[0],this.bounds[3]]}}get normalizedTransform(){return(0,wh.Q1)(this.transform)}createArcadeEvaluationOptions(e){return(0,Ga.N)(this.scale,e)}createChildTiles(){const e=this.key.getChildKeys(),t=wc.A.acquire();for(let s=0;s<e.length;s++)t[s]=new vc(this.tileInfoView,e[s]);return t}getQuantizationParameters(){return Jh.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.tileInfo.spatialReference}})}}class Sc{constructor(e){this.inner=e,this.resolver=(0,a.Tw)()}}class Ic{constructor(){this._aggregateAdapter={getFeatureObjectIds:e=>this._processor.getFeatureObjectIdsForAggregate(e)},this._subscriptions=new Map,this._cachedObjectIds=new Set,this._updateRequested=!1,this._didSourceRefresh=!1,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 T(s),this._source=new xc(this._aggregateAdapter,this._subscriptions,t,this._cachedObjectIds),this._processor=new ah(t,this._source),this._handles=(0,r.vE)([this._source.store.events.on("changed",()=>this._requestUpdate()),this._source.store.events.on("refresh",()=>this._requestRefresh()),(0,c.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 processor(){return this._processor}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)}async updateSchema(e,t){return(0,n.A)("esri-2d-update-debug")&&this._updateSchemaRequest&&console.error("InternalError: Schema already updating"),this._updateSchemaRequest=new Sc({schema:e,version:t}),this._requestUpdate(),this._updateSchemaRequest.resolver.promise}updateSubscriptions(e){const t=new Sc(e);return this._updateSubscriptionRequests.push(t),this._requestUpdate(),t.resolver.promise}updateHighlight(e){const t=new Sc(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 Sc(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,l.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(),h=t**2,c=3/(Math.PI*h),u=2*t,d=Math.ceil(p.CQ/u);for(const t of o){const o=t.tile,l=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()/u,o=i.readYForDisplay()/u,a=Math.floor(s),p=Math.floor(o);if(a<0||p<0||a>=d||p>=d)continue;const f=((.5+a-s)*u)**2+((.5+p-o)*u)**2;if(f>h)continue;const _=t*(c*(1-f/h)**2);l[p+a*d]+=_}}for(let e=0;e<l.length;e++)s=Math.min(s,l[e]),i=Math.max(i,l[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 h.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,u.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 vc(this._tileInfoView,t),i=new bc(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),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)}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(),(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)}}},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),getGeometry:e=>e.geometry,getCentroid:(e,t)=>e.ensureCentroid(t)}},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"===c(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],l(s)),t[1]=Math.min(t[1],u(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)),h=function(e,t,s){if(0===e.length)return!0;const r=l(e.at(0)?.minScale),n=u(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)(l(r.minScale),u(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 h&&"1=1"!==h?h:""}function*a(e,t,s){if("manual"===c(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)h(i.minScale,i.maxScale,t,s)&&(yield i)}}function h(e,t,s,r){return e=l(e),s=l(s),t=u(t),!(!(0,i.Sp)(s,e)&&(r??s)>e||(0,i.Hx)(t,s)||void 0!==r&&(0,i.Sp)(r,e))}function c(e){return"mode"in e?e.mode:e.filterMode}function l(e){return e||Number.POSITIVE_INFINITY}function u(e){return e||0}},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}}},46140:(e,t,s)=>{s.d(t,{A:()=>r});var i=s(49186);let r=class e{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)}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 e(this.major,this.minor,this._context)}static parse(t,s=""){const[r,n]=t.split("."),o=/^\s*\d+\s*$/;if(!r?.match||!o.test(r))throw new i.A((s&&s+":")+"invalid-version","Expected major version to be a number, but got '${version}'",{version:t});if(!n?.match||!o.test(n))throw new i.A((s&&s+":")+"invalid-version","Expected minor version to be a number, but got '${version}'",{version:t});const a=parseInt(r,10),h=parseInt(n,10);return new e(a,h,s)}}},55674:(e,t,s)=>{s.d(t,{Ad:()=>p,Gj:()=>m,QY:()=>d,lL:()=>g,xR:()=>f});var i=s(66131),r=s(49186),n=(s(44208),s(44729)),o=s(15032),a=s(65864),h=s(95466),c=s(43668),l=s(98623);const u=["geometry","scale","timeProperties"];function d(e,t){if(null!=t)for(const s of u)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,c.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 h=n.scriptUsesGeometryEngine(a);h&&await n.enableGeometrySupport(),await n.loadDependentModules(new Set,a,null,!1,h);const l={vars:i.reduce((e,t)=>({...e,[t]:null}),{}),spatialReference:t,useAsync:!1},u=n.compileScript(a,l);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,u,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 h.A(g(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)===l.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??l.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 g(e){const t=[];for(const s in e)t.push({name:s,alias:s,type:"string"==typeof e[s]?"esriFieldTypeString":"esriFieldTypeDouble"});return t}},58501:(e,t,s)=>{s.d(t,{q:()=>r});var i=s(62815);function r(e,t,s){if(!s?.features||!s.hasZ)return;const r=(0,i.N)(s.geometryType,t,e.outSpatialReference);if(r)for(const e of s.features)r(e.geometry)}},62815:(e,t,s)=>{s.d(t,{N:()=>o});var i=s(86211),r=s(73941),n=s(21325);function o(e,t,s){if(null==t||null==s||s.vcsWkid||(0,n.aI)(t,s)||(0,r.xP)(t)||(0,r.xP)(s))return;const o=(0,i.G9)(t)/(0,i.G9)(s);if(1!==o)switch(e){case"point":case"esriGeometryPoint":return e=>function(e,t){null!=e?.z&&(e.z*=t)}(e,o);case"polyline":case"esriGeometryPolyline":return e=>function(e,t){if(e)for(const s of e.paths)for(const e of s)e.length>2&&(e[2]*=t)}(e,o);case"polygon":case"esriGeometryPolygon":return e=>function(e,t){if(e)for(const s of e.rings)for(const e of s)e.length>2&&(e[2]*=t)}(e,o);case"multipoint":case"esriGeometryMultipoint":return e=>function(e,t){if(e)for(const s of e.points)s.length>2&&(s[2]*=t)}(e,o);case"extent":case"esriGeometryEnvelope":return e=>function(e,t){e&&null!=e.zmin&&null!=e.zmax&&(e.zmin*=t,e.zmax*=t)}(e,o);default:return}}},67482:(e,t,s)=>{function i(e){return null!=a(e)||null!=o(e)}function r(e){return h.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(l&&/\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=!c.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=h.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"),c=+(s.seconds??"0");if(o>23)return null;if(a>59)return null;if(c>59)return null;const l=s.ms??"0",u=l?+l.padEnd(3,"0").slice(0,3):0;let d;if(s.isUTC||!s.offsetSign)d=Date.UTC(i,r,n,o,a,c,u);else{const e=+s.offsetHours,t=+s.offsetMinutes;d=6e4*("+"===s.offsetSign?-1:1)*(60*e+t)+Date.UTC(i,r,n,o,a,c,u)}return Number.isNaN(d)?null:d}s.d(t,{Br:()=>r,Cq:()=>i,_U:()=>n});const h=/^(?:(?<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})))?$/,c=/^((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,l=!Number.isNaN(new Date("technology 10").getTime())},72457:(e,t,s)=>{s.d(t,{h:()=>n,k:()=>r});const i=new FinalizationRegistry(e=>{e.close()});function r(e,t){i.register(e,t,t)}function n(e){i.unregister(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__"},72802:(e,t,s)=>{s.d(t,{U:()=>r});var i=s(19419);class r{constructor(e,t,s,r=(0,i.vt)()){this._level=e,this._row=t,this._col=s,this.extent=r}get id(){return this._id??=`${this.level}/${this.row}/${this.col}`,this._id}get level(){return this._level}set level(e){this._level=e,this._id=null}get row(){return this._row}set row(e){this._row=e,this._id=null}get col(){return this._col}set col(e){this._col=e,this._id=null}toJSON(){return{level:this._level,row:this._row,col:this._col,extent:this.extent}}static fromJSON(e){return new r(e.level,e.row,e.col,e.extent)}}},73681:(e,t,s)=>{s.d(t,{n:()=>h});var i=s(49186),r=s(53966),n=s(46140),o=s(95466),a=s(55674);class h{static async from(e,t,s){const o=e.dictionary_version?n.A.parse(e.dictionary_version):null,l=new Set(e.itemsNames),u={};if(t)for(const e in t)u[e]=t[e];if(e.authoringInfo.configuration)for(const t of e.authoringInfo.configuration)u.hasOwnProperty(t.name)||(u[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,u);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 c(s,f);return new h(f,l,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 c 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]}}},75321:(e,t,s)=>{s.d(t,{CJ:()=>I,GA:()=>k,GL:()=>S,I:()=>T,J0:()=>C,Ki:()=>M,Px:()=>P,QE:()=>v,bW:()=>A,vJ:()=>w});var i=s(11254),r=s(49186),n=s(53966),o=s(84952),a=s(16930),h=s(21325),c=s(28735),l=s(90708),u=s(58512),d=s(85113),p=s(64714),f=s(82832),_=s(95466),m=s(98453),g=s(98623);const y=()=>n.A.getLogger("esri.layers.ogc.ogcFeatureUtils"),x="startindex",b=new Set([x,"offset"]),w="http://www.opengis.net/def/crs/",v=`${w}OGC/1.3/CRS84`;async function S(e,t,s={},n=5){const{links:a}=e,h=R(a,"items","application/geo+json")||R(a,"http://www.opengis.net/def/rel/ogc/1.0/items","application/geo+json");if(null==h)throw new r.A("ogc-feature-layer:missing-items-page","Missing items url");const{apiKey:c,customParameters:l,signal:u}=s,f=(0,o.s2)(h.href,e.landingPage.url),b={limit:n,...l,token:c},w=(0,o.a6)(f,b),{data:v}=await(0,i.A)(w,{signal:u,headers:{accept:"application/geo+json"}}),S=L(w,n,v.links)??x;(0,d.sO)(v);const I=v.numberMatched,P=(0,d.BM)(v,{geometryType:t.geometryType}),M=t.fields||P.fields||[],k=null!=t.hasZ?t.hasZ:P.hasZ,C=P.geometryType,A=t.objectIdField||P.objectIdFieldName||"OBJECTID";let T=t.timeInfo;const F=M.find(({name:e})=>e===A);if(F)F.editable=!1,F.nullable=!1;else{if(!P.objectIdFieldType)throw new r.A("ogc-feature-layer:missing-feature-id","Collection geojson require a feature id as a unique identifier");M.unshift({name:A,alias:A,type:"number"===P.objectIdFieldType?"esriFieldTypeOID":"esriFieldTypeString",editable:!1,nullable:!1})}if(A!==P.objectIdFieldName){const e=M.find(({name:e})=>e===P.objectIdFieldName);e&&(e.type="esriFieldTypeInteger")}M===P.fields&&P.unknownFields.length>0&&y().warn({name:"ogc-feature-layer:unknown-field-types",message:"Some fields types couldn't be inferred from the features and were dropped",details:{unknownFields:P.unknownFields}});for(const e of M){if(null==e.name&&(e.name=e.alias),null==e.alias&&(e.alias=e.name),"esriFieldTypeOID"!==e.type&&"esriFieldTypeGlobalID"!==e.type&&(e.editable=null==e.editable||!!e.editable,e.nullable=null==e.nullable||!!e.nullable),!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(T){const e=new _.A(M);if(T.startTimeField){const t=e.get(T.startTimeField);t?(T.startTimeField=t.name,t.type="esriFieldTypeDate"):T.startTimeField=null}if(T.endTimeField){const t=e.get(T.endTimeField);t?(T.endTimeField=t.name,t.type="esriFieldTypeDate"):T.endTimeField=null}if(T.trackIdField){const t=e.get(T.trackIdField);t?T.trackIdField=t.name:(T.trackIdField=null,y().warn({name:"ogc-feature-layer:invalid-timeInfo-trackIdField",message:"trackIdField is missing",details:{timeInfo:T}}))}T.timeReference||={timeZoneIANA:g.n$},T.startTimeField||T.endTimeField||(y().warn({name:"ogc-feature-layer:invalid-timeInfo",message:"startTimeField and endTimeField are missing",details:{timeInfo:T}}),T=void 0)}return{drawingInfo:C?(0,p.F0)(C):null,extent:O(e),geometryType:C,fields:M,hasZ:!!k,objectIdField:A,paginationParameter:S,timeInfo:T,featureCount:I}}async function I(e,t={}){const{links:s,url:n}=e,a=R(s,"data","application/json")??R(s,"http://www.opengis.net/def/rel/ogc/1.0/data","application/json");if(!a)throw new r.A("ogc-feature-layer:missing-collections-page","Missing collections url");const{apiKey:h,customParameters:c,signal:l}=t,u=(0,o.s2)(a.href,n),{data:d}=await(0,i.A)(u,{signal:l,headers:{accept:"application/json"},query:{...c,token:h}});for(const t of d.collections)t.landingPage=e;return d}async function P(e,t={}){const{links:s,url:n}=e,a=R(s,"conformance","application/json")||R(s,"http://www.opengis.net/def/rel/ogc/1.0/conformance","application/json");if(null==a)throw new r.A("ogc-feature-layer:missing-conformance-page","Missing conformance url");const{apiKey:h,customParameters:c,signal:l}=t,u=(0,o.s2)(a.href,n),{data:d}=await(0,i.A)(u,{signal:l,headers:{accept:"application/json"},query:{...c,token:h}});return d}async function M(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 k(e,t={}){const{links:s,url:r}=e,n=R(s,"service-desc","application/vnd.oai.openapi+json;version=3.0");if(null==n)return y().warn("ogc-feature-layer:missing-openapi-page","The OGC API-Features server does not have an OpenAPI page."),null;const{apiKey:a,customParameters:h,signal:c}=t,l=(0,o.s2)(n.href,r),{data:u}=await(0,i.A)(l,{signal:c,headers:{accept:"application/vnd.oai.openapi+json;version=3.0"},query:{...h,token:a}});return u}function C(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 A(e,t,s){const i=await T(e,t,s);return(0,l.ZF)(i)}async function T(e,t,s){const{collection:{links:n,landingPage:{url:p}},layerDefinition:m,maxRecordCount:g,queryParameters:{apiKey:y,customParameters:x},spatialReference:b,supportedCrs:w}=e,v=R(n,"items","application/geo+json")||R(n,"http://www.opengis.net/def/rel/ogc/1.0/items","application/geo+json");if(!v)throw new r.A("ogc-feature-layer:missing-items-page","Missing items url");const{geometry:S,num:I,start:P,timeExtent:M,where:k}=t;if(t.objectIds)throw new r.A("ogc-feature-layer:query-by-objectids-not-supported","Queries with object ids are not supported");const C=a.A.fromJSON(b),A=t.outSpatialReference??C,T=A.isWGS84?null:F(A,w),z=E(S,w),O=function(e){if(!e)return null;const{start:t,end:s}=e;return`${null!=t?t.toISOString():".."}/${null!=s?s.toISOString():".."}`}(M),L=($=k)&&"1=1"!==$?$:null,D=I??(null==P?g:10),N=0===P?void 0:P,{fields:G,geometryType:q,hasZ:B,objectIdField:W,paginationParameter:j}=m,U=(0,o.s2)(v.href,p),{data:V}=await(0,i.A)(U,{...s,query:{...x,...z,crs:T,datetime:O,query:L,limit:D,[j]:N,token:y},headers:{accept:"application/geo+json"}}),Y=(0,d.bd)(V,{geometryType:q,hasZ:B,objectIdField:W}),H=Y.length===D&&!!R(V.links??[],"next","application/geo+json"),X=new _.A(G);var $;for(const e of Y){const t={};(0,f.MB)(X,t,e.attributes,!0);for(const e of X.fields)e.nullable&&!(e.name in t)&&(t[e.name]=null);t[W]=e.attributes[W],e.attributes=t}if(!T&&A.isWebMercator)for(const e of Y)if(null!=e.geometry&&null!=q){const t=(0,l.zv)(e.geometry,q,B,!1);t.spatialReference=a.A.WGS84,e.geometry=(0,l.Ux)((0,c.Cv)(t,A))}for(const e of Y)e.objectId=e.attributes[W];const Z=T||!T&&A.isWebMercator?A.toJSON():h.KK,Q=new u.A;return Q.exceededTransferLimit=H,Q.features=Y,Q.fields=G,Q.geometryType=q,Q.hasZ=B,Q.spatialReference=Z,Q}function F(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?`${w}${n}`:null}function z(e){if(!e)return"";const{xmin:t,ymin:s,xmax:i,ymax:r}=e;return`${t},${s},${i},${r}`}function E(e,t){if(!function(e){return null!=e&&"extent"===e.type}(e))return null;const{spatialReference:s}=e;if(!s||s.isWGS84)return{bbox:z(e)};const i=F(s,t);return null!=i?{bbox:z(e),"bbox-crs":i}:s.isWebMercator?{bbox:z((0,c.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 R(e,t,s){return e.find(({rel:e,type:i})=>e===t&&i===s)??e.find(({rel:e,type:s})=>e===t&&!s)}function L(e,t,s){if(!s)return;const i=R(s,"next","application/geo+json"),r=(0,o.An)(i?.href)?.query;if(!r)return;const n=(0,o.An)(e).query,a=Object.keys(n??{}),h=Object.entries(r).filter(([e])=>!a.includes(e)).find(([e,s])=>b.has(e.toLowerCase())&&Number.parseInt(s,10)===t),c=h?.[0];return c}},76061:(e,t,s)=>{s.d(t,{G:()=>i,S:()=>r});class i{*[Symbol.iterator](){let e=this.next();for(;e;)yield e,e=this.next()}}class r extends i{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}}},77085:(e,t,s)=>{s.d(t,{Hh:()=>a,fz:()=>l,g7:()=>h,s1:()=>o,zo:()=>c});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(5756),s.e(1088)]).then(s.bind(s,31088)),Promise.all([s.e(3661),s.e(1878),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 h(e,t,s,i){return n.execute(e,t,s,i,null)}function c(e,t,s,r){const o=n.executeMany(new i.S(e),t,s,r,null);return Array.from(o)}function l(){return n.supportsCurves()}},79677:(e,t,s)=>{s.d(t,{A:()=>u});var i,r=s(31635),n=s(25482),o=s(88930),a=s(91429),h=s(98623),c=s(36005),l=s(43937);let u=class extends n.o{static{i=this}static get allTime(){return d}static get empty(){return p}static fromArray(e){return new i({start:null!=e[0]?new Date(e[0]):e[0],end:null!=e[1]?new Date(e[1]):e[1]})}constructor(e){super(e),this.end=null,this.start=null}readEnd(e,t){return null!=t.end?new Date(t.end):null}writeEnd(e,t){t.end=e?.getTime()??null}get isAllTime(){return this.equals(i.allTime)}get isEmpty(){return this.equals(i.empty)}readStart(e,t){return null!=t.start?new Date(t.start):null}writeStart(e,t){t.start=e?.getTime()??null}clone(){return new i({end:this.end,start:this.start})}equals(e){if(!e)return!1;const t=this.start?.getTime()??this.start,s=this.end?.getTime()??this.end,i=e.start?.getTime()??e.start,r=e.end?.getTime()??e.end;return t===i&&s===r}expandTo(e,t=h.qU){if(this.isEmpty||this.isAllTime)return this.clone();let s=this.start;s&&(s=(0,o.lL)(s,e,t));let r=this.end;if(r){const s=(0,o.lL)(r,e,t);r=r.getTime()===s.getTime()?s:(0,o.S1)(s,1,e,t)}return new i({start:s,end:r})}intersection(e){if(!e)return this.clone();if(this.isEmpty||e.isEmpty)return i.empty;if(this.isAllTime)return e.clone();if(e.isAllTime)return this.clone();const t=this.start?.getTime()??-1/0,s=this.end?.getTime()??1/0,r=e.start?.getTime()??-1/0,n=e.end?.getTime()??1/0;let o,a;return r>=t&&r<=s?o=r:t>=r&&t<=n&&(o=t),s>=r&&s<=n?a=s:n>=t&&n<=s&&(a=n),null==o||null==a||isNaN(o)||isNaN(a)?i.empty:new i({start:o===-1/0?null:new Date(o),end:a===1/0?null:new Date(a)})}offset(e,t,s=h.qU){if(this.isEmpty||this.isAllTime)return this.clone();const r=new i,{start:n,end:a}=this;return null!=n&&(r.start=(0,o.S1)(n,e,t,s)),null!=a&&(r.end=(0,o.S1)(a,e,t,s)),r}toArray(){return this.isEmpty?[void 0,void 0]:[this.start?.getTime()??null,this.end?.getTime()??null]}union(e){if(!e||e.isEmpty)return this.clone();if(this.isEmpty)return e.clone();if(this.isAllTime||e.isAllTime)return d.clone();const t=null!=this.start&&null!=e.start?new Date(Math.min(this.start.getTime(),e.start.getTime())):null,s=null!=this.end&&null!=e.end?new Date(Math.max(this.end.getTime(),e.end.getTime())):null;return new i({start:t,end:s})}};(0,r.Cg)([(0,a.MZ)({type:Date,json:{write:{allowNull:!0}}})],u.prototype,"end",void 0),(0,r.Cg)([(0,c.w)("end")],u.prototype,"readEnd",null),(0,r.Cg)([(0,l.K)("end")],u.prototype,"writeEnd",null),(0,r.Cg)([(0,a.MZ)({readOnly:!0,json:{read:!1}})],u.prototype,"isAllTime",null),(0,r.Cg)([(0,a.MZ)({readOnly:!0,json:{read:!1}})],u.prototype,"isEmpty",null),(0,r.Cg)([(0,a.MZ)({type:Date,json:{write:{allowNull:!0}}})],u.prototype,"start",void 0),(0,r.Cg)([(0,c.w)("start")],u.prototype,"readStart",null),(0,r.Cg)([(0,l.K)("start")],u.prototype,"writeStart",null),u=i=(0,r.Cg)([(0,a.$K)("esri.time.TimeExtent")],u);const d=new u,p=new u({start:void 0,end:void 0})},79897:(e,t,s)=>{s.d(t,{U:()=>l});var i=s(31635),r=s(69622),n=s(36563),o=s(36708),a=s(76030),h=s(10107),c=s(64108);let l=class extends r.A{constructor(){super(...arguments),this.updating=!1,this._handleId=0,this._scheduleHandleId=0,this._pendingPromises=new Set}destroy(){this.removeAll()}add(e,t,s={}){return this._installWatch(e,t,s,o.wB)}addWhen(e,t,s={}){return this._installWatch(e,t,s,o.z7)}addOnCollectionChange(e,t,{initial:s=!1,final:i=!1}={}){const r=++this._handleId;return this.addHandles([(0,o.on)(e,"after-changes",this._createSyncUpdatingCallback(),o.OH),(0,o.on)(e,"change",t,{onListenerAdd:s?e=>t({added:e.toArray(),removed:[]}):void 0,onListenerRemove:i?e=>t({added:[],removed:e.toArray()}):void 0})],r),(0,n.hA)(()=>this.removeHandles(r))}addPromise(e){if(null==e)return e;const t=++this._handleId;this.addHandles((0,n.hA)(()=>{this._pendingPromises.delete(e)&&(0!==this._pendingPromises.size||this.hasHandles(u)||this._set("updating",!1))}),t),this._pendingPromises.add(e),this._set("updating",!0);const s=()=>this.removeHandles(t);return e.then(s,s),e}removeAll(){this._pendingPromises.clear(),this.removeAllHandles(),this._set("updating",!1)}_installWatch(e,t,s={},i){const r=++this._handleId;s.sync||this._installSyncUpdatingWatch(e,r);const o=i(e,t,s);return this.addHandles(o,r),(0,n.hA)(()=>this.removeHandles(r))}_installSyncUpdatingWatch(e,t){const s=this._createSyncUpdatingCallback(),i=(0,o.wB)(e,s,{sync:!0,equals:()=>!1});return this.addHandles(i,t),i}_createSyncUpdatingCallback(){return()=>{this.removeHandles(u),++this._scheduleHandleId;const e=this._scheduleHandleId;this._get("updating")||this._set("updating",!0),this.addHandles((0,a._)(()=>{e===this._scheduleHandleId&&(this._set("updating",this._pendingPromises.size>0),this.removeHandles(u))}),u)}}};(0,i.Cg)([(0,h.MZ)({readOnly:!0})],l.prototype,"updating",void 0),l=(0,i.Cg)([(0,c.$)("esri.core.support.UpdatingHandles")],l);const u=-42},82832:(e,t,s)=>{s.d(t,{$1:()=>m,CR:()=>_,MB:()=>d,PC:()=>g,Yx:()=>h,bP:()=>l});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 h(e){return new a(e)}class c{constructor(e){this.globalId=null,this.success=!0,this.objectId=this.uniqueId=e}}function l(e){return new c(e)}const u=new Set;function d(e,t,s,i=!1){u.clear();for(const r in s){const o=e.get(r);if(!o)continue;const a=p(o,s[r]);if(u.add(o.name),o&&(i||o.editable)){const e=(0,n.CJ)(o,a);if(e)return h((0,n.uo)(e,o,a));t[o.name]=a}}for(const t of e.requiredFields??[])if(!u.has(t.name))return h(`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 g={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"]}},85113:(e,t,s)=>{s.d(t,{BM:()=>P,bd:()=>M,sO:()=>I,xD:()=>u});var i=s(67482),r=s(49186),n=s(21325),o=s(90708),a=s(43334),h=s(92722),c=s(30524);const l={LineString:"esriGeometryPolyline",MultiLineString:"esriGeometryPolyline",MultiPoint:"esriGeometryMultipoint",Point:"esriGeometryPoint",Polygon:"esriGeometryPolygon",MultiPolygon:"esriGeometryPolygon"};function u(e){return l[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 g(e,t){const{coordinates:s,type:i}=e,r=t.hasZ??!1,n=!0;switch(i){case"Point":return new h.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 h.A([],[],r,!1);for(const t of"Polygon"===i?[s]:s){y(e,t[0],r);for(let s=1;s<t.length;s++)x(e,t[s],r)}return e}}}function y(e,t,s){m(t),function(e){return!_(e)}(t)?w(e,t,s):b(e,t,s)}function x(e,t,s){m(t),function(e){return _(e)}(t)?w(e,t,s):b(e,t,s)}function b(e,t,s){for(const i of t)v(e,i,s);e.lengths.push(t.length)}function w(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 P(e,t={}){const s=[],i=new Set,r=new Set;let n,o=!1,a=null,h=!1,{geometryType:l=null}=t;for(const t of d(e)){const{geometry:e,properties:d,id:_}=t;if((!e||(l||(l=u(e.type)),u(e.type)===l))&&(o||(o=f(p(e))),h||(h=null!=_,h&&(n=typeof _,d&&(a=Object.keys(d).filter(e=>d[e]===_)))),d&&a&&h&&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,c.rS)(e);n&&s.push({name:n,alias:e,type:t})}}const _=(0,c.rS)(1===a?.length&&a[0]||null)??void 0;if(_)for(const e of s)if(e.name===_&&(0,c.WA)(e)){e.type="esriFieldTypeOID";break}return{fields:s,geometryType:l,hasZ:o,objectIdFieldName:_,objectIdFieldType:n,unknownFields:Array.from(r)}}function M(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&&u(e.type)!==s)continue;const h=n||{};let c;i&&(c=h[i],null==o||c||(h[i]=c=o)),yield new a.Om(e&&g(e,t),h,null,c)}}(d(e),t))}},87045:(e,t,s)=>{s.d(t,{A:()=>x});var i,r=s(31635),n=s(66552),o=s(25482),a=s(86211),h=s(91429),c=s(56507),l=s(86738),u=s(16930),d=s(21325),p=s(28735),f=s(91806),_=s(72802),m=s(36005),g=s(43937);const y=new n.J({PNG:"png",PNG8:"png8",PNG24:"png24",PNG32:"png32",JPEG:"jpg",JPG:"jpg",DIB:"dib",TIFF:"tiff",EMF:"emf",PS:"ps",PDF:"pdf",GIF:"gif",SVG:"svg",SVGZ:"svgz",Mixed:"mixed",MIXED:"mixed",LERC:"lerc",LERC2D:"lerc2d",RAW:"raw",pbf:"pbf"});let x=class extends o.o{static{i=this}static create(e={}){const{resolutionFactor:t=1,scales:s,size:r=256,spatialReference:n=u.A.WebMercator,numLODs:o=24}=e;if(!(0,d.fn)(n)){const e=[];if(s)for(let t=0;t<s.length;t++){const i=s[t];e.push(new f.A({level:t,scale:i,resolution:i}))}else{let t=5e-4;for(let s=o-1;s>=0;s--)e.unshift(new f.A({level:s,scale:t,resolution:t})),t*=2}return new i({dpi:96,lods:e,origin:new l.A(0,0,n),size:[r,r],spatialReference:n})}const h=(0,d.Vp)(n),c=e.origin?new l.A({x:e.origin.x,y:e.origin.y,spatialReference:n}):new l.A(h?{x:h.origin[0],y:h.origin[1],spatialReference:n}:{x:0,y:0,spatialReference:n}),p=1/(39.37*(0,a.GA)(n)*96),_=[];if(s)for(let e=0;e<s.length;e++){const t=s[e],i=t*p;_.push(new f.A({level:e,scale:t,resolution:i}))}else{let e=(0,d.EA)(n)?512/r*591657527.5917094:256/r*591657527.591555;const s=Math.ceil(o/t);_.push(new f.A({level:0,scale:e,resolution:e*p}));for(let i=1;i<s;i++){const s=e/2**t,r=s*p;_.push(new f.A({level:i,scale:s,resolution:r})),e=s}}return new i({dpi:96,lods:_,origin:c,size:[r,r],spatialReference:n})}constructor(e){super(e),this.dpi=96,this.format=null,this.origin=null,this.size=null,this.spatialReference=null}get isWrappable(){const{spatialReference:e,origin:t}=this;if(e&&t){const s=(0,d.Vp)(e);return e.isWrappable&&!!s&&Math.abs(s.origin[0]-t.x)<=s.dx}return!1}readOrigin(e,t){return l.A.fromJSON({spatialReference:t.spatialReference,...e})}set lods(e){let t=0,s=0;const i=[],r=this._levelToLOD={};e&&(t=-1/0,s=1/0,e.forEach(e=>{i.push(e.scale),t=e.scale>t?e.scale:t,s=e.scale<s?e.scale:s,r[e.level]=e})),this._set("scales",i),this._set("lods",e),this._initializeUpsampleLevels()}readSize(e,t){return[t.cols,t.rows]}writeSize(e,t){t.cols=e[0],t.rows=e[1]}zoomToScale(e){const t=this.scales;if(e<=0)return t[0];if(e>=t.length-1)return t[t.length-1];const s=Math.floor(e),i=s+1;return t[s]/(t[s]/t[i])**(e-s)}scaleToZoom(e){const t=this.scales,s=t.length-1;let i=0;for(;i<s;i++){const s=t[i],r=t[i+1];if(s<=e)return i;if(r===e)return i+1;if(s>e&&r<e)return i+Math.log(s/e)/Math.log(s/r)}return i}tileAt(e,t,s,i){const r=this.lodAt(e);if(!r)return null;let n,o;if("number"==typeof t)n=t,o=s;else if((0,d.aI)(t.spatialReference,this.spatialReference))n=t.x,o=t.y,i=s;else{const e=(0,p.Cv)(t,this.spatialReference);if(null==e)return null;n=e.x,o=e.y,i=s}const a=r.resolution*this.size[0],h=r.resolution*this.size[1];return i??=new _.U(0,0,0),i.level=e,i.row=Math.floor((this.origin.y-o)/h+.001),i.col=Math.floor((n-this.origin.x)/a+.001),this.updateTileInfo(i),i}updateTileInfo(e,t=0){if(!("extent"in e))return!1;let s=this.lodAt(e.level);if(!s&&1===t){const t=this.lods[this.lods.length-1];t.level<e.level&&(s=t)}if(!s)return!1;const i=e.level-s.level,r=s.resolution*this.size[0]/2**i,n=s.resolution*this.size[1]/2**i;return e.extent[0]=this.origin.x+e.col*r,e.extent[1]=this.origin.y-(e.row+1)*n,e.extent[2]=e.extent[0]+r,e.extent[3]=e.extent[1]+n,!0}upsampleTile(e){const t=this._upsampleLevels[e.level];return!(!t||-1===t.parentLevel||(e.level=t.parentLevel,e.row=Math.floor(e.row/t.factor+.001),e.col=Math.floor(e.col/t.factor+.001),this.updateTileInfo(e),0))}getTileBounds(e,t){const s=this.lodAt(t.level);if(null==s)return null;const{resolution:i}=s,r=i*this.size[0],n=i*this.size[1];return e[0]=this.origin.x+t.col*r,e[1]=this.origin.y-(t.row+1)*n,e[2]=e[0]+r,e[3]=e[1]+n,e}lodAt(e){return this._levelToLOD?.[e]??null}clone(){return i.fromJSON(this.write({}))}getCompatibleForVTL(e){if(this.size[0]!==this.size[1]||256===this.size[0]&&512===e)return null;const t=(512===this.size[0]&&256===e?-1:0)+(this.spatialReference.isGeographic?1:0);if(this.size[0]===e&&0===t)return this;const s=[],r=this.lods.length-t;for(let e=0;e<r;e++){const i=e+t,{scale:r,resolution:n}=i>=0?this.lods[i]:{scale:2*this.lods[0].scale,resolution:2*this.lods[0].resolution};s.push(new f.A({level:e,scale:r,resolution:n}))}return new i({size:[e,e],dpi:this.dpi,format:this.format,compressionQuality:this.compressionQuality,origin:this.origin,spatialReference:this.spatialReference,lods:s})}_initializeUpsampleLevels(){const e=this.lods;this._upsampleLevels=[];let t=null;for(let s=0;s<e.length;s++){const i=e[s];this._upsampleLevels[i.level]={parentLevel:t?t.level:-1,factor:t?t.resolution/i.resolution:0},t=i}}};(0,r.Cg)([(0,h.MZ)({type:Number,json:{write:!0}})],x.prototype,"compressionQuality",void 0),(0,r.Cg)([(0,h.MZ)({type:Number,json:{write:!0}})],x.prototype,"dpi",void 0),(0,r.Cg)([(0,h.MZ)({type:String,json:{read:y.read,write:y.write,origins:{"web-scene":{read:!1,write:!1}}}})],x.prototype,"format",void 0),(0,r.Cg)([(0,h.MZ)({readOnly:!0})],x.prototype,"isWrappable",null),(0,r.Cg)([(0,h.MZ)({type:l.A,json:{write:!0}})],x.prototype,"origin",void 0),(0,r.Cg)([(0,m.w)("origin")],x.prototype,"readOrigin",null),(0,r.Cg)([(0,h.MZ)({type:[f.A],value:null,json:{write:!0}})],x.prototype,"lods",null),(0,r.Cg)([(0,h.MZ)({readOnly:!0})],x.prototype,"scales",void 0),(0,r.Cg)([(0,h.MZ)({cast:e=>Array.isArray(e)?e:"number"==typeof e?[e,e]:[256,256]})],x.prototype,"size",void 0),(0,r.Cg)([(0,m.w)("size",["rows","cols"])],x.prototype,"readSize",null),(0,r.Cg)([(0,g.K)("size",{cols:{type:c.jz},rows:{type:c.jz}})],x.prototype,"writeSize",null),(0,r.Cg)([(0,h.MZ)({type:u.A,json:{write:!0}})],x.prototype,"spatialReference",void 0),x=i=(0,r.Cg)([(0,h.$K)("esri.layers.support.TileInfo")],x)},88340:(e,t,s)=>{function i(){return new Float32Array(2)}function r(e,t){const s=new Float32Array(2);return s[0]=e,s[1]=t,s}function n(){return i()}function o(){return r(1,1)}function a(){return r(1,0)}function h(){return r(0,1)}s.d(t,{Un:()=>l,fA:()=>r,uY:()=>c,vt:()=>i});const c=n(),l=o(),u=a(),d=h();Object.freeze(Object.defineProperty({__proto__:null,ONES:l,UNIT_X:u,UNIT_Y:d,ZEROS:c,clone:function(e){const t=new Float32Array(2);return t[0]=e[0],t[1]=e[1],t},create:i,fromValues:r,ones:o,unitX:a,unitY:h,zeros:n},Symbol.toStringTag,{value:"Module"}))},89056:(e,t,s)=>{s.d(t,{b3:()=>u,jZ:()=>l});var i=s(12195),r=s(19419),n=s(537),o=s(95108),a=s(60408),h=s(80754),c=s(21325);function l(e){return d(e,!0)}function u(e){return d(e,!1)}function d(e,t){if(null==e)return null;const s=e.spatialReference,r=(0,c.Vp)(s),o=(0,i.W)(e)?e.toJSON():e;if(!r)return o;const l=(0,c.K8)(s)?102100:4326,u=h.j7[l].maxX,d=h.j7[l].minX;if((0,a.fT)(o))return f(o,u,d);if((0,a.U9)(o))return o.points=o.points.map(e=>f(e,u,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)(b,o),s={xmin:e[0],ymin:e[1],xmax:e[2],ymax:e[3]},i=(0,h.kd)(s.xmin,d)*(2*u),r=0===i?o:(0,h.kS)(o,i);return s.xmin+=i,s.xmax+=i,s.xmax>u?y(r,u,t):s.xmin<d?y(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,[h,c]=t.valid,{x:l,frameId:u}=_(e.xmin,t),{x:d,frameId:p}=_(e.xmax,t),f=l===d&&a>0;if(a>2*c){const e={xmin:n<o?l:d,ymin:i,xmax:c,ymax:r},t={xmin:h,ymin:i,xmax:n<o?d:l,ymax:r},a={xmin:0,ymin:i,xmax:c,ymax:r},f={xmin:h,ymin:i,xmax:0,ymax:r},_=[],g=[];m(e,a)&&_.push(u),m(e,f)&&g.push(u),m(t,a)&&_.push(p),m(t,f)&&g.push(p);for(let e=u+1;e<p;e++)_.push(e),g.push(e);s.push(new x(e,[u]),new x(t,[p]),new x(a,_),new x(f,g))}else l>d||f?s.push(new x({xmin:l,ymin:i,xmax:c,ymax:r},[u]),new x({xmin:h,ymin:i,xmax:d,ymax:r},[p])):s.push(new x({xmin:l,ymin:i,xmax:d,ymax:r},[u]));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,h.kd)(i,t);e[0]=i+s*(-2*t)}else if(i<s){const t=(0,h.kd)(i,s);e[0]=i+t*(-2*s)}}else{const i=e.x;if(i>t){const s=(0,h.kd)(i,t);e.x+=s*(-2*t)}else if(i<s){const t=(0,h.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 g(e,s,i)&&g(e,s,n)&&g(e,r,n)&&g(e,r,i)}function g(e,t,s){return t>=e.xmin&&t<=e.xmax&&s>=e.ymin&&s<=e.ymax}function y(e,t,s=!0){const i=!(0,a.Rg)(e);if(i&&(0,o.m3)(e),s)return(new w).cut(e,t);const r=i?e.rings:e.paths,n=i?4:2,h=r.length,c=-2*t;for(let e=0;e<h;e++){const t=r[e];if(t&&t.length>=n){const e=[];for(const[s,...i]of t)e.push([s+c,...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 b=(0,r.vt)();class w{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])}},91806:(e,t,s)=>{s.d(t,{A:()=>h});var i,r=s(31635),n=s(25482),o=s(91429),a=s(56507);let h=class extends n.o{static{i=this}constructor(e){super(e),this.cols=null,this.level=0,this.levelValue=null,this.origin=null,this.resolution=0,this.rows=null,this.scale=0}clone(){return new i({cols:this.cols,level:this.level,levelValue:this.levelValue,resolution:this.resolution,rows:this.rows,scale:this.scale})}};(0,r.Cg)([(0,o.MZ)({json:{write:!0,origins:{"web-document":{read:!1,write:!1},"portal-item":{read:!1,write:!1}}}})],h.prototype,"cols",void 0),(0,r.Cg)([(0,o.MZ)({type:a.jz,json:{write:!0}})],h.prototype,"level",void 0),(0,r.Cg)([(0,o.MZ)({type:String,json:{write:!0}})],h.prototype,"levelValue",void 0),(0,r.Cg)([(0,o.MZ)({json:{write:!0,origins:{"web-document":{read:!1,write:!1},"portal-item":{read:!1,write:!1}}}})],h.prototype,"origin",void 0),(0,r.Cg)([(0,o.MZ)({type:Number,json:{write:!0}})],h.prototype,"resolution",void 0),(0,r.Cg)([(0,o.MZ)({json:{write:!0,origins:{"web-document":{read:!1,write:!1},"portal-item":{read:!1,write:!1}}}})],h.prototype,"rows",void 0),(0,r.Cg)([(0,o.MZ)({type:Number,json:{write:!0}})],h.prototype,"scale",void 0),h=i=(0,r.Cg)([(0,o.$K)("esri.layers.support.LOD")],h)}}]);