@itwin/map-layers-formats 3.6.0-dev.53 → 3.6.0-dev.55

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