@itwin/map-layers-formats 4.1.0-dev.7 → 4.1.0-dev.71

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 (284) hide show
  1. package/CHANGELOG.md +74 -1
  2. package/lib/cjs/ArcGisFeature/ArcGisCanvasRenderer.d.ts +19 -0
  3. package/lib/cjs/ArcGisFeature/ArcGisCanvasRenderer.d.ts.map +1 -0
  4. package/lib/cjs/ArcGisFeature/ArcGisCanvasRenderer.js +46 -0
  5. package/lib/cjs/ArcGisFeature/ArcGisCanvasRenderer.js.map +1 -0
  6. package/lib/cjs/ArcGisFeature/ArcGisFeatureFormat.d.ts.map +1 -1
  7. package/lib/cjs/ArcGisFeature/ArcGisFeatureFormat.js +3 -0
  8. package/lib/cjs/ArcGisFeature/ArcGisFeatureFormat.js.map +1 -1
  9. package/lib/cjs/ArcGisFeature/ArcGisFeatureProvider.d.ts +16 -8
  10. package/lib/cjs/ArcGisFeature/ArcGisFeatureProvider.d.ts.map +1 -1
  11. package/lib/cjs/ArcGisFeature/ArcGisFeatureProvider.js +157 -45
  12. package/lib/cjs/ArcGisFeature/ArcGisFeatureProvider.js.map +1 -1
  13. package/lib/cjs/ArcGisFeature/ArcGisFeatureQuery.d.ts +5 -0
  14. package/lib/cjs/ArcGisFeature/ArcGisFeatureQuery.d.ts.map +1 -1
  15. package/lib/cjs/ArcGisFeature/ArcGisFeatureQuery.js +4 -0
  16. package/lib/cjs/ArcGisFeature/ArcGisFeatureQuery.js.map +1 -1
  17. package/lib/cjs/ArcGisFeature/ArcGisFeatureReader.d.ts +15 -6
  18. package/lib/cjs/ArcGisFeature/ArcGisFeatureReader.d.ts.map +1 -1
  19. package/lib/cjs/ArcGisFeature/ArcGisFeatureReader.js +6 -4
  20. package/lib/cjs/ArcGisFeature/ArcGisFeatureReader.js.map +1 -1
  21. package/lib/cjs/ArcGisFeature/ArcGisJsonFeatureReader.d.ts +14 -0
  22. package/lib/cjs/ArcGisFeature/ArcGisJsonFeatureReader.d.ts.map +1 -0
  23. package/lib/cjs/ArcGisFeature/{ArcGisFeatureJSON.js → ArcGisJsonFeatureReader.js} +51 -55
  24. package/lib/cjs/ArcGisFeature/ArcGisJsonFeatureReader.js.map +1 -0
  25. package/lib/cjs/ArcGisFeature/ArcGisPbfFeatureReader.d.ts +22 -0
  26. package/lib/cjs/ArcGisFeature/ArcGisPbfFeatureReader.d.ts.map +1 -0
  27. package/lib/cjs/ArcGisFeature/ArcGisPbfFeatureReader.js +249 -0
  28. package/lib/cjs/ArcGisFeature/ArcGisPbfFeatureReader.js.map +1 -0
  29. package/lib/cjs/ArcGisFeature/ArcGisSymbologyRenderer.d.ts +32 -77
  30. package/lib/cjs/ArcGisFeature/ArcGisSymbologyRenderer.d.ts.map +1 -1
  31. package/lib/cjs/ArcGisFeature/ArcGisSymbologyRenderer.js +88 -128
  32. package/lib/cjs/ArcGisFeature/ArcGisSymbologyRenderer.js.map +1 -1
  33. package/lib/cjs/ArcGisFeature/EsriSymbology.d.ts +152 -0
  34. package/lib/cjs/ArcGisFeature/EsriSymbology.d.ts.map +1 -0
  35. package/lib/cjs/ArcGisFeature/EsriSymbology.js +181 -0
  36. package/lib/cjs/ArcGisFeature/EsriSymbology.js.map +1 -0
  37. package/lib/cjs/Tools/MapFeatureInfoDecorator.d.ts +34 -0
  38. package/lib/cjs/Tools/MapFeatureInfoDecorator.d.ts.map +1 -0
  39. package/lib/cjs/Tools/MapFeatureInfoDecorator.js +281 -0
  40. package/lib/cjs/Tools/MapFeatureInfoDecorator.js.map +1 -0
  41. package/lib/cjs/Tools/MapFeatureInfoTool.d.ts +38 -0
  42. package/lib/cjs/Tools/MapFeatureInfoTool.d.ts.map +1 -0
  43. package/lib/cjs/Tools/MapFeatureInfoTool.js +113 -0
  44. package/lib/cjs/Tools/MapFeatureInfoTool.js.map +1 -0
  45. package/lib/cjs/map-layers-formats.d.ts +1 -0
  46. package/lib/cjs/map-layers-formats.d.ts.map +1 -1
  47. package/lib/cjs/map-layers-formats.js +1 -0
  48. package/lib/cjs/map-layers-formats.js.map +1 -1
  49. package/lib/cjs/mapLayersFormats.d.ts +12 -1
  50. package/lib/cjs/mapLayersFormats.d.ts.map +1 -1
  51. package/lib/cjs/mapLayersFormats.js +11 -1
  52. package/lib/cjs/mapLayersFormats.js.map +1 -1
  53. package/lib/esm/ArcGisFeature/ArcGisCanvasRenderer.d.ts +19 -0
  54. package/lib/esm/ArcGisFeature/ArcGisCanvasRenderer.d.ts.map +1 -0
  55. package/lib/esm/ArcGisFeature/ArcGisCanvasRenderer.js +42 -0
  56. package/lib/esm/ArcGisFeature/ArcGisCanvasRenderer.js.map +1 -0
  57. package/lib/esm/ArcGisFeature/ArcGisFeatureFormat.d.ts.map +1 -1
  58. package/lib/esm/ArcGisFeature/ArcGisFeatureFormat.js +4 -1
  59. package/lib/esm/ArcGisFeature/ArcGisFeatureFormat.js.map +1 -1
  60. package/lib/esm/ArcGisFeature/ArcGisFeatureProvider.d.ts +16 -8
  61. package/lib/esm/ArcGisFeature/ArcGisFeatureProvider.d.ts.map +1 -1
  62. package/lib/esm/ArcGisFeature/ArcGisFeatureProvider.js +158 -46
  63. package/lib/esm/ArcGisFeature/ArcGisFeatureProvider.js.map +1 -1
  64. package/lib/esm/ArcGisFeature/ArcGisFeatureQuery.d.ts +5 -0
  65. package/lib/esm/ArcGisFeature/ArcGisFeatureQuery.d.ts.map +1 -1
  66. package/lib/esm/ArcGisFeature/ArcGisFeatureQuery.js +4 -0
  67. package/lib/esm/ArcGisFeature/ArcGisFeatureQuery.js.map +1 -1
  68. package/lib/esm/ArcGisFeature/ArcGisFeatureReader.d.ts +15 -6
  69. package/lib/esm/ArcGisFeature/ArcGisFeatureReader.d.ts.map +1 -1
  70. package/lib/esm/ArcGisFeature/ArcGisFeatureReader.js +4 -2
  71. package/lib/esm/ArcGisFeature/ArcGisFeatureReader.js.map +1 -1
  72. package/lib/esm/ArcGisFeature/ArcGisJsonFeatureReader.d.ts +14 -0
  73. package/lib/esm/ArcGisFeature/ArcGisJsonFeatureReader.d.ts.map +1 -0
  74. package/lib/esm/ArcGisFeature/{ArcGisFeatureJSON.js → ArcGisJsonFeatureReader.js} +51 -55
  75. package/lib/esm/ArcGisFeature/ArcGisJsonFeatureReader.js.map +1 -0
  76. package/lib/esm/ArcGisFeature/ArcGisPbfFeatureReader.d.ts +22 -0
  77. package/lib/esm/ArcGisFeature/ArcGisPbfFeatureReader.d.ts.map +1 -0
  78. package/lib/esm/ArcGisFeature/ArcGisPbfFeatureReader.js +245 -0
  79. package/lib/esm/ArcGisFeature/ArcGisPbfFeatureReader.js.map +1 -0
  80. package/lib/esm/ArcGisFeature/ArcGisSymbologyRenderer.d.ts +32 -77
  81. package/lib/esm/ArcGisFeature/ArcGisSymbologyRenderer.d.ts.map +1 -1
  82. package/lib/esm/ArcGisFeature/ArcGisSymbologyRenderer.js +84 -124
  83. package/lib/esm/ArcGisFeature/ArcGisSymbologyRenderer.js.map +1 -1
  84. package/lib/esm/ArcGisFeature/EsriSymbology.d.ts +152 -0
  85. package/lib/esm/ArcGisFeature/EsriSymbology.d.ts.map +1 -0
  86. package/lib/esm/ArcGisFeature/EsriSymbology.js +170 -0
  87. package/lib/esm/ArcGisFeature/EsriSymbology.js.map +1 -0
  88. package/lib/esm/Tools/MapFeatureInfoDecorator.d.ts +34 -0
  89. package/lib/esm/Tools/MapFeatureInfoDecorator.d.ts.map +1 -0
  90. package/lib/esm/Tools/MapFeatureInfoDecorator.js +277 -0
  91. package/lib/esm/Tools/MapFeatureInfoDecorator.js.map +1 -0
  92. package/lib/esm/Tools/MapFeatureInfoTool.d.ts +38 -0
  93. package/lib/esm/Tools/MapFeatureInfoTool.d.ts.map +1 -0
  94. package/lib/esm/Tools/MapFeatureInfoTool.js +110 -0
  95. package/lib/esm/Tools/MapFeatureInfoTool.js.map +1 -0
  96. package/lib/esm/map-layers-formats.d.ts +1 -0
  97. package/lib/esm/map-layers-formats.d.ts.map +1 -1
  98. package/lib/esm/map-layers-formats.js +1 -0
  99. package/lib/esm/map-layers-formats.js.map +1 -1
  100. package/lib/esm/mapLayersFormats.d.ts +12 -1
  101. package/lib/esm/mapLayersFormats.d.ts.map +1 -1
  102. package/lib/esm/mapLayersFormats.js +13 -2
  103. package/lib/esm/mapLayersFormats.js.map +1 -1
  104. package/lib/public/locales/en/mapLayersFormats.json +12 -0
  105. package/package.json +19 -22
  106. package/.nycrc +0 -10
  107. package/.rush/temp/operation/build/all.log +0 -3
  108. package/.rush/temp/operation/build/state.json +0 -3
  109. package/.rush/temp/operation/cover/all.log +0 -98
  110. package/.rush/temp/operation/cover/state.json +0 -3
  111. package/.rush/temp/operation/docs/all.log +0 -30
  112. package/.rush/temp/operation/docs/state.json +0 -3
  113. package/.rush/temp/package-deps_build.json +0 -36
  114. package/.rush/temp/package-deps_cover.json +0 -36
  115. package/.rush/temp/package-deps_docs.json +0 -36
  116. package/.rush/temp/shrinkwrap-deps.json +0 -505
  117. package/CHANGELOG.json +0 -119
  118. package/config/rush-project.json +0 -6
  119. package/lib/cjs/ArcGisFeature/ArcGisFeatureJSON.d.ts +0 -15
  120. package/lib/cjs/ArcGisFeature/ArcGisFeatureJSON.d.ts.map +0 -1
  121. package/lib/cjs/ArcGisFeature/ArcGisFeatureJSON.js.map +0 -1
  122. package/lib/cjs/ArcGisFeature/ArcGisFeaturePBF.d.ts +0 -15
  123. package/lib/cjs/ArcGisFeature/ArcGisFeaturePBF.d.ts.map +0 -1
  124. package/lib/cjs/ArcGisFeature/ArcGisFeaturePBF.js +0 -201
  125. package/lib/cjs/ArcGisFeature/ArcGisFeaturePBF.js.map +0 -1
  126. package/lib/cjs/ArcGisFeature/ArcGisFeatureRenderer.d.ts +0 -33
  127. package/lib/cjs/ArcGisFeature/ArcGisFeatureRenderer.d.ts.map +0 -1
  128. package/lib/cjs/ArcGisFeature/ArcGisFeatureRenderer.js +0 -143
  129. package/lib/cjs/ArcGisFeature/ArcGisFeatureRenderer.js.map +0 -1
  130. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureFeatureFormats.test.d.ts +0 -2
  131. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureFeatureFormats.test.d.ts.map +0 -1
  132. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureFeatureFormats.test.js +0 -35
  133. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureFeatureFormats.test.js.map +0 -1
  134. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureJSON.test.d.ts +0 -2
  135. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureJSON.test.d.ts.map +0 -1
  136. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureJSON.test.js +0 -162
  137. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureJSON.test.js.map +0 -1
  138. package/lib/cjs/test/ArcGisFeature/ArcGisFeaturePBF.test.d.ts +0 -2
  139. package/lib/cjs/test/ArcGisFeature/ArcGisFeaturePBF.test.d.ts.map +0 -1
  140. package/lib/cjs/test/ArcGisFeature/ArcGisFeaturePBF.test.js +0 -168
  141. package/lib/cjs/test/ArcGisFeature/ArcGisFeaturePBF.test.js.map +0 -1
  142. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureProvider.test.d.ts +0 -2
  143. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureProvider.test.d.ts.map +0 -1
  144. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureProvider.test.js +0 -680
  145. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureProvider.test.js.map +0 -1
  146. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureQuery.test.d.ts +0 -2
  147. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureQuery.test.d.ts.map +0 -1
  148. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureQuery.test.js +0 -104
  149. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureQuery.test.js.map +0 -1
  150. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureRenderer.test.d.ts +0 -2
  151. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureRenderer.test.d.ts.map +0 -1
  152. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureRenderer.test.js +0 -215
  153. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureRenderer.test.js.map +0 -1
  154. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureResponse.test.d.ts +0 -2
  155. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureResponse.test.d.ts.map +0 -1
  156. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureResponse.test.js +0 -95
  157. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureResponse.test.js.map +0 -1
  158. package/lib/cjs/test/ArcGisFeature/ArcGisSymbologyRenderer.test.d.ts +0 -2
  159. package/lib/cjs/test/ArcGisFeature/ArcGisSymbologyRenderer.test.d.ts.map +0 -1
  160. package/lib/cjs/test/ArcGisFeature/ArcGisSymbologyRenderer.test.js +0 -60
  161. package/lib/cjs/test/ArcGisFeature/ArcGisSymbologyRenderer.test.js.map +0 -1
  162. package/lib/cjs/test/ArcGisFeature/Mocks.d.ts +0 -7
  163. package/lib/cjs/test/ArcGisFeature/Mocks.d.ts.map +0 -1
  164. package/lib/cjs/test/ArcGisFeature/Mocks.js +0 -19
  165. package/lib/cjs/test/ArcGisFeature/Mocks.js.map +0 -1
  166. package/lib/cjs/test/ArcGisFeature/NewYorkDataset.d.ts +0 -56
  167. package/lib/cjs/test/ArcGisFeature/NewYorkDataset.d.ts.map +0 -1
  168. package/lib/cjs/test/ArcGisFeature/NewYorkDataset.js +0 -420
  169. package/lib/cjs/test/ArcGisFeature/NewYorkDataset.js.map +0 -1
  170. package/lib/cjs/test/ArcGisFeature/PhillyLandmarksDataset.d.ts +0 -1043
  171. package/lib/cjs/test/ArcGisFeature/PhillyLandmarksDataset.d.ts.map +0 -1
  172. package/lib/cjs/test/ArcGisFeature/PhillyLandmarksDataset.js +0 -427
  173. package/lib/cjs/test/ArcGisFeature/PhillyLandmarksDataset.js.map +0 -1
  174. package/lib/cjs/test/coverage/.nyc_output/2a6113c3-018f-40b1-ae8f-f3d0cbe030ce.json +0 -1
  175. package/lib/cjs/test/coverage/.nyc_output/74410d89-cce2-4b2a-89c9-6d56490c73f1.json +0 -1
  176. package/lib/cjs/test/coverage/.nyc_output/processinfo/2a6113c3-018f-40b1-ae8f-f3d0cbe030ce.json +0 -1
  177. package/lib/cjs/test/coverage/.nyc_output/processinfo/74410d89-cce2-4b2a-89c9-6d56490c73f1.json +0 -1
  178. package/lib/cjs/test/coverage/.nyc_output/processinfo/index.json +0 -1
  179. package/lib/cjs/test/coverage/cobertura-coverage.xml +0 -1169
  180. package/lib/cjs/test/coverage/lcov-report/base.css +0 -224
  181. package/lib/cjs/test/coverage/lcov-report/block-navigation.js +0 -87
  182. package/lib/cjs/test/coverage/lcov-report/favicon.png +0 -0
  183. package/lib/cjs/test/coverage/lcov-report/index.html +0 -131
  184. package/lib/cjs/test/coverage/lcov-report/prettify.css +0 -1
  185. package/lib/cjs/test/coverage/lcov-report/prettify.js +0 -2
  186. package/lib/cjs/test/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  187. package/lib/cjs/test/coverage/lcov-report/sorter.js +0 -196
  188. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureFormat.ts.html +0 -133
  189. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureJSON.ts.html +0 -550
  190. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeaturePBF.ts.html +0 -730
  191. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureProvider.ts.html +0 -1546
  192. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureQuery.ts.html +0 -763
  193. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureReader.ts.html +0 -223
  194. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureRenderer.ts.html +0 -598
  195. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureResponse.ts.html +0 -301
  196. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisSymbologyRenderer.ts.html +0 -832
  197. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/index.html +0 -236
  198. package/lib/cjs/test/coverage/lcov-report/src/index.html +0 -131
  199. package/lib/cjs/test/coverage/lcov-report/src/map-layers-formats.ts.html +0 -130
  200. package/lib/cjs/test/coverage/lcov-report/src/mapLayersFormats.ts.html +0 -163
  201. package/lib/cjs/test/coverage/lcov.info +0 -1358
  202. package/lib/cjs/tsconfig.tsbuildinfo +0 -1
  203. package/lib/esm/ArcGisFeature/ArcGisFeatureJSON.d.ts +0 -15
  204. package/lib/esm/ArcGisFeature/ArcGisFeatureJSON.d.ts.map +0 -1
  205. package/lib/esm/ArcGisFeature/ArcGisFeatureJSON.js.map +0 -1
  206. package/lib/esm/ArcGisFeature/ArcGisFeaturePBF.d.ts +0 -15
  207. package/lib/esm/ArcGisFeature/ArcGisFeaturePBF.d.ts.map +0 -1
  208. package/lib/esm/ArcGisFeature/ArcGisFeaturePBF.js +0 -197
  209. package/lib/esm/ArcGisFeature/ArcGisFeaturePBF.js.map +0 -1
  210. package/lib/esm/ArcGisFeature/ArcGisFeatureRenderer.d.ts +0 -33
  211. package/lib/esm/ArcGisFeature/ArcGisFeatureRenderer.d.ts.map +0 -1
  212. package/lib/esm/ArcGisFeature/ArcGisFeatureRenderer.js +0 -139
  213. package/lib/esm/ArcGisFeature/ArcGisFeatureRenderer.js.map +0 -1
  214. package/lib/esm/test/ArcGisFeature/ArcGisFeatureFeatureFormats.test.d.ts +0 -2
  215. package/lib/esm/test/ArcGisFeature/ArcGisFeatureFeatureFormats.test.d.ts.map +0 -1
  216. package/lib/esm/test/ArcGisFeature/ArcGisFeatureFeatureFormats.test.js +0 -33
  217. package/lib/esm/test/ArcGisFeature/ArcGisFeatureFeatureFormats.test.js.map +0 -1
  218. package/lib/esm/test/ArcGisFeature/ArcGisFeatureJSON.test.d.ts +0 -2
  219. package/lib/esm/test/ArcGisFeature/ArcGisFeatureJSON.test.d.ts.map +0 -1
  220. package/lib/esm/test/ArcGisFeature/ArcGisFeatureJSON.test.js +0 -160
  221. package/lib/esm/test/ArcGisFeature/ArcGisFeatureJSON.test.js.map +0 -1
  222. package/lib/esm/test/ArcGisFeature/ArcGisFeaturePBF.test.d.ts +0 -2
  223. package/lib/esm/test/ArcGisFeature/ArcGisFeaturePBF.test.d.ts.map +0 -1
  224. package/lib/esm/test/ArcGisFeature/ArcGisFeaturePBF.test.js +0 -166
  225. package/lib/esm/test/ArcGisFeature/ArcGisFeaturePBF.test.js.map +0 -1
  226. package/lib/esm/test/ArcGisFeature/ArcGisFeatureProvider.test.d.ts +0 -2
  227. package/lib/esm/test/ArcGisFeature/ArcGisFeatureProvider.test.d.ts.map +0 -1
  228. package/lib/esm/test/ArcGisFeature/ArcGisFeatureProvider.test.js +0 -678
  229. package/lib/esm/test/ArcGisFeature/ArcGisFeatureProvider.test.js.map +0 -1
  230. package/lib/esm/test/ArcGisFeature/ArcGisFeatureQuery.test.d.ts +0 -2
  231. package/lib/esm/test/ArcGisFeature/ArcGisFeatureQuery.test.d.ts.map +0 -1
  232. package/lib/esm/test/ArcGisFeature/ArcGisFeatureQuery.test.js +0 -102
  233. package/lib/esm/test/ArcGisFeature/ArcGisFeatureQuery.test.js.map +0 -1
  234. package/lib/esm/test/ArcGisFeature/ArcGisFeatureRenderer.test.d.ts +0 -2
  235. package/lib/esm/test/ArcGisFeature/ArcGisFeatureRenderer.test.d.ts.map +0 -1
  236. package/lib/esm/test/ArcGisFeature/ArcGisFeatureRenderer.test.js +0 -213
  237. package/lib/esm/test/ArcGisFeature/ArcGisFeatureRenderer.test.js.map +0 -1
  238. package/lib/esm/test/ArcGisFeature/ArcGisFeatureResponse.test.d.ts +0 -2
  239. package/lib/esm/test/ArcGisFeature/ArcGisFeatureResponse.test.d.ts.map +0 -1
  240. package/lib/esm/test/ArcGisFeature/ArcGisFeatureResponse.test.js +0 -93
  241. package/lib/esm/test/ArcGisFeature/ArcGisFeatureResponse.test.js.map +0 -1
  242. package/lib/esm/test/ArcGisFeature/ArcGisSymbologyRenderer.test.d.ts +0 -2
  243. package/lib/esm/test/ArcGisFeature/ArcGisSymbologyRenderer.test.d.ts.map +0 -1
  244. package/lib/esm/test/ArcGisFeature/ArcGisSymbologyRenderer.test.js +0 -58
  245. package/lib/esm/test/ArcGisFeature/ArcGisSymbologyRenderer.test.js.map +0 -1
  246. package/lib/esm/test/ArcGisFeature/Mocks.d.ts +0 -7
  247. package/lib/esm/test/ArcGisFeature/Mocks.d.ts.map +0 -1
  248. package/lib/esm/test/ArcGisFeature/Mocks.js +0 -16
  249. package/lib/esm/test/ArcGisFeature/Mocks.js.map +0 -1
  250. package/lib/esm/test/ArcGisFeature/NewYorkDataset.d.ts +0 -56
  251. package/lib/esm/test/ArcGisFeature/NewYorkDataset.d.ts.map +0 -1
  252. package/lib/esm/test/ArcGisFeature/NewYorkDataset.js +0 -417
  253. package/lib/esm/test/ArcGisFeature/NewYorkDataset.js.map +0 -1
  254. package/lib/esm/test/ArcGisFeature/PhillyLandmarksDataset.d.ts +0 -1043
  255. package/lib/esm/test/ArcGisFeature/PhillyLandmarksDataset.d.ts.map +0 -1
  256. package/lib/esm/test/ArcGisFeature/PhillyLandmarksDataset.js +0 -424
  257. package/lib/esm/test/ArcGisFeature/PhillyLandmarksDataset.js.map +0 -1
  258. package/lib/esm/tsconfig.tsbuildinfo +0 -1
  259. package/lib/test/junit_results.xml +0 -159
  260. package/map-layers-formats.build.log +0 -30
  261. package/src/ArcGisFeature/ArcGisFeatureFormat.ts +0 -16
  262. package/src/ArcGisFeature/ArcGisFeatureJSON.ts +0 -155
  263. package/src/ArcGisFeature/ArcGisFeaturePBF.ts +0 -215
  264. package/src/ArcGisFeature/ArcGisFeatureProvider.ts +0 -487
  265. package/src/ArcGisFeature/ArcGisFeatureQuery.ts +0 -226
  266. package/src/ArcGisFeature/ArcGisFeatureReader.ts +0 -46
  267. package/src/ArcGisFeature/ArcGisFeatureRenderer.ts +0 -171
  268. package/src/ArcGisFeature/ArcGisFeatureResponse.ts +0 -72
  269. package/src/ArcGisFeature/ArcGisSymbologyRenderer.ts +0 -249
  270. package/src/ArcGisFeature/esriPBuffer.gen.ts +0 -2612
  271. package/src/map-layers-formats.ts +0 -15
  272. package/src/mapLayersFormats.ts +0 -26
  273. package/src/test/ArcGisFeature/ArcGisFeatureFeatureFormats.test.ts +0 -46
  274. package/src/test/ArcGisFeature/ArcGisFeatureJSON.test.ts +0 -202
  275. package/src/test/ArcGisFeature/ArcGisFeaturePBF.test.ts +0 -227
  276. package/src/test/ArcGisFeature/ArcGisFeatureProvider.test.ts +0 -805
  277. package/src/test/ArcGisFeature/ArcGisFeatureQuery.test.ts +0 -117
  278. package/src/test/ArcGisFeature/ArcGisFeatureRenderer.test.ts +0 -296
  279. package/src/test/ArcGisFeature/ArcGisFeatureResponse.test.ts +0 -109
  280. package/src/test/ArcGisFeature/ArcGisSymbologyRenderer.test.ts +0 -77
  281. package/src/test/ArcGisFeature/Mocks.ts +0 -19
  282. package/src/test/ArcGisFeature/NewYorkDataset.ts +0 -423
  283. package/src/test/ArcGisFeature/PhillyLandmarksDataset.ts +0 -455
  284. package/tsconfig.json +0 -20
@@ -1,487 +0,0 @@
1
- /*---------------------------------------------------------------------------------------------
2
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
- * See LICENSE.md in the project root for license terms and full copyright notice.
4
- *--------------------------------------------------------------------------------------------*/
5
-
6
- import { Cartographic, ImageMapLayerSettings, ImageSource, ImageSourceFormat, ServerError } from "@itwin/core-common";
7
- import { base64StringToUint8Array, IModelStatus, Logger } from "@itwin/core-bentley";
8
- import { Matrix4d, Point3d, Range2d, Transform } from "@itwin/core-geometry";
9
- import { ArcGisErrorCode, ArcGISImageryProvider, ArcGISServiceMetadata, ArcGisUtilities, ImageryMapTileTree, MapCartoRectangle, MapLayerFeatureInfo, MapLayerImageryProviderStatus, QuadId } from "@itwin/core-frontend";
10
- import { ArcGisSymbologyRenderer } from "./ArcGisSymbologyRenderer";
11
- import { ArcGisExtent, ArcGisFeatureFormat, ArcGisFeatureQuery, ArcGisGeometry, FeatureQueryQuantizationParams } from "./ArcGisFeatureQuery";
12
- import { ArcGisFeatureRenderer } from "./ArcGisFeatureRenderer";
13
- import { ArcGisFeaturePBF } from "./ArcGisFeaturePBF";
14
- import { ArcGisFeatureJSON } from "./ArcGisFeatureJSON";
15
- import { ArcGisFeatureResponse, ArcGisResponseData } from "./ArcGisFeatureResponse";
16
- import { ArcGisFeatureReader } from "./ArcGisFeatureReader";
17
- const loggerCategory = "MapLayersFormats.ArcGISFeature";
18
- /**
19
- * @internal
20
- */
21
- interface ArcGisFeatureUrl {
22
- url: string;
23
- envelope?: ArcGisExtent; // envelope representing the current computed URL, requiered to refine request.
24
- }
25
-
26
- /** Provide tiles from a ESRI ArcGIS Feature service
27
- * @internal
28
- */
29
- export class ArcGisFeatureProvider extends ArcGISImageryProvider {
30
- // Debug flags, should always be commited to FALSE !
31
- private _drawDebugInfo = false;
32
- private _debugFeatureGeom = false;
33
-
34
- private _supportsCoordinatesQuantization = false;
35
- private _querySupported = false;
36
- private _layerId = 0;
37
- private _layerMetadata: any;
38
- private _format: ArcGisFeatureFormat|undefined;
39
- public serviceJson: any;
40
- private _symbologyRenderer: ArcGisSymbologyRenderer|undefined;
41
- private static readonly _nbSubTiles = 2;
42
- private _outSR = 102100;
43
-
44
- private _maxDepthFromLod = 0;
45
- private _minDepthFromLod = 0;
46
- public override get minimumZoomLevel(): number { return this._minDepthFromLod; }
47
- public override get maximumZoomLevel(): number { return this._maxDepthFromLod; }
48
-
49
- constructor(settings: ImageMapLayerSettings) {
50
- super(settings, true);
51
- }
52
-
53
- public override async initialize(): Promise<void> {
54
- const metadata = await this.getServiceJson();
55
- const json = metadata?.content;
56
-
57
- if (json === undefined) {
58
- Logger.logError(loggerCategory, "Could not get service JSON");
59
- throw new ServerError(IModelStatus.ValidationFailed, "");
60
- }
61
-
62
- if (json?.error?.code === ArcGisErrorCode.TokenRequired || json?.error?.code === ArcGisErrorCode.InvalidToken) {
63
- // Check again layer status, it might have change during await.
64
- if (this.status === MapLayerImageryProviderStatus.Valid) {
65
- this.setStatus(MapLayerImageryProviderStatus.RequireAuth);
66
- return;
67
- }
68
- }
69
-
70
- if (json.capabilities) {
71
- this._querySupported = json.capabilities.indexOf("Query") >= 0;
72
- if (!this._querySupported)
73
- throw new ServerError(IModelStatus.ValidationFailed, "");
74
- }
75
-
76
- this.serviceJson = json;
77
-
78
- let foundVisibleSubLayer = false;
79
- if (this._settings.subLayers.length >= 0) {
80
- // There is more than sub-layer for this layer, pick the first visible one.
81
- for (const layer of this._settings.subLayers) {
82
- if (layer.visible && typeof layer.id === "number") {
83
- this._layerId = layer.id;
84
- foundVisibleSubLayer = true;
85
- break;
86
- }
87
- }
88
- }
89
-
90
- if (!foundVisibleSubLayer && json !== undefined) {
91
- // No suitable sublayer was specified on the layerSettings object, lets find a default one in the capabilities
92
-
93
- // Check layer metadata
94
- if (Array.isArray(this.serviceJson.layers) && this.serviceJson.layers.length >= 1) {
95
-
96
- const hasDefaultVisibility = Object.keys(this.serviceJson.layers[0]).includes("defaultVisibility");
97
- if (hasDefaultVisibility) {
98
- for (const layer of this.serviceJson.layers) {
99
- if (layer.defaultVisibility) {
100
- this._layerId = layer.id;
101
- }
102
- }
103
- } else {
104
- // On some older servers, the default visiblity is on the layer capabilities (i.e. not the service capabilities)
105
- for (const layer of this.serviceJson.layers) {
106
- const layerJson = await this.getLayerMetadata(layer.id);
107
- if (!layerJson) {
108
- continue;
109
- }
110
-
111
- if (layerJson.defaultVisibility) {
112
- this._layerId = layer.id;
113
- this._layerMetadata = layerJson;
114
- break;
115
- }
116
- }
117
- }
118
-
119
- } else {
120
- // There is no layer to publish? Something is off with this server..
121
- throw new ServerError(IModelStatus.ValidationFailed, "");
122
- }
123
- }
124
-
125
- // Make sure we cache layer info (i.e. rendering info)
126
- if (!this._layerMetadata) {
127
-
128
- this._layerMetadata = await this.getLayerMetadata(this._layerId);
129
- if (!this._layerMetadata) {
130
- Logger.logError(loggerCategory, "Could not layer metadata");
131
- throw new ServerError(IModelStatus.ValidationFailed, "");
132
- }
133
- }
134
-
135
- // Parse server version
136
- let majorVersion: number|undefined;
137
- if (this.serviceJson?.currentVersion) {
138
- try {
139
- majorVersion = Math.trunc(this.serviceJson?.currentVersion);
140
- } catch {
141
- }
142
- }
143
-
144
- // Coordinates Quantization: If supported, server will transform for us the coordinates in the Tile coordinate space (pixels, origin = upper left corner
145
- // If not supported, transformation will be applied client side.
146
- // Note: For some reasons, even though 'supportsCoordinatesQuantization' is set to 'true' on the layer metadata, server will give an error message for server version < 11
147
- if (majorVersion && majorVersion >= 11 && this._layerMetadata.supportsCoordinatesQuantization) {
148
- this._supportsCoordinatesQuantization = true;
149
- }
150
-
151
- // Check supported query formats: JSON and PBF are currently implemented by this provider
152
- // Note: needs to be checked on the layer metadata, service metadata advertises a different set of formats
153
- // Also, since PBF format does not support floating points, there is no point using this format if supportsCoordinatesQuantization is not available.
154
- if (this._layerMetadata.supportedQueryFormats) {
155
- const formats: string[] = this._layerMetadata.supportedQueryFormats.split(", ");
156
- if (formats.includes("PBF") && this._supportsCoordinatesQuantization ) {
157
- this._format = "PBF";
158
- } else if (formats.includes ("JSON")) {
159
- this._format = "JSON";
160
- }
161
- }
162
-
163
- if (!this._format) {
164
- Logger.logError(loggerCategory, "Could not get request format from service JSON");
165
- throw new ServerError(IModelStatus.ValidationFailed, "");
166
- }
167
-
168
- // Read range using full extent from service metadata
169
- if (json.fullExtent) {
170
- if (json.fullExtent.spatialReference.latestWkid === 3857 || json.fullExtent.spatialReference.wkid === 102100) {
171
- const range3857 = Range2d.createFrom({
172
- low: {x: json.fullExtent.xmin, y: json.fullExtent.ymin},
173
- high: {x: json.fullExtent.xmax, y: json.fullExtent.ymax} });
174
-
175
- const west = this.getEPSG4326Lon(range3857.xLow);
176
- const south = this.getEPSG4326Lat(range3857.yLow);
177
- const east = this.getEPSG4326Lon(range3857.xHigh);
178
- const north = this.getEPSG4326Lat(range3857.yHigh);
179
- this.cartoRange = MapCartoRectangle.fromDegrees(west, south, east, north);
180
- }
181
- }
182
-
183
- // Check for minScale / max scale
184
- const minScale = this._layerMetadata?.minScale || undefined; // undefined, 0 -> undefined
185
- const maxScale = this._layerMetadata?.maxScale || undefined; // undefined, 0 -> undefined
186
- const scales = ArcGisUtilities.getZoomLevelsScales(this.defaultMaximumZoomLevel, this.tileSize, minScale, maxScale, 1.0);
187
- if (scales.minLod)
188
- this._minDepthFromLod = scales.minLod;
189
-
190
- // Some servers advertises a max LOD of 0, it should be interpreted as 'not defined' (otherwise a max lod of 0 would would mean never display anything)
191
- this._maxDepthFromLod = (scales.maxLod ? scales.maxLod : this.defaultMaximumZoomLevel);
192
-
193
- this._symbologyRenderer = new ArcGisSymbologyRenderer(this._layerMetadata?.geometryType, this._layerMetadata?.drawingInfo?.renderer);
194
- }
195
-
196
- protected async getLayerMetadata(layerId: number) {
197
- let metadata: ArcGISServiceMetadata|undefined;
198
- try {
199
- const url = new URL(this._settings.url);
200
- url.pathname = `${url.pathname}/${layerId}`;
201
- metadata = await ArcGisUtilities.getServiceJson(url.toString(), this._settings.formatId, this._settings.userName, this._settings.password, this._accessTokenRequired);
202
- } catch {
203
-
204
- }
205
- return metadata?.content;
206
- }
207
-
208
- public override get tileSize(): number { return 512; }
209
- public get format(): ArcGisFeatureFormat|undefined { return this._format; }
210
-
211
- // We don't use this method inside this provider (see constructFeatureUrl), but since this is an abstract method, we need to define something
212
- public async constructUrl(_row: number, _column: number, _zoomLevel: number): Promise<string> {
213
- return "";
214
- }
215
-
216
- public constructFeatureUrl(row: number, column: number, zoomLevel: number, format: ArcGisFeatureFormat, geomOverride?: ArcGisGeometry, outFields?: string, tolerance?: number, returnGeometry?: boolean): ArcGisFeatureUrl | undefined {
217
-
218
- const tileExtent = this.getEPSG3857Extent(row, column, zoomLevel);
219
- const tileEnvelope = {
220
- xmin: tileExtent.left, ymin: tileExtent.bottom,
221
- xmax: tileExtent.right, ymax: tileExtent.top,
222
- spatialReference: {wkid:102100, latestWkid:3857},
223
- };
224
-
225
- // Actual spatial filter.
226
- // By default, we request the tile extent. If 'cartoPoint' is specified,
227
- // we restrict the spatial to specific point. (i.e. GetFeatureInfo requests)
228
- // If envelope is provided, it has the priority over 'cartoPoint'
229
- let geometry: ArcGisGeometry|undefined;
230
- if (geomOverride) {
231
- geometry = geomOverride;
232
- } else {
233
- geometry = {geom: tileEnvelope, type: "esriGeometryEnvelope"};
234
- }
235
-
236
- let quantizationParameters: FeatureQueryQuantizationParams|undefined;
237
- const toleranceWorld = (tileExtent.top - tileExtent.bottom) / this.tileSize;
238
- if (this._supportsCoordinatesQuantization) {
239
- quantizationParameters = {
240
- mode: "view",
241
- originPosition: "upperLeft",
242
- tolerance: toleranceWorld, // pixel size in world units
243
- extent: tileEnvelope,
244
- };
245
- }
246
- const url = new ArcGisFeatureQuery(
247
- this._settings.url,
248
- this._layerId,
249
- format,
250
- this._outSR,
251
- { geometry,
252
- geometryType: "esriGeometryEnvelope",
253
- returnExceededLimitFeatures: false,
254
- maxRecordCountFactor: 3, // This was grabbed from the ESRI web viewer request, not sure where this factor come from
255
- resultType: "tile",
256
- quantizationParameters,
257
- outFields,
258
- returnGeometry,
259
- distance: (tolerance ? tolerance*toleranceWorld :undefined) });
260
-
261
- let envelope: ArcGisExtent | undefined;
262
- if (geomOverride && geomOverride.type === "esriGeometryEnvelope"){
263
- envelope = geomOverride.geom as ArcGisExtent;
264
- } else {
265
- envelope = tileEnvelope;
266
- }
267
-
268
- return {url: url.toString(), envelope} ;
269
-
270
- }
271
-
272
- // Makes an identify request to ESRI MapService , and return it as a list MapLayerFeatureInfo object
273
- public override async getFeatureInfo(featureInfos: MapLayerFeatureInfo[], quadId: QuadId, carto: Cartographic, _tree: ImageryMapTileTree): Promise<void> {
274
- if (!this._querySupported || this.format === undefined)
275
- return;
276
-
277
- const cartoPoint = {
278
- x: this.getEPSG3857X(carto.longitudeDegrees),
279
- y: this.getEPSG3857Y(carto.latitudeDegrees),
280
- spatialReference: {wkid:102100, latestWkid:3857},
281
- };
282
-
283
- const doFeatureInfoQuery = async (format: ArcGisFeatureFormat, outFields?: string, returnGeometry?: boolean,) => {
284
- const infoUrl = this.constructFeatureUrl(quadId.row, quadId.column, quadId.level, format, {geom: cartoPoint, type: "esriGeometryPoint"}, outFields, 3 /* tolerance in pixel*/, returnGeometry);
285
-
286
- if (!infoUrl || infoUrl.url.length === 0) {
287
- Logger.logError(loggerCategory, `Could not construct feature info query URL`);
288
- return undefined;
289
- }
290
-
291
- const response = this.fetch(new URL(infoUrl.url), { method: "GET" });
292
-
293
- const featureResponse = new ArcGisFeatureResponse(format, response);
294
- return featureResponse.getResponseData();
295
- };
296
-
297
- if (this._debugFeatureGeom) {
298
- try {
299
- let responseData = await doFeatureInfoQuery("PBF", "", true);
300
- if (responseData) {
301
- Logger.logInfo(loggerCategory, JSON.stringify(responseData.data.toObject()));
302
- }
303
- responseData = await doFeatureInfoQuery("JSON", "", true);
304
- if (responseData) {
305
- Logger.logInfo(loggerCategory, JSON.stringify(responseData.data));
306
- }
307
- } catch (e) {
308
- Logger.logInfo(loggerCategory, `Error occured with debug FeatureInfo: ${e}`);
309
- }
310
- }
311
-
312
- try {
313
- const responseData = await doFeatureInfoQuery(this.format, "*", false);
314
- if (!responseData) {
315
- Logger.logError(loggerCategory, `Could not get feature info data`);
316
- return;
317
- }
318
- if (responseData.exceedTransferLimit) {
319
- Logger.logError(loggerCategory, `Could not get feature info : transfert limit exeeded.`);
320
- return;
321
- }
322
- const featureReader: ArcGisFeatureReader = this.format === "PBF" ? new ArcGisFeaturePBF(this._settings, this._layerMetadata) : new ArcGisFeatureJSON(this._settings, this._layerMetadata);
323
- featureReader.readFeatureInfo(responseData, featureInfos);
324
-
325
- } catch (e) {
326
- Logger.logError(loggerCategory, `Exception occured while loading feature info data : ${e}`);
327
- return;
328
- }
329
-
330
- return;
331
- }
332
-
333
- private async fetchTile(row: number, column: number, zoomLevel: number, refineEnvelope?: ArcGisExtent): Promise<ArcGisFeatureResponse | undefined> {
334
- if (!this.format) {
335
- return undefined;
336
- }
337
-
338
- const geomOverride: ArcGisGeometry|undefined = (refineEnvelope ? {geom: refineEnvelope, type: "esriGeometryEnvelope"} : undefined);
339
- const tileUrl = this.constructFeatureUrl(row, column, zoomLevel, this.format, geomOverride);
340
- if (!tileUrl || tileUrl.url.length === 0) {
341
- Logger.logError(loggerCategory, `Could not construct feature query URL for tile ${zoomLevel}/${row}/${column}`);
342
- return undefined;
343
- }
344
-
345
- const response = this.fetch(new URL(tileUrl.url), { method: "GET" });
346
- return new ArcGisFeatureResponse(this.format, response, tileUrl.envelope);
347
- }
348
-
349
- public drawTileDebugInfo(row: number, column: number, zoomLevel: number, context: CanvasRenderingContext2D ){
350
- context.fillStyle = "cyan";
351
- context.strokeRect(0, 0, this.tileSize, this.tileSize);
352
- context.font = "30px Arial";
353
- context.lineWidth = 5;
354
- context.fillText(`${zoomLevel}-${row}-${column}`, 10, 50);
355
- }
356
-
357
- // Compute transform that provides coordinates in the canvas coordinate system (pixels, origin = top-left)
358
- // from coordinate in world (i.e EPSG:3857)
359
- protected computeTileWorld2CanvasTransform(row: number, column: number, zoomLevel: number) {
360
-
361
- const tileExtentWorld3857 = this.getEPSG3857Extent(row, column, zoomLevel);
362
- const worldTileWidth = tileExtentWorld3857.right - tileExtentWorld3857.left;
363
- const canvasTileWidth = this.tileSize;
364
- const world2CanvasRatio = canvasTileWidth / worldTileWidth;
365
- const worldTileOrigin = Point3d.create(tileExtentWorld3857.left, tileExtentWorld3857.bottom);
366
- const worldTileExtent = Point3d.create(tileExtentWorld3857.right, tileExtentWorld3857.top);
367
- const canvasTileOriginOffset = worldTileOrigin.clone();
368
- const canvasTileExtentOffset = worldTileExtent.clone();
369
- canvasTileOriginOffset.scaleInPlace(world2CanvasRatio);
370
- canvasTileExtentOffset.scaleInPlace(world2CanvasRatio);
371
- const xTranslate = -1*canvasTileOriginOffset.x;
372
-
373
- // Canvas origin is uppler left corner, so we need to flip the y axsis
374
- const yTranslate = canvasTileExtentOffset.y; // y-axis flip
375
- const yWorld2CanvasRatio = -1*world2CanvasRatio; // y-axis flip
376
-
377
- const matrix = Matrix4d.createTranslationAndScaleXYZ(xTranslate, yTranslate, 0, world2CanvasRatio, yWorld2CanvasRatio, 1);
378
- return matrix.asTransform;
379
- }
380
-
381
- public override async loadTile(row: number, column: number, zoomLevel: number): Promise<ImageSource | undefined> {
382
-
383
- if ((this.status === MapLayerImageryProviderStatus.RequireAuth)) {
384
- return undefined;
385
- }
386
- const canvas = document.createElement("canvas");
387
- canvas.width = this.tileSize;
388
- canvas.height = this.tileSize;
389
-
390
- const ctx = canvas.getContext("2d");
391
- if (ctx == null) {
392
- Logger.logError(loggerCategory, "No canvas context available for loading tile.");
393
- return undefined;
394
- }
395
-
396
- if (!this._symbologyRenderer) {
397
- Logger.logError(loggerCategory, "No symbology renderer available for loading tile.");
398
- return undefined;
399
- }
400
- try {
401
-
402
- // Compute transform if CoordinatesQuantization is not supported by service
403
- let transfo: Transform | undefined;
404
- if (!this._supportsCoordinatesQuantization) {
405
- transfo = this.computeTileWorld2CanvasTransform(row, column, zoomLevel);
406
- if (!transfo) {
407
- Logger.logError(loggerCategory, `Could not compute data transformation for tile (${zoomLevel}/${row}/${column})`);
408
- }
409
- }
410
-
411
- const renderer = new ArcGisFeatureRenderer(ctx, this._symbologyRenderer, transfo);
412
- const featureReader: ArcGisFeatureReader = this.format === "PBF" ? new ArcGisFeaturePBF(this._settings, this._layerMetadata) : new ArcGisFeatureJSON(this._settings, this._layerMetadata);
413
-
414
- const getSubEnvelopes = (envelope: ArcGisExtent): ArcGisExtent[] => {
415
- const dx = (envelope.xmax - envelope.xmin) * 0.5;
416
- const dy = (envelope.xmax - envelope.xmin) * 0.5;
417
- const subEnvelopes: ArcGisExtent[] = [];
418
- for (let posX=0; posX<ArcGisFeatureProvider._nbSubTiles; posX++) {
419
- for (let posY=0; posY<ArcGisFeatureProvider._nbSubTiles; posY++) {
420
- subEnvelopes.push({
421
- xmin: envelope.xmin + (dx*posX), ymin: envelope.ymin + (dy*posY),
422
- xmax: envelope.xmin + (dx*(posX+1)), ymax: envelope.ymin + (dy*(posY+1)),
423
- spatialReference: {wkid:102100, latestWkid:3857},
424
- });
425
- }
426
- }
427
- return subEnvelopes;
428
- };
429
-
430
- // The strategy here is simple: we make a request for an area that represents the current tile (i.e envelope),
431
- // the server will either return the requested data OR a 'exceedTransferLimit' message (too much data to transfers).
432
- // In the latter case, we subdivide the previous request envelope in for 4 sub-envelopes,
433
- // and repeat again until we get data.
434
- const renderData = async (envelope?: ArcGisExtent) => {
435
- let response: ArcGisFeatureResponse | undefined;
436
- let responseData: ArcGisResponseData | undefined;
437
- try {
438
- response = await this.fetchTile(row, column, zoomLevel, envelope);
439
- if (!response) {
440
- Logger.logError(loggerCategory, `Error occurred while fetching tile (${zoomLevel}/${row}/${column})`);
441
- return ;
442
- }
443
-
444
- responseData = await response.getResponseData();
445
- if (!responseData) {
446
- Logger.logError(loggerCategory, `Could not get response data for tile (${zoomLevel}/${row}/${column})`);
447
- return ;
448
- }
449
- } catch (e) {
450
- Logger.logError(loggerCategory, `Exception occurred while loading tile (${zoomLevel}/${row}/${column}) : ${e}`);
451
- return;
452
- }
453
-
454
- if (responseData.exceedTransferLimit) {
455
- if (response.envelope) {
456
- const subEnvelopes = getSubEnvelopes(response.envelope);
457
- const renderPromises = [];
458
- for (const subEnvelope of subEnvelopes) {
459
- renderPromises.push(renderData(subEnvelope));
460
- }
461
- await Promise.all(renderPromises);
462
- } else {
463
- Logger.logError(loggerCategory, `Request exceeded transfer limit, could not refine request`);
464
- }
465
- } else {
466
- featureReader.readAndRender(responseData, renderer);
467
- }
468
- };
469
- await renderData();
470
- if (this._drawDebugInfo)
471
- this.drawTileDebugInfo(row, column, zoomLevel, ctx);
472
- } catch (e) {
473
- Logger.logError(loggerCategory, `Exception occurred while loading tile (${zoomLevel}/${row}/${column}) : ${e}`);
474
- }
475
-
476
- try {
477
- const dataUrl = canvas.toDataURL("image/png");
478
- const header = "data:image/png;base64,";
479
- const dataUrl2 = dataUrl.substring(header.length);
480
- return new ImageSource(base64StringToUint8Array(dataUrl2), ImageSourceFormat.Png);
481
- } catch (e) {
482
- Logger.logError(loggerCategory, `Exception occurred while rendering tile (${zoomLevel}/${row}/${column}) : ${e}.`);
483
- }
484
-
485
- return undefined;
486
- }
487
- }