@itwin/map-layers-formats 4.1.0-dev.51 → 4.1.0-dev.56

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 (272) hide show
  1. package/lib/cjs/ArcGisFeature/ArcGisCanvasRenderer.d.ts +17 -0
  2. package/lib/cjs/ArcGisFeature/ArcGisCanvasRenderer.d.ts.map +1 -0
  3. package/lib/cjs/ArcGisFeature/ArcGisCanvasRenderer.js +42 -0
  4. package/lib/cjs/ArcGisFeature/ArcGisCanvasRenderer.js.map +1 -0
  5. package/lib/cjs/ArcGisFeature/ArcGisFeatureFormat.js.map +1 -1
  6. package/lib/cjs/ArcGisFeature/ArcGisFeatureProvider.d.ts +4 -5
  7. package/lib/cjs/ArcGisFeature/ArcGisFeatureProvider.d.ts.map +1 -1
  8. package/lib/cjs/ArcGisFeature/ArcGisFeatureProvider.js +39 -24
  9. package/lib/cjs/ArcGisFeature/ArcGisFeatureProvider.js.map +1 -1
  10. package/lib/cjs/ArcGisFeature/ArcGisFeatureQuery.d.ts +5 -0
  11. package/lib/cjs/ArcGisFeature/ArcGisFeatureQuery.d.ts.map +1 -1
  12. package/lib/cjs/ArcGisFeature/ArcGisFeatureQuery.js +4 -0
  13. package/lib/cjs/ArcGisFeature/ArcGisFeatureQuery.js.map +1 -1
  14. package/lib/cjs/ArcGisFeature/ArcGisFeatureReader.d.ts +15 -6
  15. package/lib/cjs/ArcGisFeature/ArcGisFeatureReader.d.ts.map +1 -1
  16. package/lib/cjs/ArcGisFeature/ArcGisFeatureReader.js +6 -4
  17. package/lib/cjs/ArcGisFeature/ArcGisFeatureReader.js.map +1 -1
  18. package/lib/cjs/ArcGisFeature/ArcGisFeatureResponse.js.map +1 -1
  19. package/lib/cjs/ArcGisFeature/ArcGisJsonFeatureReader.d.ts +13 -0
  20. package/lib/cjs/ArcGisFeature/ArcGisJsonFeatureReader.d.ts.map +1 -0
  21. package/lib/cjs/ArcGisFeature/{ArcGisFeatureJSON.js → ArcGisJsonFeatureReader.js} +36 -58
  22. package/lib/cjs/ArcGisFeature/ArcGisJsonFeatureReader.js.map +1 -0
  23. package/lib/cjs/ArcGisFeature/{ArcGisFeaturePBF.d.ts → ArcGisPbfFeatureReader.d.ts} +6 -7
  24. package/lib/cjs/ArcGisFeature/ArcGisPbfFeatureReader.d.ts.map +1 -0
  25. package/lib/cjs/ArcGisFeature/{ArcGisFeaturePBF.js → ArcGisPbfFeatureReader.js} +46 -32
  26. package/lib/cjs/ArcGisFeature/ArcGisPbfFeatureReader.js.map +1 -0
  27. package/lib/cjs/ArcGisFeature/ArcGisSymbologyRenderer.js +1 -1
  28. package/lib/cjs/ArcGisFeature/ArcGisSymbologyRenderer.js.map +1 -1
  29. package/lib/cjs/ArcGisFeature/esriPBuffer.gen.js.map +1 -1
  30. package/lib/cjs/Tools/MapFeatureInfoDecorator.d.ts +34 -0
  31. package/lib/cjs/Tools/MapFeatureInfoDecorator.d.ts.map +1 -0
  32. package/lib/cjs/Tools/MapFeatureInfoDecorator.js +281 -0
  33. package/lib/cjs/Tools/MapFeatureInfoDecorator.js.map +1 -0
  34. package/lib/cjs/Tools/MapFeatureInfoTool.d.ts +38 -0
  35. package/lib/cjs/Tools/MapFeatureInfoTool.d.ts.map +1 -0
  36. package/lib/cjs/Tools/MapFeatureInfoTool.js +113 -0
  37. package/lib/cjs/Tools/MapFeatureInfoTool.js.map +1 -0
  38. package/lib/cjs/map-layers-formats.d.ts +1 -0
  39. package/lib/cjs/map-layers-formats.d.ts.map +1 -1
  40. package/lib/cjs/map-layers-formats.js +1 -0
  41. package/lib/cjs/map-layers-formats.js.map +1 -1
  42. package/lib/cjs/mapLayersFormats.d.ts +12 -1
  43. package/lib/cjs/mapLayersFormats.d.ts.map +1 -1
  44. package/lib/cjs/mapLayersFormats.js +11 -1
  45. package/lib/cjs/mapLayersFormats.js.map +1 -1
  46. package/lib/esm/ArcGisFeature/ArcGisCanvasRenderer.d.ts +17 -0
  47. package/lib/esm/ArcGisFeature/ArcGisCanvasRenderer.d.ts.map +1 -0
  48. package/lib/esm/ArcGisFeature/ArcGisCanvasRenderer.js +38 -0
  49. package/lib/esm/ArcGisFeature/ArcGisCanvasRenderer.js.map +1 -0
  50. package/lib/esm/ArcGisFeature/ArcGisFeatureFormat.js.map +1 -1
  51. package/lib/esm/ArcGisFeature/ArcGisFeatureProvider.d.ts +4 -5
  52. package/lib/esm/ArcGisFeature/ArcGisFeatureProvider.d.ts.map +1 -1
  53. package/lib/esm/ArcGisFeature/ArcGisFeatureProvider.js +40 -25
  54. package/lib/esm/ArcGisFeature/ArcGisFeatureProvider.js.map +1 -1
  55. package/lib/esm/ArcGisFeature/ArcGisFeatureQuery.d.ts +5 -0
  56. package/lib/esm/ArcGisFeature/ArcGisFeatureQuery.d.ts.map +1 -1
  57. package/lib/esm/ArcGisFeature/ArcGisFeatureQuery.js +4 -0
  58. package/lib/esm/ArcGisFeature/ArcGisFeatureQuery.js.map +1 -1
  59. package/lib/esm/ArcGisFeature/ArcGisFeatureReader.d.ts +15 -6
  60. package/lib/esm/ArcGisFeature/ArcGisFeatureReader.d.ts.map +1 -1
  61. package/lib/esm/ArcGisFeature/ArcGisFeatureReader.js +4 -2
  62. package/lib/esm/ArcGisFeature/ArcGisFeatureReader.js.map +1 -1
  63. package/lib/esm/ArcGisFeature/ArcGisFeatureResponse.js.map +1 -1
  64. package/lib/esm/ArcGisFeature/ArcGisJsonFeatureReader.d.ts +13 -0
  65. package/lib/esm/ArcGisFeature/ArcGisJsonFeatureReader.d.ts.map +1 -0
  66. package/lib/esm/ArcGisFeature/ArcGisJsonFeatureReader.js +107 -0
  67. package/lib/esm/ArcGisFeature/ArcGisJsonFeatureReader.js.map +1 -0
  68. package/lib/esm/ArcGisFeature/{ArcGisFeaturePBF.d.ts → ArcGisPbfFeatureReader.d.ts} +6 -7
  69. package/lib/esm/ArcGisFeature/ArcGisPbfFeatureReader.d.ts.map +1 -0
  70. package/lib/esm/ArcGisFeature/{ArcGisFeaturePBF.js → ArcGisPbfFeatureReader.js} +44 -30
  71. package/lib/esm/ArcGisFeature/ArcGisPbfFeatureReader.js.map +1 -0
  72. package/lib/esm/ArcGisFeature/ArcGisSymbologyRenderer.js +1 -1
  73. package/lib/esm/ArcGisFeature/ArcGisSymbologyRenderer.js.map +1 -1
  74. package/lib/esm/ArcGisFeature/esriPBuffer.gen.js.map +1 -1
  75. package/lib/esm/Tools/MapFeatureInfoDecorator.d.ts +34 -0
  76. package/lib/esm/Tools/MapFeatureInfoDecorator.d.ts.map +1 -0
  77. package/lib/esm/Tools/MapFeatureInfoDecorator.js +277 -0
  78. package/lib/esm/Tools/MapFeatureInfoDecorator.js.map +1 -0
  79. package/lib/esm/Tools/MapFeatureInfoTool.d.ts +38 -0
  80. package/lib/esm/Tools/MapFeatureInfoTool.d.ts.map +1 -0
  81. package/lib/esm/Tools/MapFeatureInfoTool.js +110 -0
  82. package/lib/esm/Tools/MapFeatureInfoTool.js.map +1 -0
  83. package/lib/esm/map-layers-formats.d.ts +1 -0
  84. package/lib/esm/map-layers-formats.d.ts.map +1 -1
  85. package/lib/esm/map-layers-formats.js +1 -0
  86. package/lib/esm/map-layers-formats.js.map +1 -1
  87. package/lib/esm/mapLayersFormats.d.ts +12 -1
  88. package/lib/esm/mapLayersFormats.d.ts.map +1 -1
  89. package/lib/esm/mapLayersFormats.js +13 -2
  90. package/lib/esm/mapLayersFormats.js.map +1 -1
  91. package/lib/public/locales/en/mapLayersFormats.json +12 -0
  92. package/package.json +15 -12
  93. package/.nycrc +0 -10
  94. package/.rush/temp/operation/build/all.log +0 -1
  95. package/.rush/temp/operation/build/state.json +0 -3
  96. package/.rush/temp/operation/cover/all.log +0 -103
  97. package/.rush/temp/operation/cover/state.json +0 -3
  98. package/.rush/temp/operation/docs/all.log +0 -30
  99. package/.rush/temp/operation/docs/state.json +0 -3
  100. package/.rush/temp/package-deps_build.json +0 -36
  101. package/.rush/temp/package-deps_cover.json +0 -36
  102. package/.rush/temp/package-deps_docs.json +0 -36
  103. package/.rush/temp/shrinkwrap-deps.json +0 -495
  104. package/CHANGELOG.json +0 -176
  105. package/config/rush-project.json +0 -6
  106. package/lib/cjs/ArcGisFeature/ArcGisFeatureJSON.d.ts +0 -15
  107. package/lib/cjs/ArcGisFeature/ArcGisFeatureJSON.d.ts.map +0 -1
  108. package/lib/cjs/ArcGisFeature/ArcGisFeatureJSON.js.map +0 -1
  109. package/lib/cjs/ArcGisFeature/ArcGisFeaturePBF.d.ts.map +0 -1
  110. package/lib/cjs/ArcGisFeature/ArcGisFeaturePBF.js.map +0 -1
  111. package/lib/cjs/ArcGisFeature/ArcGisFeatureRenderer.d.ts +0 -33
  112. package/lib/cjs/ArcGisFeature/ArcGisFeatureRenderer.d.ts.map +0 -1
  113. package/lib/cjs/ArcGisFeature/ArcGisFeatureRenderer.js +0 -143
  114. package/lib/cjs/ArcGisFeature/ArcGisFeatureRenderer.js.map +0 -1
  115. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureFeatureFormats.test.d.ts +0 -2
  116. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureFeatureFormats.test.d.ts.map +0 -1
  117. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureFeatureFormats.test.js +0 -35
  118. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureFeatureFormats.test.js.map +0 -1
  119. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureJSON.test.d.ts +0 -2
  120. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureJSON.test.d.ts.map +0 -1
  121. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureJSON.test.js +0 -162
  122. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureJSON.test.js.map +0 -1
  123. package/lib/cjs/test/ArcGisFeature/ArcGisFeaturePBF.test.d.ts +0 -2
  124. package/lib/cjs/test/ArcGisFeature/ArcGisFeaturePBF.test.d.ts.map +0 -1
  125. package/lib/cjs/test/ArcGisFeature/ArcGisFeaturePBF.test.js +0 -168
  126. package/lib/cjs/test/ArcGisFeature/ArcGisFeaturePBF.test.js.map +0 -1
  127. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureProvider.test.d.ts +0 -2
  128. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureProvider.test.d.ts.map +0 -1
  129. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureProvider.test.js +0 -812
  130. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureProvider.test.js.map +0 -1
  131. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureQuery.test.d.ts +0 -2
  132. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureQuery.test.d.ts.map +0 -1
  133. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureQuery.test.js +0 -104
  134. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureQuery.test.js.map +0 -1
  135. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureRenderer.test.d.ts +0 -2
  136. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureRenderer.test.d.ts.map +0 -1
  137. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureRenderer.test.js +0 -215
  138. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureRenderer.test.js.map +0 -1
  139. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureResponse.test.d.ts +0 -2
  140. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureResponse.test.d.ts.map +0 -1
  141. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureResponse.test.js +0 -95
  142. package/lib/cjs/test/ArcGisFeature/ArcGisFeatureResponse.test.js.map +0 -1
  143. package/lib/cjs/test/ArcGisFeature/ArcGisSymbologyRenderer.test.d.ts +0 -2
  144. package/lib/cjs/test/ArcGisFeature/ArcGisSymbologyRenderer.test.d.ts.map +0 -1
  145. package/lib/cjs/test/ArcGisFeature/ArcGisSymbologyRenderer.test.js +0 -60
  146. package/lib/cjs/test/ArcGisFeature/ArcGisSymbologyRenderer.test.js.map +0 -1
  147. package/lib/cjs/test/ArcGisFeature/Mocks.d.ts +0 -7
  148. package/lib/cjs/test/ArcGisFeature/Mocks.d.ts.map +0 -1
  149. package/lib/cjs/test/ArcGisFeature/Mocks.js +0 -19
  150. package/lib/cjs/test/ArcGisFeature/Mocks.js.map +0 -1
  151. package/lib/cjs/test/ArcGisFeature/NewYorkDataset.d.ts +0 -56
  152. package/lib/cjs/test/ArcGisFeature/NewYorkDataset.d.ts.map +0 -1
  153. package/lib/cjs/test/ArcGisFeature/NewYorkDataset.js +0 -420
  154. package/lib/cjs/test/ArcGisFeature/NewYorkDataset.js.map +0 -1
  155. package/lib/cjs/test/ArcGisFeature/PhillyLandmarksDataset.d.ts +0 -1043
  156. package/lib/cjs/test/ArcGisFeature/PhillyLandmarksDataset.d.ts.map +0 -1
  157. package/lib/cjs/test/ArcGisFeature/PhillyLandmarksDataset.js +0 -427
  158. package/lib/cjs/test/ArcGisFeature/PhillyLandmarksDataset.js.map +0 -1
  159. package/lib/cjs/test/coverage/.nyc_output/6abfdfec-4bea-416d-b808-b4b6a26933a0.json +0 -1
  160. package/lib/cjs/test/coverage/.nyc_output/e3a863c9-d93d-496e-88fc-7e67e520c8b6.json +0 -1
  161. package/lib/cjs/test/coverage/.nyc_output/processinfo/6abfdfec-4bea-416d-b808-b4b6a26933a0.json +0 -1
  162. package/lib/cjs/test/coverage/.nyc_output/processinfo/e3a863c9-d93d-496e-88fc-7e67e520c8b6.json +0 -1
  163. package/lib/cjs/test/coverage/.nyc_output/processinfo/index.json +0 -1
  164. package/lib/cjs/test/coverage/cobertura-coverage.xml +0 -1206
  165. package/lib/cjs/test/coverage/lcov-report/base.css +0 -224
  166. package/lib/cjs/test/coverage/lcov-report/block-navigation.js +0 -87
  167. package/lib/cjs/test/coverage/lcov-report/favicon.png +0 -0
  168. package/lib/cjs/test/coverage/lcov-report/index.html +0 -131
  169. package/lib/cjs/test/coverage/lcov-report/prettify.css +0 -1
  170. package/lib/cjs/test/coverage/lcov-report/prettify.js +0 -2
  171. package/lib/cjs/test/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  172. package/lib/cjs/test/coverage/lcov-report/sorter.js +0 -196
  173. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureFormat.ts.html +0 -145
  174. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureJSON.ts.html +0 -550
  175. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeaturePBF.ts.html +0 -730
  176. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureProvider.ts.html +0 -1672
  177. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureQuery.ts.html +0 -763
  178. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureReader.ts.html +0 -223
  179. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureRenderer.ts.html +0 -598
  180. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureResponse.ts.html +0 -301
  181. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisSymbologyRenderer.ts.html +0 -832
  182. package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/index.html +0 -236
  183. package/lib/cjs/test/coverage/lcov-report/src/index.html +0 -131
  184. package/lib/cjs/test/coverage/lcov-report/src/map-layers-formats.ts.html +0 -130
  185. package/lib/cjs/test/coverage/lcov-report/src/mapLayersFormats.ts.html +0 -163
  186. package/lib/cjs/test/coverage/lcov.info +0 -1399
  187. package/lib/cjs/tsconfig.tsbuildinfo +0 -1
  188. package/lib/esm/ArcGisFeature/ArcGisFeatureJSON.d.ts +0 -15
  189. package/lib/esm/ArcGisFeature/ArcGisFeatureJSON.d.ts.map +0 -1
  190. package/lib/esm/ArcGisFeature/ArcGisFeatureJSON.js +0 -129
  191. package/lib/esm/ArcGisFeature/ArcGisFeatureJSON.js.map +0 -1
  192. package/lib/esm/ArcGisFeature/ArcGisFeaturePBF.d.ts.map +0 -1
  193. package/lib/esm/ArcGisFeature/ArcGisFeaturePBF.js.map +0 -1
  194. package/lib/esm/ArcGisFeature/ArcGisFeatureRenderer.d.ts +0 -33
  195. package/lib/esm/ArcGisFeature/ArcGisFeatureRenderer.d.ts.map +0 -1
  196. package/lib/esm/ArcGisFeature/ArcGisFeatureRenderer.js +0 -139
  197. package/lib/esm/ArcGisFeature/ArcGisFeatureRenderer.js.map +0 -1
  198. package/lib/esm/test/ArcGisFeature/ArcGisFeatureFeatureFormats.test.d.ts +0 -2
  199. package/lib/esm/test/ArcGisFeature/ArcGisFeatureFeatureFormats.test.d.ts.map +0 -1
  200. package/lib/esm/test/ArcGisFeature/ArcGisFeatureFeatureFormats.test.js +0 -33
  201. package/lib/esm/test/ArcGisFeature/ArcGisFeatureFeatureFormats.test.js.map +0 -1
  202. package/lib/esm/test/ArcGisFeature/ArcGisFeatureJSON.test.d.ts +0 -2
  203. package/lib/esm/test/ArcGisFeature/ArcGisFeatureJSON.test.d.ts.map +0 -1
  204. package/lib/esm/test/ArcGisFeature/ArcGisFeatureJSON.test.js +0 -160
  205. package/lib/esm/test/ArcGisFeature/ArcGisFeatureJSON.test.js.map +0 -1
  206. package/lib/esm/test/ArcGisFeature/ArcGisFeaturePBF.test.d.ts +0 -2
  207. package/lib/esm/test/ArcGisFeature/ArcGisFeaturePBF.test.d.ts.map +0 -1
  208. package/lib/esm/test/ArcGisFeature/ArcGisFeaturePBF.test.js +0 -166
  209. package/lib/esm/test/ArcGisFeature/ArcGisFeaturePBF.test.js.map +0 -1
  210. package/lib/esm/test/ArcGisFeature/ArcGisFeatureProvider.test.d.ts +0 -2
  211. package/lib/esm/test/ArcGisFeature/ArcGisFeatureProvider.test.d.ts.map +0 -1
  212. package/lib/esm/test/ArcGisFeature/ArcGisFeatureProvider.test.js +0 -810
  213. package/lib/esm/test/ArcGisFeature/ArcGisFeatureProvider.test.js.map +0 -1
  214. package/lib/esm/test/ArcGisFeature/ArcGisFeatureQuery.test.d.ts +0 -2
  215. package/lib/esm/test/ArcGisFeature/ArcGisFeatureQuery.test.d.ts.map +0 -1
  216. package/lib/esm/test/ArcGisFeature/ArcGisFeatureQuery.test.js +0 -102
  217. package/lib/esm/test/ArcGisFeature/ArcGisFeatureQuery.test.js.map +0 -1
  218. package/lib/esm/test/ArcGisFeature/ArcGisFeatureRenderer.test.d.ts +0 -2
  219. package/lib/esm/test/ArcGisFeature/ArcGisFeatureRenderer.test.d.ts.map +0 -1
  220. package/lib/esm/test/ArcGisFeature/ArcGisFeatureRenderer.test.js +0 -213
  221. package/lib/esm/test/ArcGisFeature/ArcGisFeatureRenderer.test.js.map +0 -1
  222. package/lib/esm/test/ArcGisFeature/ArcGisFeatureResponse.test.d.ts +0 -2
  223. package/lib/esm/test/ArcGisFeature/ArcGisFeatureResponse.test.d.ts.map +0 -1
  224. package/lib/esm/test/ArcGisFeature/ArcGisFeatureResponse.test.js +0 -93
  225. package/lib/esm/test/ArcGisFeature/ArcGisFeatureResponse.test.js.map +0 -1
  226. package/lib/esm/test/ArcGisFeature/ArcGisSymbologyRenderer.test.d.ts +0 -2
  227. package/lib/esm/test/ArcGisFeature/ArcGisSymbologyRenderer.test.d.ts.map +0 -1
  228. package/lib/esm/test/ArcGisFeature/ArcGisSymbologyRenderer.test.js +0 -58
  229. package/lib/esm/test/ArcGisFeature/ArcGisSymbologyRenderer.test.js.map +0 -1
  230. package/lib/esm/test/ArcGisFeature/Mocks.d.ts +0 -7
  231. package/lib/esm/test/ArcGisFeature/Mocks.d.ts.map +0 -1
  232. package/lib/esm/test/ArcGisFeature/Mocks.js +0 -16
  233. package/lib/esm/test/ArcGisFeature/Mocks.js.map +0 -1
  234. package/lib/esm/test/ArcGisFeature/NewYorkDataset.d.ts +0 -56
  235. package/lib/esm/test/ArcGisFeature/NewYorkDataset.d.ts.map +0 -1
  236. package/lib/esm/test/ArcGisFeature/NewYorkDataset.js +0 -417
  237. package/lib/esm/test/ArcGisFeature/NewYorkDataset.js.map +0 -1
  238. package/lib/esm/test/ArcGisFeature/PhillyLandmarksDataset.d.ts +0 -1043
  239. package/lib/esm/test/ArcGisFeature/PhillyLandmarksDataset.d.ts.map +0 -1
  240. package/lib/esm/test/ArcGisFeature/PhillyLandmarksDataset.js +0 -424
  241. package/lib/esm/test/ArcGisFeature/PhillyLandmarksDataset.js.map +0 -1
  242. package/lib/esm/tsconfig.tsbuildinfo +0 -1
  243. package/lib/test/junit_results.xml +0 -169
  244. package/map-layers-formats.build.cache.log +0 -2
  245. package/map-layers-formats.cover.log +0 -103
  246. package/map-layers-formats.docs.log +0 -30
  247. package/map-layers-formats.lint.error.log +0 -1
  248. package/map-layers-formats.lint.log +0 -2
  249. package/src/ArcGisFeature/ArcGisFeatureFormat.ts +0 -20
  250. package/src/ArcGisFeature/ArcGisFeatureJSON.ts +0 -155
  251. package/src/ArcGisFeature/ArcGisFeaturePBF.ts +0 -215
  252. package/src/ArcGisFeature/ArcGisFeatureProvider.ts +0 -529
  253. package/src/ArcGisFeature/ArcGisFeatureQuery.ts +0 -226
  254. package/src/ArcGisFeature/ArcGisFeatureReader.ts +0 -46
  255. package/src/ArcGisFeature/ArcGisFeatureRenderer.ts +0 -171
  256. package/src/ArcGisFeature/ArcGisFeatureResponse.ts +0 -72
  257. package/src/ArcGisFeature/ArcGisSymbologyRenderer.ts +0 -249
  258. package/src/ArcGisFeature/esriPBuffer.gen.ts +0 -2612
  259. package/src/map-layers-formats.ts +0 -15
  260. package/src/mapLayersFormats.ts +0 -26
  261. package/src/test/ArcGisFeature/ArcGisFeatureFeatureFormats.test.ts +0 -46
  262. package/src/test/ArcGisFeature/ArcGisFeatureJSON.test.ts +0 -202
  263. package/src/test/ArcGisFeature/ArcGisFeaturePBF.test.ts +0 -227
  264. package/src/test/ArcGisFeature/ArcGisFeatureProvider.test.ts +0 -977
  265. package/src/test/ArcGisFeature/ArcGisFeatureQuery.test.ts +0 -117
  266. package/src/test/ArcGisFeature/ArcGisFeatureRenderer.test.ts +0 -296
  267. package/src/test/ArcGisFeature/ArcGisFeatureResponse.test.ts +0 -109
  268. package/src/test/ArcGisFeature/ArcGisSymbologyRenderer.test.ts +0 -77
  269. package/src/test/ArcGisFeature/Mocks.ts +0 -19
  270. package/src/test/ArcGisFeature/NewYorkDataset.ts +0 -423
  271. package/src/test/ArcGisFeature/PhillyLandmarksDataset.ts +0 -455
  272. package/tsconfig.json +0 -20
@@ -1,812 +0,0 @@
1
- "use strict";
2
- /*---------------------------------------------------------------------------------------------
3
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
4
- * See LICENSE.md in the project root for license terms and full copyright notice.
5
- *--------------------------------------------------------------------------------------------*/
6
- Object.defineProperty(exports, "__esModule", { value: true });
7
- const core_common_1 = require("@itwin/core-common");
8
- const chai = require("chai");
9
- const chaiAsPromised = require("chai-as-promised");
10
- const ArcGisFeatureFormat_1 = require("../../ArcGisFeature/ArcGisFeatureFormat");
11
- const map_layers_formats_1 = require("../../map-layers-formats");
12
- const sinon = require("sinon");
13
- const core_frontend_1 = require("@itwin/core-frontend");
14
- const NewYorkDataset_1 = require("./NewYorkDataset");
15
- const core_bentley_1 = require("@itwin/core-bentley");
16
- const PhillyLandmarksDataset_1 = require("./PhillyLandmarksDataset");
17
- const ArcGisFeatureResponse_1 = require("../../ArcGisFeature/ArcGisFeatureResponse");
18
- const core_geometry_1 = require("@itwin/core-geometry");
19
- const ArcGisFeaturePBF_1 = require("../../ArcGisFeature/ArcGisFeaturePBF");
20
- const ArcGisFeatureJSON_1 = require("../../ArcGisFeature/ArcGisFeatureJSON");
21
- const expect = chai.expect;
22
- chai.use(chaiAsPromised);
23
- const esriFeatureSampleSource = { name: "dummyFeatureLayer", url: "https://dummy.com/SomeGuid/ArcGIS/rest/services/SomeService/FeatureServer", formatId: ArcGisFeatureFormat_1.ArcGisFeatureMapLayerFormat.formatId };
24
- const pngTransparent1x1 = "iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVR42mNkYPhfDwAChwGA60e6kgAAAABJRU5ErkJggg==";
25
- describe("ArcGisFeatureProvider", () => {
26
- const sandbox = sinon.createSandbox();
27
- let fetchStub;
28
- beforeEach(async () => {
29
- // Make sure no call to fetch is made, other it creates leaks
30
- fetchStub = sandbox.stub(core_frontend_1.ArcGISImageryProvider.prototype, "fetch");
31
- });
32
- afterEach(async () => {
33
- sandbox.restore();
34
- });
35
- it("should initialize with valid service metadata", async () => {
36
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
37
- return { accessTokenRequired: false, content: NewYorkDataset_1.NewYorkDataset.serviceCapabilities };
38
- });
39
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function _(_layerId) {
40
- return NewYorkDataset_1.NewYorkDataset.streetsLayerCapabilities;
41
- });
42
- const settings = core_common_1.ImageMapLayerSettings.fromJSON(esriFeatureSampleSource);
43
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
44
- await provider.initialize();
45
- expect(provider._minDepthFromLod).to.equals(11);
46
- expect(provider._maxDepthFromLod).to.equals(22);
47
- });
48
- it("should initialize and set cartoRange without making extra extent request", async () => {
49
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
50
- return { accessTokenRequired: false, content: NewYorkDataset_1.NewYorkDataset.serviceCapabilities };
51
- });
52
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function _(_layerId) {
53
- return NewYorkDataset_1.NewYorkDataset.streetsLayerCapabilities;
54
- });
55
- const setCartoSpy = sandbox.spy(map_layers_formats_1.ArcGisFeatureProvider.prototype, "setCartoRangeFromExtentJson");
56
- const fetchLayerExtentSpy = sandbox.spy(map_layers_formats_1.ArcGisFeatureProvider.prototype, "fetchLayerExtent");
57
- const settings = core_common_1.ImageMapLayerSettings.fromJSON(esriFeatureSampleSource);
58
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
59
- await provider.initialize();
60
- expect(setCartoSpy.called).to.be.true;
61
- expect(setCartoSpy.args[0][0]).to.be.equals(NewYorkDataset_1.NewYorkDataset.streetsLayerCapabilities.extent);
62
- expect(fetchLayerExtentSpy.called).to.be.false;
63
- });
64
- it("should make an extra extent request when none available in layer metadata", async () => {
65
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
66
- return { accessTokenRequired: false, content: NewYorkDataset_1.NewYorkDataset.serviceCapabilities };
67
- });
68
- const setCartoSpy = sandbox.spy(map_layers_formats_1.ArcGisFeatureProvider.prototype, "setCartoRangeFromExtentJson");
69
- const layerExtent = { ...NewYorkDataset_1.NewYorkDataset.streetsLayerCapabilities.extent };
70
- const fetchLayerExtentStub = sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "fetchLayerExtent").callsFake(async function _(_layerId) {
71
- return layerExtent;
72
- });
73
- const layerCapabilitiesNoExtent = { ...NewYorkDataset_1.NewYorkDataset.streetsLayerCapabilities, extent: null };
74
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function _(_layerId) {
75
- return layerCapabilitiesNoExtent;
76
- });
77
- const settings = core_common_1.ImageMapLayerSettings.fromJSON(esriFeatureSampleSource);
78
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
79
- await provider.initialize();
80
- expect(fetchLayerExtentStub.called).to.be.true;
81
- expect(setCartoSpy.called).to.be.true;
82
- expect(setCartoSpy.args[0][0]).to.be.equals(layerExtent);
83
- });
84
- it("should make an extra extent request when none available in layer metadata", async () => {
85
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
86
- return { accessTokenRequired: false, content: NewYorkDataset_1.NewYorkDataset.serviceCapabilities };
87
- });
88
- const setCartoSpy = sandbox.spy(map_layers_formats_1.ArcGisFeatureProvider.prototype, "setCartoRangeFromExtentJson");
89
- const layerExtent = { ...NewYorkDataset_1.NewYorkDataset.streetsLayerCapabilities.extent };
90
- const fetchLayerExtentStub = sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "fetchLayerExtent").callsFake(async function _(_layerId) {
91
- return layerExtent;
92
- });
93
- const layerExtentBadSrs = { ...NewYorkDataset_1.NewYorkDataset.streetsLayerCapabilities };
94
- layerExtentBadSrs.extent.spatialReference.wkid = 1234;
95
- layerExtentBadSrs.extent.spatialReference.latestWkid = 1234;
96
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function _(_layerId) {
97
- return layerExtentBadSrs;
98
- });
99
- const settings = core_common_1.ImageMapLayerSettings.fromJSON(esriFeatureSampleSource);
100
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
101
- await provider.initialize();
102
- expect(fetchLayerExtentStub.called).to.be.true;
103
- expect(setCartoSpy.called).to.be.true;
104
- expect(setCartoSpy.args[0][0]).to.be.equals(layerExtent);
105
- });
106
- it("should set cartoRange from Extent json", async () => {
107
- const newYorkLayerExtent = NewYorkDataset_1.NewYorkDataset.streetsLayerCapabilities.extent;
108
- const settings = core_common_1.ImageMapLayerSettings.fromJSON(esriFeatureSampleSource);
109
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
110
- const west = provider.getEPSG4326Lon(newYorkLayerExtent.xmin);
111
- const south = provider.getEPSG4326Lat(newYorkLayerExtent.ymin);
112
- const east = provider.getEPSG4326Lon(newYorkLayerExtent.xmax);
113
- const north = provider.getEPSG4326Lat(newYorkLayerExtent.ymax);
114
- provider.setCartoRangeFromExtentJson(newYorkLayerExtent);
115
- expect(provider.cartoRange).to.be.not.undefined;
116
- const delta = 0.0000001;
117
- expect(provider.cartoRange.west * core_geometry_1.Angle.degreesPerRadian).to.approximately(west, delta);
118
- expect(provider.cartoRange.south * core_geometry_1.Angle.degreesPerRadian).to.approximately(south, delta);
119
- expect(provider.cartoRange.east * core_geometry_1.Angle.degreesPerRadian).to.approximately(east, delta);
120
- expect(provider.cartoRange.north * core_geometry_1.Angle.degreesPerRadian).to.approximately(north, delta);
121
- });
122
- it("should compose proper request to get extent", async () => {
123
- fetchStub.restore(); // fetch is always stubbed by default, restore and provide our own stub
124
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
125
- return { accessTokenRequired: false, content: NewYorkDataset_1.NewYorkDataset.serviceCapabilities };
126
- });
127
- const layerCapabilitiesNoExtent = { ...NewYorkDataset_1.NewYorkDataset.streetsLayerCapabilities };
128
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function _(_layerId) {
129
- return layerCapabilitiesNoExtent;
130
- });
131
- const referenceExtent = { extent: NewYorkDataset_1.NewYorkDataset.streetsLayerCapabilities.extent };
132
- const stub = sandbox.stub(core_frontend_1.ArcGISImageryProvider.prototype, "fetch").callsFake(async function _(_url, _options) {
133
- const test = {
134
- headers: { "content-type": "json" },
135
- json: async () => {
136
- return referenceExtent;
137
- },
138
- status: 200,
139
- }; // By using unknown type, I can define parts of Response I really need
140
- return test;
141
- });
142
- let layerId = 0;
143
- let expectedUrl = `https://dummy.com/SomeGuid/ArcGIS/rest/services/SomeService/FeatureServer/${layerId}/query?where=1%3D1&outSR=3857&returnExtentOnly=true&f=json`;
144
- let cachedExtent = map_layers_formats_1.ArcGisFeatureProvider._extentCache.get(expectedUrl);
145
- expect(cachedExtent).to.be.undefined;
146
- const settings = core_common_1.ImageMapLayerSettings.fromJSON(esriFeatureSampleSource);
147
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
148
- await provider.initialize();
149
- let fetchExtent = await provider.fetchLayerExtent();
150
- expect(fetchExtent).to.equals(referenceExtent.extent);
151
- expect(stub.getCalls().length).to.equals(1);
152
- expect(stub.args[0][0].toString()).to.be.equals(expectedUrl);
153
- // Check if entry has been created in cache
154
- cachedExtent = map_layers_formats_1.ArcGisFeatureProvider._extentCache.get(expectedUrl);
155
- expect(cachedExtent).to.be.not.undefined;
156
- expect(cachedExtent).to.equals(referenceExtent);
157
- // Make sure cache is used
158
- await provider.fetchLayerExtent();
159
- expect(stub.getCalls().length).to.equals(1);
160
- // Force a different layerId, and check a new request has been made
161
- layerId = 2;
162
- expectedUrl = `https://dummy.com/SomeGuid/ArcGIS/rest/services/SomeService/FeatureServer/${layerId}/query?where=1%3D1&outSR=3857&returnExtentOnly=true&f=json`;
163
- cachedExtent = map_layers_formats_1.ArcGisFeatureProvider._extentCache.get(expectedUrl);
164
- expect(cachedExtent).to.be.undefined;
165
- provider._layerId = layerId;
166
- fetchExtent = await provider.fetchLayerExtent();
167
- expect(fetchExtent).to.equals(referenceExtent.extent);
168
- expect(stub.getCalls().length).to.equals(2);
169
- expect(stub.args[1][0].toString()).to.be.equals(expectedUrl);
170
- // check cache has been updated with a new entry
171
- cachedExtent = map_layers_formats_1.ArcGisFeatureProvider._extentCache.get(expectedUrl);
172
- expect(cachedExtent).to.be.not.undefined;
173
- expect(cachedExtent).to.equals(referenceExtent);
174
- });
175
- it("should not initialize with no service metadata", async () => {
176
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
177
- return undefined;
178
- });
179
- const settings = core_common_1.ImageMapLayerSettings.fromJSON(esriFeatureSampleSource);
180
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
181
- await expect(provider.initialize()).to.be.rejectedWith(core_common_1.ServerError);
182
- });
183
- it("should update status when invalid token error from service", async () => {
184
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
185
- return { accessTokenRequired: false, content: { error: { code: 499 } } };
186
- });
187
- const settings = core_common_1.ImageMapLayerSettings.fromJSON(esriFeatureSampleSource);
188
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
189
- const raiseEventSpy = sandbox.spy(provider.onStatusChanged, "raiseEvent");
190
- await provider.initialize();
191
- expect(provider.status).to.equals(core_frontend_1.MapLayerImageryProviderStatus.RequireAuth);
192
- expect(raiseEventSpy.calledOnceWith(provider)).to.be.true;
193
- });
194
- it("should throw query capability not supported", async () => {
195
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
196
- return { accessTokenRequired: false, content: { capabilities: "Test" } };
197
- });
198
- const settings = core_common_1.ImageMapLayerSettings.fromJSON(esriFeatureSampleSource);
199
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
200
- await expect(provider.initialize()).to.be.rejectedWith(core_common_1.ServerError);
201
- });
202
- it("should pick the first visible sub-layer when multiple visible sub-layers", async () => {
203
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
204
- return { accessTokenRequired: false, content: { capabilities: "Query" } };
205
- });
206
- const settings = core_common_1.ImageMapLayerSettings.fromJSON({
207
- ...esriFeatureSampleSource,
208
- subLayers: [{ id: 0, name: "layer1", visible: true }, { id: 2, name: "layer2", visible: true }]
209
- });
210
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
211
- provider._format = "JSON";
212
- await provider.initialize();
213
- expect(provider._layerId).to.equals(settings.subLayers[0].id);
214
- });
215
- it("should pick sub-layers from service metadata if none provided on layer settings", async () => {
216
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
217
- return { accessTokenRequired: false, content: { capabilities: "Query",
218
- layers: [
219
- {
220
- id: 0,
221
- },
222
- {
223
- id: 1,
224
- },
225
- ] },
226
- };
227
- });
228
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (id) {
229
- if (id === 1) {
230
- return { defaultVisibility: true };
231
- }
232
- return undefined;
233
- });
234
- const settings = core_common_1.ImageMapLayerSettings.fromJSON(esriFeatureSampleSource);
235
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
236
- provider._format = "JSON";
237
- await provider.initialize();
238
- expect(provider._layerId).to.equals(1);
239
- expect(provider._layerMetadata).to.eql({ defaultVisibility: true });
240
- });
241
- it("should throw error if no layers in capabilities", async () => {
242
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
243
- return { accessTokenRequired: false, content: { capabilities: "Query", layers: [] } };
244
- });
245
- const settings = core_common_1.ImageMapLayerSettings.fromJSON(esriFeatureSampleSource);
246
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
247
- await expect(provider.initialize()).to.be.rejectedWith(core_common_1.ServerError);
248
- });
249
- it("should throw if no layer metadata from service", async () => {
250
- const settings = core_common_1.ImageMapLayerSettings.fromJSON({
251
- ...esriFeatureSampleSource,
252
- subLayers: [{ id: 0, name: "layer1", visible: true }, { id: 2, name: "layer2", visible: true }]
253
- });
254
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
255
- return { accessTokenRequired: false, content: { capabilities: "Query" } };
256
- });
257
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
258
- return undefined;
259
- });
260
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
261
- await expect(provider.initialize()).to.be.rejectedWith(core_common_1.ServerError);
262
- });
263
- it("should read supported supported format", async () => {
264
- const settings = core_common_1.ImageMapLayerSettings.fromJSON({
265
- ...esriFeatureSampleSource,
266
- subLayers: [{ id: 0, name: "layer1", visible: true }, { id: 2, name: "layer2", visible: true }]
267
- });
268
- let getLayerMetadataStub = sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
269
- return { defaultVisibility: true, supportedQueryFormats: "PBF, JSON" };
270
- });
271
- const getServiceJsonStub = sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
272
- return { accessTokenRequired: false, content: { capabilities: "Query" } };
273
- });
274
- let provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
275
- await provider.initialize();
276
- expect(provider.format).to.equals("JSON");
277
- // PBF requires 'supportsCoordinatesQuantization'
278
- getServiceJsonStub.restore();
279
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
280
- return { accessTokenRequired: false, content: { currentVersion: 11, capabilities: "Query" } };
281
- });
282
- getLayerMetadataStub.restore();
283
- getLayerMetadataStub = sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
284
- return { defaultVisibility: true, supportsCoordinatesQuantization: true, supportedQueryFormats: "PBF, JSON" };
285
- });
286
- provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
287
- await provider.initialize();
288
- expect(provider.format).to.equals("PBF");
289
- getLayerMetadataStub.restore();
290
- getLayerMetadataStub = sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
291
- return { defaultVisibility: true, supportedQueryFormats: "JSON" };
292
- });
293
- getServiceJsonStub.restore();
294
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
295
- return { accessTokenRequired: false, content: { currentVersion: 10.91, capabilities: "Query", supportsCoordinatesQuantization: true } };
296
- });
297
- provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
298
- await provider.initialize();
299
- expect(provider.format).to.equals("JSON");
300
- getLayerMetadataStub.restore();
301
- getLayerMetadataStub = sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
302
- return { defaultVisibility: true, supportedQueryFormats: "JSON" };
303
- });
304
- provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
305
- await provider.initialize();
306
- expect(provider.format).to.equals("JSON");
307
- getLayerMetadataStub.restore();
308
- getLayerMetadataStub = sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
309
- return { defaultVisibility: true, supportedQueryFormats: "" };
310
- });
311
- provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
312
- await expect(provider.initialize()).to.be.rejectedWith(core_common_1.ServerError);
313
- });
314
- it("should compute minLod/maxLod", async () => {
315
- const settings = core_common_1.ImageMapLayerSettings.fromJSON({
316
- ...esriFeatureSampleSource,
317
- subLayers: [{ id: 0, name: "layer1", visible: true }, { id: 2, name: "layer2", visible: true }]
318
- });
319
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
320
- return {
321
- defaultVisibility: true,
322
- supportedQueryFormats: "PBF, JSON",
323
- minScale: 600000,
324
- maxScale: 5000,
325
- };
326
- });
327
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
328
- return { accessTokenRequired: false, content: { capabilities: "Query" } };
329
- });
330
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
331
- await provider.initialize();
332
- expect(provider._minDepthFromLod).to.equals(9);
333
- expect(provider._maxDepthFromLod).to.equals(15);
334
- });
335
- it("should construct empty url", async () => {
336
- const settings = core_common_1.ImageMapLayerSettings.fromJSON(esriFeatureSampleSource);
337
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
338
- const url = await provider.constructUrl(0, 0, 0);
339
- expect(url).to.equals("");
340
- });
341
- it("should construct feature query url", async () => {
342
- const settings = core_common_1.ImageMapLayerSettings.fromJSON({
343
- ...esriFeatureSampleSource,
344
- subLayers: [{ id: 0, name: "layer1", visible: true }, { id: 2, name: "layer2", visible: true }]
345
- });
346
- let getLayerMetadataStub = sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
347
- return {
348
- defaultVisibility: true,
349
- supportedQueryFormats: "PBF, JSON",
350
- };
351
- });
352
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
353
- return { accessTokenRequired: false, content: { currentVersion: 11, capabilities: "Query" } };
354
- });
355
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
356
- await provider.initialize();
357
- let url = provider.constructFeatureUrl(0, 0, 0, "PBF");
358
- const extent = {
359
- xmin: -20037508.34,
360
- ymin: -20037508.33,
361
- xmax: 20037508.34,
362
- ymax: 20037508.34,
363
- spatialReference: {
364
- wkid: 102100,
365
- latestWkid: 3857,
366
- },
367
- };
368
- expect(url?.url).to.equals("https://dummy.com/SomeGuid/ArcGIS/rest/services/SomeService/FeatureServer/0/query?f=PBF&resultType=tile&maxRecordCountFactor=3&returnExceededLimitFeatures=false&outSR=102100&geometryType=esriGeometryEnvelope&geometry=%7B%22xmin%22%3A-20037508.34%2C%22ymin%22%3A-20037508.339999996%2C%22xmax%22%3A20037508.34%2C%22ymax%22%3A20037508.340000004%2C%22spatialReference%22%3A%7B%22wkid%22%3A102100%2C%22latestWkid%22%3A3857%7D%7D&units=esriSRUnit_Meter&inSR=102100");
369
- expect(url?.envelope?.xmin).to.be.closeTo(extent.xmin, 0.01);
370
- expect(url?.envelope?.ymin).to.be.closeTo(extent.ymin, 0.01);
371
- expect(url?.envelope?.xmax).to.be.closeTo(extent.xmax, 0.01);
372
- expect(url?.envelope?.ymax).to.be.closeTo(extent.ymax, 0.01);
373
- expect(url?.envelope?.spatialReference.wkid).to.be.equal(102100);
374
- expect(url?.envelope?.spatialReference.latestWkid).to.be.equal(3857);
375
- // Now turn ON 'supportsCoordinatesQuantization' to ON
376
- getLayerMetadataStub.restore();
377
- getLayerMetadataStub = sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
378
- return {
379
- defaultVisibility: true,
380
- supportedQueryFormats: "PBF, JSON",
381
- supportsCoordinatesQuantization: true,
382
- };
383
- });
384
- const provider2 = new map_layers_formats_1.ArcGisFeatureProvider(settings);
385
- await provider2.initialize();
386
- url = provider2.constructFeatureUrl(0, 0, 0, "PBF");
387
- expect(url?.url).to.equals("https://dummy.com/SomeGuid/ArcGIS/rest/services/SomeService/FeatureServer/0/query?f=PBF&resultType=tile&maxRecordCountFactor=3&returnExceededLimitFeatures=false&outSR=102100&geometryType=esriGeometryEnvelope&geometry=%7B%22xmin%22%3A-20037508.34%2C%22ymin%22%3A-20037508.339999996%2C%22xmax%22%3A20037508.34%2C%22ymax%22%3A20037508.340000004%2C%22spatialReference%22%3A%7B%22wkid%22%3A102100%2C%22latestWkid%22%3A3857%7D%7D&units=esriSRUnit_Meter&inSR=102100&quantizationParameters=%7B%22mode%22%3A%22view%22%2C%22originPosition%22%3A%22upperLeft%22%2C%22tolerance%22%3A78271.516953125%2C%22extent%22%3A%7B%22xmin%22%3A-20037508.34%2C%22ymin%22%3A-20037508.339999996%2C%22xmax%22%3A20037508.34%2C%22ymax%22%3A20037508.340000004%2C%22spatialReference%22%3A%7B%22wkid%22%3A102100%2C%22latestWkid%22%3A3857%7D%7D%7D");
388
- expect(url?.envelope?.xmin).to.be.closeTo(extent.xmin, 0.01);
389
- expect(url?.envelope?.ymin).to.be.closeTo(extent.ymin, 0.01);
390
- expect(url?.envelope?.xmax).to.be.closeTo(extent.xmax, 0.01);
391
- expect(url?.envelope?.ymax).to.be.closeTo(extent.ymax, 0.01);
392
- expect(url?.envelope?.spatialReference.wkid).to.be.equal(extent.spatialReference.wkid);
393
- expect(url?.envelope?.spatialReference.latestWkid).to.be.equal(extent.spatialReference.latestWkid);
394
- // Test passing an override geometry
395
- const overrideGeom = {
396
- type: "esriGeometryEnvelope",
397
- geom: {
398
- xmin: -50,
399
- ymin: -50,
400
- xmax: 50,
401
- ymax: 50,
402
- spatialReference: {
403
- wkid: 102100,
404
- latestWkid: 3857,
405
- },
406
- },
407
- };
408
- const provider3 = new map_layers_formats_1.ArcGisFeatureProvider(settings);
409
- await provider3.initialize();
410
- url = provider3.constructFeatureUrl(0, 0, 0, "PBF", overrideGeom);
411
- expect(url?.url).to.equals("https://dummy.com/SomeGuid/ArcGIS/rest/services/SomeService/FeatureServer/0/query?f=PBF&resultType=tile&maxRecordCountFactor=3&returnExceededLimitFeatures=false&outSR=102100&geometryType=esriGeometryEnvelope&geometry=%7B%22xmin%22%3A-50%2C%22ymin%22%3A-50%2C%22xmax%22%3A50%2C%22ymax%22%3A50%2C%22spatialReference%22%3A%7B%22wkid%22%3A102100%2C%22latestWkid%22%3A3857%7D%7D&units=esriSRUnit_Meter&inSR=102100&quantizationParameters=%7B%22mode%22%3A%22view%22%2C%22originPosition%22%3A%22upperLeft%22%2C%22tolerance%22%3A78271.516953125%2C%22extent%22%3A%7B%22xmin%22%3A-20037508.34%2C%22ymin%22%3A-20037508.339999996%2C%22xmax%22%3A20037508.34%2C%22ymax%22%3A20037508.340000004%2C%22spatialReference%22%3A%7B%22wkid%22%3A102100%2C%22latestWkid%22%3A3857%7D%7D%7D");
412
- expect(url?.envelope?.xmin).to.be.closeTo(overrideGeom.geom.xmin, 0.01);
413
- expect(url?.envelope?.ymin).to.be.closeTo(overrideGeom.geom.ymin, 0.01);
414
- expect(url?.envelope?.xmax).to.be.closeTo(overrideGeom.geom.xmax, 0.01);
415
- expect(url?.envelope?.ymax).to.be.closeTo(overrideGeom.geom.ymax, 0.01);
416
- expect(url?.envelope?.spatialReference.wkid).to.be.equal(overrideGeom.geom.spatialReference.wkid);
417
- expect(url?.envelope?.spatialReference.latestWkid).to.be.equal(overrideGeom.geom.spatialReference.latestWkid);
418
- // Now test with a different tolerance value
419
- url = provider3.constructFeatureUrl(0, 0, 0, "PBF", overrideGeom, undefined, 10);
420
- expect(url?.url).to.equals("https://dummy.com/SomeGuid/ArcGIS/rest/services/SomeService/FeatureServer/0/query?f=PBF&resultType=tile&maxRecordCountFactor=3&returnExceededLimitFeatures=false&outSR=102100&geometryType=esriGeometryEnvelope&geometry=%7B%22xmin%22%3A-50%2C%22ymin%22%3A-50%2C%22xmax%22%3A50%2C%22ymax%22%3A50%2C%22spatialReference%22%3A%7B%22wkid%22%3A102100%2C%22latestWkid%22%3A3857%7D%7D&units=esriSRUnit_Meter&inSR=102100&quantizationParameters=%7B%22mode%22%3A%22view%22%2C%22originPosition%22%3A%22upperLeft%22%2C%22tolerance%22%3A78271.516953125%2C%22extent%22%3A%7B%22xmin%22%3A-20037508.34%2C%22ymin%22%3A-20037508.339999996%2C%22xmax%22%3A20037508.34%2C%22ymax%22%3A20037508.340000004%2C%22spatialReference%22%3A%7B%22wkid%22%3A102100%2C%22latestWkid%22%3A3857%7D%7D%7D&distance=782715.16953125");
421
- expect(url?.envelope?.xmin).to.be.closeTo(overrideGeom.geom.xmin, 0.01);
422
- expect(url?.envelope?.ymin).to.be.closeTo(overrideGeom.geom.ymin, 0.01);
423
- expect(url?.envelope?.xmax).to.be.closeTo(overrideGeom.geom.xmax, 0.01);
424
- expect(url?.envelope?.ymax).to.be.closeTo(overrideGeom.geom.ymax, 0.01);
425
- expect(url?.envelope?.spatialReference.wkid).to.be.equal(overrideGeom.geom.spatialReference.wkid);
426
- expect(url?.envelope?.spatialReference.latestWkid).to.be.equal(overrideGeom.geom.spatialReference.latestWkid);
427
- });
428
- it("should log error when getFeatureInfo cannot be performed", async () => {
429
- const settings = core_common_1.ImageMapLayerSettings.fromJSON({
430
- ...esriFeatureSampleSource,
431
- subLayers: [{ id: 0, name: "layer1", visible: true }, { id: 2, name: "layer2", visible: true }]
432
- });
433
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
434
- return {
435
- defaultVisibility: true,
436
- supportedQueryFormats: "PBF, JSON",
437
- minScale: 600000,
438
- maxScale: 5000,
439
- };
440
- });
441
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
442
- return { accessTokenRequired: false, content: { currentVersion: 11, capabilities: "Query" } };
443
- });
444
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "constructFeatureUrl").callsFake(function _(_row, _column, _zoomLevel, _format, _geomOverride, _outFields, _tolerance, _returnGeometry) {
445
- return undefined;
446
- });
447
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
448
- await provider.initialize();
449
- const featureInfos = [];
450
- const logErrorSpy = sandbox.spy(core_bentley_1.Logger, "logError");
451
- await provider.getFeatureInfo(featureInfos, new core_frontend_1.QuadId(0, 0, 0), core_common_1.Cartographic.fromDegrees({ latitude: 46, longitude: -71 }), undefined);
452
- expect(featureInfos.length).to.equals(0);
453
- expect(logErrorSpy.called).to.be.true;
454
- });
455
- it("should process data in getFeatureInfo", async () => {
456
- const settings = core_common_1.ImageMapLayerSettings.fromJSON({
457
- ...esriFeatureSampleSource,
458
- subLayers: [{ id: 0, name: "layer1", visible: true }, { id: 2, name: "layer2", visible: true }]
459
- });
460
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
461
- return {
462
- defaultVisibility: true,
463
- supportedQueryFormats: "PBF, JSON",
464
- supportsCoordinatesQuantization: true,
465
- minScale: 600000,
466
- maxScale: 5000,
467
- };
468
- });
469
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
470
- return { accessTokenRequired: false, content: { currentVersion: 11, capabilities: "Query" } };
471
- });
472
- fetchStub.restore(); // fetch is always stubbed by default, restore and provide our own stub
473
- sandbox.stub(core_frontend_1.ArcGISImageryProvider.prototype, "fetch").callsFake(async function _(_url, _options) {
474
- const test = {
475
- headers: { "content-type": "pbf" },
476
- arrayBuffer: async () => {
477
- const byteArray = core_common_1.Base64EncodedString.toUint8Array(PhillyLandmarksDataset_1.PhillyLandmarksDataset.phillyTransportationGetFeatureInfoQueryEncodedPbf);
478
- return Promise.resolve(byteArray ? core_bentley_1.ByteStream.fromUint8Array(byteArray).arrayBuffer : undefined);
479
- },
480
- status: 200,
481
- }; // By using unknown type, I can define parts of Response I really need
482
- return test;
483
- });
484
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
485
- await provider.initialize();
486
- const featureInfos = [];
487
- const logErrorSpy = sandbox.spy(core_bentley_1.Logger, "logError");
488
- await provider.getFeatureInfo(featureInfos, new core_frontend_1.QuadId(0, 0, 0), core_common_1.Cartographic.fromDegrees({ latitude: 46, longitude: -71 }), undefined);
489
- expect(featureInfos.length).to.equals(1);
490
- expect(logErrorSpy.calledOnce).to.be.false;
491
- });
492
- it("should log error when exceed transfert limit", async () => {
493
- const settings = core_common_1.ImageMapLayerSettings.fromJSON({
494
- ...esriFeatureSampleSource,
495
- subLayers: [{ id: 0, name: "layer1", visible: true }, { id: 2, name: "layer2", visible: true }]
496
- });
497
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
498
- return {
499
- defaultVisibility: true,
500
- supportedQueryFormats: "PBF, JSON",
501
- minScale: 600000,
502
- maxScale: 5000,
503
- };
504
- });
505
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
506
- return { accessTokenRequired: false, content: { capabilities: "Query" } };
507
- });
508
- sandbox.stub(ArcGisFeatureResponse_1.ArcGisFeatureResponse.prototype, "getResponseData").callsFake(async function _() {
509
- return { exceedTransferLimit: true, data: undefined };
510
- });
511
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
512
- await provider.initialize();
513
- const featureInfos = [];
514
- const logErrorSpy = sandbox.spy(core_bentley_1.Logger, "logError");
515
- await provider.getFeatureInfo(featureInfos, new core_frontend_1.QuadId(0, 0, 0), core_common_1.Cartographic.fromDegrees({ latitude: 46, longitude: -71 }), undefined);
516
- expect(featureInfos.length).to.equals(0);
517
- expect(logErrorSpy.calledOnce).to.be.true;
518
- });
519
- it("should log error when exceed exception thrown limit", async () => {
520
- const settings = core_common_1.ImageMapLayerSettings.fromJSON({
521
- ...esriFeatureSampleSource,
522
- subLayers: [{ id: 0, name: "layer1", visible: true }, { id: 2, name: "layer2", visible: true }]
523
- });
524
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
525
- return {
526
- defaultVisibility: true,
527
- supportedQueryFormats: "PBF, JSON",
528
- minScale: 600000,
529
- maxScale: 5000,
530
- };
531
- });
532
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
533
- return { accessTokenRequired: false, content: { capabilities: "Query" } };
534
- });
535
- sandbox.stub(ArcGisFeatureResponse_1.ArcGisFeatureResponse.prototype, "getResponseData").callsFake(async function _() {
536
- throw new Error();
537
- });
538
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
539
- await provider.initialize();
540
- const featureInfos = [];
541
- const logErrorSpy = sandbox.spy(core_bentley_1.Logger, "logError");
542
- await provider.getFeatureInfo(featureInfos, new core_frontend_1.QuadId(0, 0, 0), core_common_1.Cartographic.fromDegrees({ latitude: 46, longitude: -71 }), undefined);
543
- expect(featureInfos.length).to.equals(0);
544
- expect(logErrorSpy.calledOnce).to.be.true;
545
- });
546
- it("should debug Feature Geom", async () => {
547
- const settings = core_common_1.ImageMapLayerSettings.fromJSON({
548
- ...esriFeatureSampleSource,
549
- subLayers: [{ id: 0, name: "layer1", visible: true }, { id: 2, name: "layer2", visible: true }]
550
- });
551
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
552
- return {
553
- defaultVisibility: true,
554
- supportedQueryFormats: "PBF, JSON",
555
- minScale: 600000,
556
- maxScale: 5000,
557
- };
558
- });
559
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
560
- return { accessTokenRequired: false, content: { capabilities: "Query" } };
561
- });
562
- sandbox.stub(ArcGisFeatureResponse_1.ArcGisFeatureResponse.prototype, "getResponseData").callsFake(async function _() {
563
- return { data: {
564
- toObject: () => undefined,
565
- } };
566
- });
567
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
568
- await provider.initialize();
569
- provider._debugFeatureGeom = true;
570
- const featureInfos = [];
571
- const logInfoSpy = sandbox.spy(core_bentley_1.Logger, "logInfo");
572
- await provider.getFeatureInfo(featureInfos, new core_frontend_1.QuadId(0, 0, 0), core_common_1.Cartographic.fromDegrees({ latitude: 46, longitude: -71 }), undefined);
573
- expect(featureInfos.length).to.equals(0);
574
- expect(logInfoSpy.callCount).to.equals(2);
575
- });
576
- it("should compute computeTileWorld2CanvasTransform", async () => {
577
- const settings = core_common_1.ImageMapLayerSettings.fromJSON({
578
- ...esriFeatureSampleSource,
579
- subLayers: [{ id: 0, name: "layer1", visible: true }, { id: 2, name: "layer2", visible: true }]
580
- });
581
- const worldSize = 100;
582
- const canvasSize = 10;
583
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
584
- const getEPSG3857ExtentStub = sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getEPSG3857Extent").callsFake(function (_row, _column, _zoomLevel) {
585
- return { left: 0, right: worldSize, bottom: 0, top: worldSize };
586
- });
587
- sandbox.stub(provider, "tileSize").get(function () {
588
- return canvasSize; // return a size of 10 to simplicity
589
- });
590
- let transform = provider.computeTileWorld2CanvasTransform(0, 0, 0);
591
- let worldPoint = core_geometry_1.Point3d.createFrom({ x: worldSize * 0.5, y: worldSize * 0.5, z: 0 });
592
- let transformedPoint = transform?.multiplyPoint3d(worldPoint);
593
- // Make sure center point remains in the center
594
- expect(transformedPoint).to.not.undefined;
595
- expect(transformedPoint.x).to.equals(canvasSize * 0.5);
596
- expect(transformedPoint.y).to.equals(canvasSize * 0.5);
597
- expect(transformedPoint.z).to.equals(0);
598
- // Check that y-axis get flipped
599
- worldPoint = core_geometry_1.Point3d.createFrom({ x: 0, y: 10, z: 0 });
600
- transformedPoint = transform?.multiplyPoint3d(worldPoint);
601
- expect(transformedPoint.x).to.equals(0);
602
- expect(transformedPoint.y).to.equals(9);
603
- expect(transformedPoint.z).to.equals(0);
604
- // Now check translation has been applied (origin shift)
605
- getEPSG3857ExtentStub.restore();
606
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getEPSG3857Extent").callsFake(function (_row, _column, _zoomLevel) {
607
- return { left: worldSize, right: worldSize * 2, bottom: worldSize, top: worldSize * 2 };
608
- });
609
- worldPoint = core_geometry_1.Point3d.createFrom({ x: worldSize, y: worldSize, z: 0 });
610
- transform = provider.computeTileWorld2CanvasTransform(0, 0, 0);
611
- transformedPoint = transform?.multiplyPoint3d(worldPoint);
612
- expect(transformedPoint).to.not.undefined;
613
- expect(transformedPoint.x).to.equals(0);
614
- expect(transformedPoint.y).to.equals(10);
615
- expect(transformedPoint.z).to.equals(0);
616
- });
617
- it("should loadTile from PBF request", async () => {
618
- const settings = core_common_1.ImageMapLayerSettings.fromJSON({
619
- ...esriFeatureSampleSource,
620
- subLayers: [{ id: 0, name: "layer1", visible: true }, { id: 2, name: "layer2", visible: true }]
621
- });
622
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
623
- return {
624
- defaultVisibility: true,
625
- supportedQueryFormats: "PBF",
626
- supportsCoordinatesQuantization: true,
627
- };
628
- });
629
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
630
- return { accessTokenRequired: false, content: { currentVersion: 11, capabilities: "Query" } };
631
- });
632
- sandbox.stub(HTMLCanvasElement.prototype, "getContext").callsFake(function _(_contextId, _options) {
633
- return {};
634
- });
635
- sandbox.stub(HTMLCanvasElement.prototype, "toDataURL").callsFake(function _(_type, _quality) {
636
- return `data:image/png;base64,${pngTransparent1x1}`;
637
- });
638
- const providerStub = sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "fetchTile").callsFake(async function _() {
639
- return new ArcGisFeatureResponse_1.ArcGisFeatureResponse("PBF", Promise.resolve({}));
640
- });
641
- sandbox.stub(ArcGisFeatureResponse_1.ArcGisFeatureResponse.prototype, "getResponseData").callsFake(async function _() {
642
- return {
643
- exceedTransferLimit: false,
644
- data: { toObject: () => undefined },
645
- };
646
- });
647
- // toDataURL string;
648
- const readAndRenderSpy = sandbox.spy(ArcGisFeaturePBF_1.ArcGisFeaturePBF.prototype, "readAndRender");
649
- const computeTransfoSpy = sandbox.spy(map_layers_formats_1.ArcGisFeatureProvider.prototype, "computeTileWorld2CanvasTransform");
650
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
651
- await provider.initialize();
652
- const tileData = await provider.loadTile(0, 0, 0);
653
- expect(tileData).to.not.undefined;
654
- expect(tileData?.data instanceof Uint8Array).to.be.true;
655
- expect(tileData?.data).to.eqls((0, core_bentley_1.base64StringToUint8Array)(pngTransparent1x1));
656
- expect(tileData?.format).to.equals(core_common_1.ImageSourceFormat.Png);
657
- expect(providerStub.calledOnce).to.be.true;
658
- expect(readAndRenderSpy.calledOnce).to.be.true;
659
- expect(computeTransfoSpy.calledOnce).to.be.false; // Should not be called since we have supportsCoordinatesQuantization in layer metadata
660
- });
661
- it("should loadTile from JSON request", async () => {
662
- const settings = core_common_1.ImageMapLayerSettings.fromJSON({
663
- ...esriFeatureSampleSource,
664
- subLayers: [{ id: 0, name: "layer1", visible: true }, { id: 2, name: "layer2", visible: true }]
665
- });
666
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
667
- return {
668
- defaultVisibility: true,
669
- supportedQueryFormats: "JSON",
670
- };
671
- });
672
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
673
- return { accessTokenRequired: false, content: { capabilities: "Query" } };
674
- });
675
- sandbox.stub(HTMLCanvasElement.prototype, "getContext").callsFake(function _(_contextId, _options) {
676
- return {};
677
- });
678
- sandbox.stub(HTMLCanvasElement.prototype, "toDataURL").callsFake(function _(_type, _quality) {
679
- return `data:image/png;base64,${pngTransparent1x1}`;
680
- });
681
- const providerStub = sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "fetchTile").callsFake(async function _() {
682
- return new ArcGisFeatureResponse_1.ArcGisFeatureResponse("JSON", Promise.resolve({}));
683
- });
684
- sandbox.stub(ArcGisFeatureResponse_1.ArcGisFeatureResponse.prototype, "getResponseData").callsFake(async function _() {
685
- return {
686
- exceedTransferLimit: false,
687
- data: { toObject: () => undefined },
688
- };
689
- });
690
- const readAndRenderSpy = sandbox.spy(ArcGisFeatureJSON_1.ArcGisFeatureJSON.prototype, "readAndRender");
691
- const computeTransfoSpy = sandbox.spy(map_layers_formats_1.ArcGisFeatureProvider.prototype, "computeTileWorld2CanvasTransform");
692
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
693
- await provider.initialize();
694
- const tileData = await provider.loadTile(0, 0, 0);
695
- expect(tileData).to.not.undefined;
696
- expect(tileData?.data instanceof Uint8Array).to.be.true;
697
- expect(tileData?.data).to.eqls((0, core_bentley_1.base64StringToUint8Array)(pngTransparent1x1));
698
- expect(tileData?.format).to.equals(core_common_1.ImageSourceFormat.Png);
699
- expect(providerStub.calledOnce).to.be.true;
700
- expect(readAndRenderSpy.calledOnce).to.be.true;
701
- expect(computeTransfoSpy.calledOnce).to.be.true; // Should be called since we dont have _supportsCoordinatesQuantization in layer metadata
702
- });
703
- it("should make sub request if loadtile request return 'exceedTransferLimit'", async () => {
704
- const settings = core_common_1.ImageMapLayerSettings.fromJSON({
705
- ...esriFeatureSampleSource,
706
- subLayers: [{ id: 0, name: "layer1", visible: true }, { id: 2, name: "layer2", visible: true }]
707
- });
708
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
709
- return {
710
- defaultVisibility: true,
711
- supportedQueryFormats: "JSON",
712
- };
713
- });
714
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
715
- return { accessTokenRequired: false, content: { capabilities: "Query" } };
716
- });
717
- sandbox.stub(HTMLCanvasElement.prototype, "getContext").callsFake(function _(_contextId, _options) {
718
- return {};
719
- });
720
- sandbox.stub(HTMLCanvasElement.prototype, "toDataURL").callsFake(function _(_type, _quality) {
721
- return `data:image/png;base64,${pngTransparent1x1}`;
722
- });
723
- const extentSize = 100;
724
- const fetchTileStub = sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "fetchTile").callsFake(async function _() {
725
- const envelope = {
726
- xmin: 0,
727
- ymin: 0,
728
- xmax: extentSize,
729
- ymax: extentSize,
730
- spatialReference: {
731
- wkid: 102100,
732
- latestWkid: 3857,
733
- }
734
- };
735
- return new ArcGisFeatureResponse_1.ArcGisFeatureResponse("JSON", Promise.resolve({}), envelope);
736
- });
737
- let firstCall = true;
738
- sandbox.stub(ArcGisFeatureResponse_1.ArcGisFeatureResponse.prototype, "getResponseData").callsFake(async function _() {
739
- const exceed = firstCall === true;
740
- firstCall = false;
741
- return {
742
- exceedTransferLimit: exceed,
743
- data: { toObject: () => undefined },
744
- };
745
- });
746
- const readAndRenderSpy = sandbox.spy(ArcGisFeatureJSON_1.ArcGisFeatureJSON.prototype, "readAndRender");
747
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
748
- await provider.initialize();
749
- await provider.loadTile(0, 0, 0);
750
- // We should have 5 calls:
751
- // Call #1 : initial call for 0,0,0 and it returns 'exceedTransferLimit'
752
- // Calls #2-5: Four calls which represent a call for each sub-envelope (initial extent divided by 4)
753
- expect(fetchTileStub.getCalls().length).to.equals(5);
754
- expect(fetchTileStub.getCalls()[1].args[3]).to.eqls({
755
- xmin: 0, ymin: 0, xmax: extentSize * 0.5, ymax: extentSize * 0.5,
756
- spatialReference: { wkid: 102100, latestWkid: 3857,
757
- }
758
- });
759
- expect(fetchTileStub.getCalls()[2].args[3]).to.eqls({
760
- xmin: 0, ymin: extentSize * 0.5, xmax: extentSize * 0.5, ymax: extentSize,
761
- spatialReference: { wkid: 102100, latestWkid: 3857,
762
- }
763
- });
764
- expect(fetchTileStub.getCalls()[3].args[3]).to.eqls({
765
- xmin: extentSize * 0.5, ymin: 0, xmax: extentSize, ymax: extentSize * 0.5,
766
- spatialReference: { wkid: 102100, latestWkid: 3857,
767
- }
768
- });
769
- expect(fetchTileStub.getCalls()[4].args[3]).to.eqls({
770
- xmin: extentSize * 0.5, ymin: extentSize * 0.5, xmax: extentSize, ymax: extentSize,
771
- spatialReference: { wkid: 102100, latestWkid: 3857,
772
- }
773
- });
774
- expect(readAndRenderSpy.getCalls().length).to.equals(4);
775
- });
776
- it("fetchTile should return undefined when to format defined", async () => {
777
- const settings = core_common_1.ImageMapLayerSettings.fromJSON({
778
- ...esriFeatureSampleSource,
779
- subLayers: [{ id: 0, name: "layer1", visible: true }, { id: 2, name: "layer2", visible: true }]
780
- });
781
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
782
- // make a first request with init, should return undefined because of missing format
783
- const tileData = await provider.fetchTile(0, 0, 0);
784
- expect(tileData).to.be.undefined;
785
- });
786
- it("fetchTile should call fetch with the proper URL", async () => {
787
- const settings = core_common_1.ImageMapLayerSettings.fromJSON({
788
- ...esriFeatureSampleSource,
789
- subLayers: [{ id: 0, name: "layer1", visible: true }, { id: 2, name: "layer2", visible: true }]
790
- });
791
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
792
- return {
793
- defaultVisibility: true,
794
- supportedQueryFormats: "JSON",
795
- };
796
- });
797
- sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
798
- return { accessTokenRequired: false, content: { capabilities: "Query" } };
799
- });
800
- sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "constructFeatureUrl").callsFake(function _(_row, _column, _zoomLevel, _format, _geomOverride, _outFields, _tolerance, _returnGeometry) {
801
- return { url: settings.url };
802
- });
803
- const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
804
- await provider.initialize();
805
- const response = await provider.fetchTile(0, 0, 0);
806
- expect(response).to.not.undefined;
807
- expect(fetchStub.calledOnce).to.be.true;
808
- const test1 = fetchStub.getCall(0).firstArg;
809
- expect(test1.toString()).to.equals(new URL(settings.url).toString());
810
- });
811
- });
812
- //# sourceMappingURL=ArcGisFeatureProvider.test.js.map