@itwin/map-layers-formats 4.10.0-dev.9 → 5.0.0-dev.0

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 (36) hide show
  1. package/CHANGELOG.md +21 -1
  2. package/lib/cjs/ArcGisFeature/ArcGisFeatureProvider.d.ts.map +1 -1
  3. package/lib/cjs/ArcGisFeature/ArcGisFeatureProvider.js +12 -10
  4. package/lib/cjs/ArcGisFeature/ArcGisFeatureProvider.js.map +1 -1
  5. package/lib/cjs/ArcGisFeature/ArcGisFeatureQuery.d.ts +8 -1
  6. package/lib/cjs/ArcGisFeature/ArcGisFeatureQuery.d.ts.map +1 -1
  7. package/lib/cjs/ArcGisFeature/ArcGisFeatureQuery.js +8 -1
  8. package/lib/cjs/ArcGisFeature/ArcGisFeatureQuery.js.map +1 -1
  9. package/lib/cjs/ArcGisFeature/ArcGisFeatureResponse.d.ts.map +1 -1
  10. package/lib/cjs/ArcGisFeature/ArcGisFeatureResponse.js +3 -2
  11. package/lib/cjs/ArcGisFeature/ArcGisFeatureResponse.js.map +1 -1
  12. package/lib/cjs/ArcGisFeature/ArcGisSymbologyRenderer.d.ts.map +1 -1
  13. package/lib/cjs/ArcGisFeature/esriPBuffer.gen.d.ts +69 -364
  14. package/lib/cjs/ArcGisFeature/esriPBuffer.gen.d.ts.map +1 -1
  15. package/lib/cjs/Feature/FeatureInfoReader.d.ts.map +1 -1
  16. package/lib/cjs/GeoJSON/GeoJSONGeometry.d.ts +3 -3
  17. package/lib/cjs/OgcApiFeatures/OgcApiFeaturesProvider.js +3 -3
  18. package/lib/cjs/OgcApiFeatures/OgcApiFeaturesProvider.js.map +1 -1
  19. package/lib/esm/ArcGisFeature/ArcGisFeatureProvider.d.ts.map +1 -1
  20. package/lib/esm/ArcGisFeature/ArcGisFeatureProvider.js +13 -11
  21. package/lib/esm/ArcGisFeature/ArcGisFeatureProvider.js.map +1 -1
  22. package/lib/esm/ArcGisFeature/ArcGisFeatureQuery.d.ts +8 -1
  23. package/lib/esm/ArcGisFeature/ArcGisFeatureQuery.d.ts.map +1 -1
  24. package/lib/esm/ArcGisFeature/ArcGisFeatureQuery.js +7 -0
  25. package/lib/esm/ArcGisFeature/ArcGisFeatureQuery.js.map +1 -1
  26. package/lib/esm/ArcGisFeature/ArcGisFeatureResponse.d.ts.map +1 -1
  27. package/lib/esm/ArcGisFeature/ArcGisFeatureResponse.js +3 -2
  28. package/lib/esm/ArcGisFeature/ArcGisFeatureResponse.js.map +1 -1
  29. package/lib/esm/ArcGisFeature/ArcGisSymbologyRenderer.d.ts.map +1 -1
  30. package/lib/esm/ArcGisFeature/esriPBuffer.gen.d.ts +69 -364
  31. package/lib/esm/ArcGisFeature/esriPBuffer.gen.d.ts.map +1 -1
  32. package/lib/esm/Feature/FeatureInfoReader.d.ts.map +1 -1
  33. package/lib/esm/GeoJSON/GeoJSONGeometry.d.ts +3 -3
  34. package/lib/esm/OgcApiFeatures/OgcApiFeaturesProvider.js +3 -3
  35. package/lib/esm/OgcApiFeatures/OgcApiFeaturesProvider.js.map +1 -1
  36. package/package.json +16 -16
@@ -1 +1 @@
1
- {"version":3,"file":"FeatureInfoReader.d.ts","sourceRoot":"","sources":["../../../src/Feature/FeatureInfoReader.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,UAAU,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAEtE;;GAEG;AACH,8BAAsB,iBAAiB;IAG9B,cAAc,EAAE,MAAM,GAAC,SAAS,CAAC;IAIjC,0BAA0B,UAAS;IAE1C,SAAS,CAAC,qBAAqB,UAAW,MAAM,YAE9C;IAEF,SAAS,CAAC,eAAe,aAAc,iBAAiB,SAAS,WAAW,KAAK,GAAC,SAAS,YASzF;CAEH"}
1
+ {"version":3,"file":"FeatureInfoReader.d.ts","sourceRoot":"","sources":["../../../src/Feature/FeatureInfoReader.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,UAAU,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAEtE;;GAEG;AACH,8BAAsB,iBAAiB;IAG9B,cAAc,EAAE,MAAM,GAAC,SAAS,CAAC;IAIjC,0BAA0B,UAAS;IAE1C,SAAS,CAAC,qBAAqB,UAAW,MAAM,YAE9C;IAEF,SAAS,CAAC,eAAe,aAAc,iBAAiB,SAAS,UAAU,CAAC,KAAK,GAAC,SAAS,YASzF;CAEH"}
@@ -11,8 +11,8 @@ export interface MultiPath {
11
11
  }
12
12
  /** @internal */
13
13
  export declare class GeoJSONGeometryUtils {
14
- static isRingOrPath(geom: GeoJson.Geometry): boolean;
15
- static isFilled(geom: GeoJson.Geometry): boolean;
16
- static isPoint(geom: GeoJson.Geometry): boolean;
14
+ static isRingOrPath(geom: GeoJson.Geometry): geom is GeoJson.LineString | GeoJson.MultiLineString | GeoJson.Polygon | GeoJson.MultiPolygon;
15
+ static isFilled(geom: GeoJson.Geometry): geom is GeoJson.Polygon | GeoJson.MultiPolygon;
16
+ static isPoint(geom: GeoJson.Geometry): geom is GeoJson.Point | GeoJson.MultiPoint;
17
17
  }
18
18
  //# sourceMappingURL=GeoJSONGeometry.d.ts.map
@@ -314,7 +314,7 @@ class OgcApiFeaturesProvider extends core_frontend_1.MapLayerImageryProvider {
314
314
  }
315
315
  }
316
316
  }
317
- catch (_e) {
317
+ catch {
318
318
  core_bentley_1.Logger.logError(loggerCategory, "Unknown error occurred when index static data");
319
319
  success = false;
320
320
  }
@@ -380,7 +380,7 @@ class OgcApiFeaturesProvider extends core_frontend_1.MapLayerImageryProvider {
380
380
  try {
381
381
  data = await this.fetchItems(url, this._tileModeFetchTimeout);
382
382
  }
383
- catch (_e) {
383
+ catch {
384
384
  }
385
385
  if (!data) {
386
386
  core_bentley_1.Logger.logError(loggerCategory, "Could not fetch OgcApiFeatures data.");
@@ -459,7 +459,7 @@ class OgcApiFeaturesProvider extends core_frontend_1.MapLayerImageryProvider {
459
459
  try {
460
460
  data = await this.fetchItems(url, this._tileModeFetchTimeout);
461
461
  }
462
- catch (_e) {
462
+ catch {
463
463
  }
464
464
  if (!data) {
465
465
  core_bentley_1.Logger.logError(loggerCategory, "Could not fetch OgcApiFeatures data.");
@@ -1 +1 @@
1
- {"version":3,"file":"OgcApiFeaturesProvider.js","sourceRoot":"","sources":["../../../src/OgcApiFeatures/OgcApiFeaturesProvider.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n\r\nimport { FeatureGraphicsRenderer, HitDetail, ImageryMapTileTree, MapCartoRectangle, MapFeatureInfoOptions, MapLayerFeatureInfo, MapLayerImageryProvider, QuadId, WGS84Extent } from \"@itwin/core-frontend\";\r\nimport { EsriPMS, EsriPMSProps, EsriRenderer, EsriSFS, EsriSFSProps, EsriSLS, EsriSLSProps, EsriSymbol } from \"../ArcGisFeature/EsriSymbology\";\r\nimport { Cartographic, ColorDef, ImageMapLayerSettings, ImageSource, ImageSourceFormat, ServerError, SubLayerId } from \"@itwin/core-common\";\r\nimport { Matrix4d, Point3d, Range2d } from \"@itwin/core-geometry\";\r\nimport { ArcGisSymbologyCanvasRenderer } from \"../ArcGisFeature/ArcGisSymbologyRenderer\";\r\nimport { FeatureCanvasRenderer } from \"../Feature/FeatureCanvasRenderer\";\r\nimport { base64StringToUint8Array, IModelStatus, Logger } from \"@itwin/core-bentley\";\r\nimport * as Geojson from \"geojson\";\r\nimport { FeatureDefaultSymbology } from \"../Feature/FeatureSymbology\";\r\nimport { OgcApiFeaturesReader } from \"./OgcApiFeaturesReader\";\r\nimport { RandomMapColor } from \"../Feature/RandomMapColor\";\r\nimport { DefaultMarkerIcon } from \"../Feature/DefaultMarkerIcon\";\r\n\r\nconst loggerCategory = \"MapLayersFormats.OgcApiFeatures\";\r\nconst dataUrlHeaderToken = \"base64,\";\r\n\r\n/** Provide tiles from a ESRI ArcGIS Feature service\r\n* @internal\r\n*/\r\nexport class DefaultOgcSymbology implements FeatureDefaultSymbology {\r\n\r\n private static readonly _defaultPMSProps: Omit<EsriPMSProps, \"imageData\" | \"contentType\"> = {\r\n type: \"esriPMS\",\r\n url: \"\",\r\n width: 16,\r\n height: 24,\r\n // We want the anchor point to be the bottom of the push pin, so apply offset on the y-axis (anchor point is already in the center of the icon)\r\n xoffset: 0,\r\n yoffset: -12,\r\n };\r\n private _defaultPMS: EsriPMS;\r\n\r\n private static readonly _defaultSLSProps: EsriSLSProps = {\r\n type: \"esriSLS\",\r\n color: [0, 0, 255, 255],\r\n width: 1,\r\n style: \"esriSLSSolid\",\r\n };\r\n private _defaultSLS: EsriSLS;\r\n\r\n private static readonly _defaultSFSProps: EsriSFSProps = {\r\n type: \"esriSFS\",\r\n color: [0, 0, 255, 255], // blue fill\r\n style: \"esriSFSSolid\",\r\n outline: DefaultOgcSymbology._defaultSLSProps,\r\n };\r\n private _defaultSFS = EsriSFS.fromJSON(DefaultOgcSymbology._defaultSFSProps);\r\n\r\n public constructor(randomColor?: RandomMapColor) {\r\n const color = randomColor ? randomColor.getColorDef() : ColorDef.blue;\r\n this._defaultPMS = EsriPMS.fromJSON( {\r\n ...DefaultMarkerIcon.getContent(color),\r\n type: \"esriPMS\",\r\n url: \"\",\r\n width: 16,\r\n height: 24,\r\n xoffset: 0,\r\n yoffset: -12,\r\n });\r\n\r\n const randomColors = color.colors;\r\n const newSLSProps = {\r\n ...DefaultOgcSymbology._defaultSLSProps,\r\n color: [randomColors.r, randomColors.g, randomColors.b, 255],\r\n };\r\n this._defaultSLS = EsriSLS.fromJSON(newSLSProps);\r\n this._defaultSFS = EsriSFS.fromJSON({\r\n ...DefaultOgcSymbology._defaultSFSProps,\r\n color: [randomColors.r, randomColors.g, randomColors.b, 255],\r\n outline: {\r\n ...DefaultOgcSymbology._defaultSLSProps,\r\n color: [0, 0, 0, 255],\r\n },\r\n });\r\n }\r\n\r\n public async initialize() {\r\n // Marker image need to be loaded upfront;\r\n await this._defaultPMS.loadImage();\r\n }\r\n\r\n public getSymbology(geometryType: string): EsriSymbol {\r\n if (geometryType === \"LineString\"|| geometryType === \"MultiLineString\" )\r\n return this._defaultSLS;\r\n else if (geometryType === \"Polygon\"|| geometryType === \"MultiPolygon\" )\r\n return this._defaultSFS;\r\n else if (geometryType === \"Point\"|| geometryType === \"MultiPoint\" )\r\n return this._defaultPMS;\r\n\r\n throw new Error(`Could not get default symbology for geometry type ${geometryType}`);\r\n }\r\n}\r\n/** @internal */\r\nexport class OgcApiFeaturesProvider extends MapLayerImageryProvider {\r\n\r\n // Debug flags, should always be committed to FALSE !\r\n private readonly _drawDebugInfo = false;\r\n /// ////////////////////////////\r\n\r\n private readonly _limitParamMaxValue = 10000; // This is documented in OGC Features specification; a single items request never returns more than 10 000 items\r\n private readonly _tiledModeMinLod = 14;\r\n private readonly _staticModeFetchTimeout = 10000;\r\n private readonly _tileModeFetchTimeout = 10000;\r\n private readonly _forceTileMode = false;\r\n private _spatialIdx: any;\r\n private _defaultSymbol = new DefaultOgcSymbology(new RandomMapColor());\r\n private _renderer: EsriRenderer|undefined;\r\n private _collectionUrl = \"\";\r\n private _itemsUrl = \"\";\r\n private readonly _itemsCrs = \"http://www.opengis.net/def/crs/OGC/1.3/CRS84\"; // Fixed fow now\r\n private _queryables: any;\r\n\r\n public serviceJson: any;\r\n private _staticData: Geojson.FeatureCollection|undefined;\r\n\r\n constructor(settings: ImageMapLayerSettings) {\r\n super(settings, true);\r\n }\r\n\r\n public override get supportsMapFeatureInfo() { return true;}\r\n public override get minimumZoomLevel(): number { return this.staticMode ? super.minimumZoomLevel : this._tiledModeMinLod; }\r\n public get staticMode(): boolean { return !!(this._spatialIdx && this._staticData && !this._forceTileMode); }\r\n\r\n public override async initialize(): Promise<void> {\r\n\r\n this._collectionUrl = this._settings.url;\r\n let layerId: SubLayerId|undefined;\r\n\r\n // OGC Feature service request can only serve data for a single feature\r\n // so if multiple sub-layer ids are specified, we pick the first one.\r\n if (this._settings.subLayers && this._settings.subLayers.length > 0) {\r\n layerId = this._settings.subLayers[0].id;\r\n }\r\n\r\n const readCollectionsPage = (data: any) => {\r\n const collection = data.collections.find((col: any)=> col.id === layerId);\r\n const collectionLinks = collection?.links;\r\n if (!collectionLinks) {\r\n const msg = `Missing layer id or matching collection could not be found`;\r\n Logger.logError(loggerCategory, msg);\r\n throw new Error(msg);\r\n }\r\n const collectionLink = collectionLinks.find((link: any)=> link.rel.includes(\"collection\") && link.type === \"application/json\",\r\n );\r\n this._collectionUrl = collectionLink.href;\r\n };\r\n\r\n const layerIdMismatch = () => {\r\n const msg = `Collection metadata and sub-layers id mismatch`;\r\n Logger.logError(loggerCategory, msg);\r\n throw new Error(msg);\r\n };\r\n let collectionMetadata: any;\r\n let json = await this.fetchMetadata(this._settings.url);\r\n if (json?.type === \"FeatureCollection\") {\r\n // We landed on the items page, we need to look for the collection metadata url\r\n if (Array.isArray(json.links)) {\r\n const collectionLink = json.links.find((link: any)=> link.rel.includes(\"collection\") && link.type === \"application/json\");\r\n this._collectionUrl = collectionLink.href;\r\n }\r\n } else if (json.itemType === \"feature\") {\r\n // We landed on a specific collection page.\r\n collectionMetadata = json;\r\n\r\n // Check if the collection id matches at least one sub-layer\r\n if (this._settings.subLayers && this._settings.subLayers.length > 0) {\r\n const subLayer = this._settings.subLayers.find((s)=>s.id === collectionMetadata.id);\r\n if (subLayer)\r\n layerId = subLayer.id;\r\n } else {\r\n // No sub-layers were specified, defaults to collection id.\r\n layerId = collectionMetadata.id;\r\n }\r\n\r\n } else if (Array.isArray(json.collections)) {\r\n // We landed in the \"Collections\" page\r\n // Find to find the specified layer id among the available collections\r\n readCollectionsPage(json);\r\n } else if (Array.isArray(json.links)) {\r\n // This might be the main landing page\r\n // We need to find the the \"Collections\" page\r\n const collectionsLink = json.links.find((link: any)=> link.rel.includes(\"data\") && link.type === \"application/json\");\r\n if (!collectionsLink) {\r\n Logger.logError(loggerCategory, \"Could not find collections link\");\r\n throw new ServerError(IModelStatus.ValidationFailed, \"\");\r\n }\r\n\r\n json = await this.fetchMetadata(collectionsLink.href);\r\n if (Array.isArray(json.collections)) {\r\n readCollectionsPage(json);\r\n }\r\n }\r\n\r\n // Read collection metadata\r\n if (!collectionMetadata)\r\n collectionMetadata = await this.fetchMetadata(this._collectionUrl);\r\n\r\n if (layerId !== undefined && layerId !== collectionMetadata.id) {\r\n layerIdMismatch();\r\n }\r\n\r\n // Read cartographic range\r\n if (Array.isArray(collectionMetadata?.extent?.spatial?.bbox)\r\n && collectionMetadata.extent.spatial.bbox.length > 0\r\n && collectionMetadata.extent.spatial.crs === this._itemsCrs\r\n ) {\r\n const firstBbox = collectionMetadata.extent.spatial?.bbox[0];\r\n this.cartoRange = MapCartoRectangle.fromDegrees(firstBbox[0], firstBbox[1], firstBbox[2], firstBbox[3]);\r\n }\r\n\r\n // Read important links\r\n let queryablesHref: string|undefined;\r\n let itemsHref: string|undefined;\r\n if (Array.isArray(collectionMetadata?.links)) {\r\n // Items links (Mandatory)\r\n const itemsLink = collectionMetadata.links.find((link: any)=> link.rel.includes(\"items\") && link.type === \"application/geo+json\");\r\n itemsHref = itemsLink.href;\r\n\r\n // Queryables link (Optional)\r\n const queryablesLink = collectionMetadata.links.find((link: any)=> link.rel.includes(\"queryables\") && link.type === \"application/schema+json\");\r\n queryablesHref = queryablesLink.href;\r\n\r\n }\r\n\r\n if (itemsHref)\r\n this._itemsUrl = itemsHref;\r\n else {\r\n const msg = \"Unable to find items link on collection\";\r\n Logger.logError(loggerCategory, msg);\r\n throw new Error(msg);\r\n }\r\n if (queryablesHref)\r\n this._queryables = await this.fetchMetadata(queryablesHref);\r\n\r\n if (!this._forceTileMode) {\r\n const status = await this.fetchAllItems();\r\n if (status) {\r\n await this.indexStaticData();\r\n }\r\n }\r\n\r\n await this._defaultSymbol.initialize(); // images must be loaded upfront\r\n }\r\n\r\n private async fetchMetadata(url: string): Promise<any> {\r\n const tmpUrl = this.appendCustomParams(url);\r\n const response = await this.makeRequest(tmpUrl);\r\n return response.json();\r\n }\r\n\r\n private async fetchAllItems() {\r\n const urlObj = new URL(this._itemsUrl);\r\n urlObj.searchParams.append(\"limit\", `${this._limitParamMaxValue}`);\r\n const url = this.appendCustomParams(urlObj.toString());\r\n this._staticData = await this.fetchItems(url, this._staticModeFetchTimeout);\r\n return this._staticData ? true : false;\r\n }\r\n\r\n private async fetchItems(url: string, timeout: number) {\r\n let data: any;\r\n let success = true;\r\n try {\r\n const fetchBegin = Date.now();\r\n let tmpUrl = this.appendCustomParams(url);\r\n let response = await this.makeTileRequest(tmpUrl, timeout);\r\n let json = await response.json();\r\n data = json;\r\n // Follow \"next\" link if any\r\n let nextLink = json.links?.find((link: any)=>link.rel === \"next\");\r\n while (nextLink && (Date.now() - fetchBegin) < timeout && success) {\r\n tmpUrl = this.appendCustomParams(nextLink.href);\r\n response = await this.makeTileRequest(tmpUrl, this._staticModeFetchTimeout);\r\n json = await response.json();\r\n if (json?.features)\r\n data!.features = this._staticData?.features ? [...this._staticData.features, ...json.features] : json.features;\r\n else\r\n success = false;\r\n nextLink = json.links?.find((link: any)=>link.rel === \"next\");\r\n }\r\n if (Date.now() - fetchBegin >= this._staticModeFetchTimeout) {\r\n // We ran out of time, let switch to tile mode\r\n success = false;\r\n }\r\n } catch (e) {\r\n success = false;\r\n if (e instanceof DOMException && e.name === \"AbortError\") {\r\n Logger.logInfo(loggerCategory, \"Request to fetch all features time out, switching to tile mode.\");\r\n } else {\r\n Logger.logError(loggerCategory, \"Unknown error occurred when fetching OgcApiFeatures data.\");\r\n }\r\n }\r\n return success ? data : undefined;\r\n }\r\n\r\n // Read features range and build in-memory spatial index\r\n private async indexStaticData() {\r\n // UGLY IMPORT:\r\n // flatbush only provides ECM modules, and since mocha is not very good with ECM modules,\r\n // we need to have this special import, until we replace mocha with something else.\r\n const flatbush = (await import(\"flatbush\")).default;\r\n let success = true;\r\n try {\r\n const datasetRange = new Range2d();\r\n const buildPositionRange = (coords: Geojson.Position, range: Range2d) => range.extendXY(coords[0], coords[1]);\r\n const buildPositionArrayRange = (coords: Geojson.Position[], range: Range2d) => coords.forEach((position) => buildPositionRange(position, range) );\r\n const buildDoublePositionRange = (coords: Geojson.Position[][], range: Range2d) => coords.forEach((position) => buildPositionArrayRange(position, range) );\r\n const buildTriplePositionRange = (coords: Geojson.Position[][][], range: Range2d) => coords.forEach((position) => buildDoublePositionRange(position, range) );\r\n\r\n const readGeomRange = (geom: Geojson.Geometry, range: Range2d) => {\r\n if (geom.type === \"Point\")\r\n buildPositionRange(geom.coordinates, range);\r\n else if (geom.type === \"LineString\" || geom.type === \"MultiPoint\")\r\n buildPositionArrayRange(geom.coordinates, range);\r\n else if (geom.type === \"Polygon\" || geom.type === \"MultiLineString\")\r\n buildDoublePositionRange(geom.coordinates, range);\r\n else if (geom.type === \"MultiPolygon\" )\r\n buildTriplePositionRange(geom.coordinates, range);\r\n };\r\n\r\n if (this._staticData && Array.isArray(this._staticData.features)) {\r\n this._spatialIdx = new flatbush(this._staticData.features.length);\r\n this._staticData.features.forEach((feature: Geojson.Feature) => {\r\n try {\r\n if (feature.geometry.type === \"LineString\"\r\n || feature.geometry.type === \"MultiLineString\"\r\n || feature.geometry.type === \"Point\"\r\n || feature.geometry.type === \"MultiPoint\"\r\n || feature.geometry.type === \"Polygon\"\r\n || feature.geometry.type === \"MultiPolygon\"\r\n ) {\r\n readGeomRange(feature.geometry, datasetRange);\r\n this._spatialIdx?.add(datasetRange.xLow, datasetRange.yLow, datasetRange.xHigh,datasetRange. yHigh);\r\n datasetRange.setNull();\r\n } else if (feature.geometry.type === \"GeometryCollection\") {\r\n feature.geometry.geometries.forEach((geom) => {\r\n readGeomRange(geom, datasetRange);\r\n this._spatialIdx?.add(datasetRange.xLow, datasetRange.yLow, datasetRange.xHigh,datasetRange. yHigh);\r\n });\r\n datasetRange.setNull();\r\n }\r\n } catch (e: any) {\r\n Logger.logInfo(loggerCategory, `Unknown error occurred indexing feature: ${e.message}`);\r\n success = false;\r\n }\r\n });\r\n\r\n if (success) {\r\n this._spatialIdx.finish();\r\n }\r\n }\r\n\r\n } catch (_e) {\r\n Logger.logError(loggerCategory, \"Unknown error occurred when index static data\");\r\n success = false;\r\n }\r\n return success;\r\n }\r\n\r\n public override get tileSize(): number { return 512; }\r\n\r\n // We don't use this method inside this provider (see constructFeatureUrl), but since this is an abstract method, we need to define something\r\n public async constructUrl(_row: number, _column: number, _zoomLevel: number): Promise<string> {\r\n return \"\";\r\n }\r\n\r\n public drawTileDebugInfo(row: number, column: number, zoomLevel: number, context: CanvasRenderingContext2D) {\r\n context.fillStyle = \"cyan\";\r\n context.strokeRect(0, 0, this.tileSize, this.tileSize);\r\n context.font = \"30px Arial\";\r\n context.lineWidth = 5;\r\n context.fillText(`${zoomLevel}-${row}-${column}`, 10, 50);\r\n }\r\n\r\n // Compute transform that provides coordinates in the canvas coordinate system (pixels, origin = top-left)\r\n // from coordinate in world\r\n public computeTileWorld2CanvasTransform(row: number, column: number, zoomLevel: number) {\r\n\r\n const tileExtentWorld4326 = this.getEPSG4326Extent(row, column, zoomLevel);\r\n const worldTileWidth = tileExtentWorld4326.longitudeRight - tileExtentWorld4326.longitudeLeft;\r\n const worldTileHeight = tileExtentWorld4326.latitudeTop - tileExtentWorld4326.latitudeBottom;\r\n const canvasTileWidth = this.tileSize;\r\n const canvasTileHeight = this.tileSize;\r\n const world2CanvasRatioX = canvasTileWidth / worldTileWidth;\r\n const world2CanvasRatioY = canvasTileHeight / worldTileHeight;\r\n const worldTileOrigin = Point3d.create(tileExtentWorld4326.longitudeLeft, tileExtentWorld4326.latitudeBottom);\r\n const worldTileExtent = Point3d.create(tileExtentWorld4326.longitudeRight, tileExtentWorld4326.latitudeTop);\r\n const canvasTileOriginOffset = worldTileOrigin.clone();\r\n const canvasTileExtentOffset = worldTileExtent.clone();\r\n canvasTileOriginOffset.x *= world2CanvasRatioX;\r\n canvasTileOriginOffset.y *= world2CanvasRatioY;\r\n canvasTileExtentOffset.x *= world2CanvasRatioX;\r\n canvasTileExtentOffset.y *= world2CanvasRatioY;\r\n const xTranslate = -1 * canvasTileOriginOffset.x;\r\n\r\n // Canvas origin is upper left corner, so we need to flip the y axis\r\n const yTranslate = canvasTileExtentOffset.y; // y-axis flip\r\n const yWorld2CanvasRatio = -1 * world2CanvasRatioY; // y-axis flip\r\n\r\n const matrix = Matrix4d.createTranslationAndScaleXYZ(xTranslate, yTranslate, 0, world2CanvasRatioX, yWorld2CanvasRatio, 1);\r\n return matrix.asTransform;\r\n }\r\n\r\n public override async loadTile(row: number, column: number, zoomLevel: number): Promise<ImageSource | undefined> {\r\n\r\n const extent4326 = this.getEPSG4326Extent(row, column, zoomLevel);\r\n\r\n let data: any;\r\n if (this.staticMode) {\r\n // Static data mode\r\n const filteredData: Geojson.FeatureCollection = {type: \"FeatureCollection\", features: []};\r\n\r\n this._spatialIdx?.search(extent4326.longitudeLeft, extent4326.latitudeBottom, extent4326.longitudeRight, extent4326.latitudeTop,\r\n (index: number) => {\r\n filteredData.features.push(this._staticData!.features[index]);\r\n return true;\r\n });\r\n\r\n data = filteredData;\r\n } else {\r\n // Tiled data mode\r\n const extent4326Str = this.getEPSG4326TileExtentString(row, column, zoomLevel, false);\r\n const urlObj = new URL(this._itemsUrl);\r\n urlObj.searchParams.append(\"bbox\", `${extent4326Str}`);\r\n urlObj.searchParams.append(\"bbox-crs\", this._itemsCrs);\r\n urlObj.searchParams.append(\"limit\", `${this._limitParamMaxValue}`);\r\n const url = this.appendCustomParams(urlObj.toString());\r\n\r\n try {\r\n data = await this.fetchItems(url, this._tileModeFetchTimeout);\r\n } catch (_e) {\r\n }\r\n if (!data) {\r\n Logger.logError(loggerCategory, \"Could not fetch OgcApiFeatures data.\");\r\n }\r\n }\r\n\r\n if (!data || !Array.isArray(data.features) || data.features.length === 0) {\r\n Logger.logInfo(loggerCategory, `No data to render for tile (${zoomLevel}/${row}/${column}).`);\r\n }\r\n\r\n // Rendering starts here\r\n const canvas = document.createElement(\"canvas\");\r\n canvas.width = this.tileSize;\r\n canvas.height = this.tileSize;\r\n const ctx = canvas.getContext(\"2d\");\r\n if (ctx == null) {\r\n Logger.logError(loggerCategory, \"No canvas context available for loading tile.\");\r\n return undefined;\r\n }\r\n\r\n try {\r\n // Compute transform if CoordinatesQuantization is not supported by service\r\n const transfo = this.computeTileWorld2CanvasTransform(row, column, zoomLevel);\r\n if (!transfo) {\r\n Logger.logError(loggerCategory, `Could not compute data transformation for tile (${zoomLevel}/${row}/${column})`);\r\n }\r\n\r\n // Create the renderer\r\n\r\n // Instead of passing a Transform oject to the render, it should be possible\r\n // instead to set the Transform directly on the Canvas, when I tried the display was incorrect, floating point issue?\r\n // const transfoRow = transfo!.toRows();\r\n // ctx.setTransform(transfoRow[0][0], transfoRow[1][0], transfoRow[0][1], transfoRow[1][1], transfoRow[0][3], transfoRow[1][3]);\r\n const symbRenderer = ArcGisSymbologyCanvasRenderer.create(this._renderer, this._defaultSymbol);\r\n const renderer = new FeatureCanvasRenderer(ctx, symbRenderer, transfo);\r\n\r\n const featureReader = new OgcApiFeaturesReader();\r\n\r\n await featureReader.readAndRender(data, renderer);\r\n if (this._drawDebugInfo)\r\n this.drawTileDebugInfo(row, column, zoomLevel, ctx);\r\n } catch (e) {\r\n Logger.logError(loggerCategory, `Exception occurred while loading tile (${zoomLevel}/${row}/${column}) : ${e}`);\r\n }\r\n\r\n try {\r\n return this.createImageSourceFromDataURL(canvas.toDataURL(\"image/png\"), ImageSourceFormat.Png);\r\n } catch (e) {\r\n Logger.logError(loggerCategory, `Exception occurred while rendering tile (${zoomLevel}/${row}/${column}) : ${e}.`);\r\n }\r\n\r\n return undefined;\r\n }\r\n\r\n private createImageSourceFromDataURL(dataUrl: string, format: ImageSourceFormat) {\r\n if (!dataUrl)\r\n return undefined;\r\n\r\n const dataStartPos = dataUrl.indexOf(dataUrlHeaderToken) + dataUrlHeaderToken.length;\r\n\r\n if (dataStartPos < 0)\r\n return undefined;\r\n\r\n const base64Png = dataUrl.substring(dataStartPos);\r\n return new ImageSource(base64StringToUint8Array(base64Png), format);\r\n }\r\n\r\n public override async getFeatureInfo(featureInfos: MapLayerFeatureInfo[], quadId: QuadId, carto: Cartographic, _tree: ImageryMapTileTree, hit: HitDetail, options?: MapFeatureInfoOptions): Promise<void> {\r\n const tileExtent = this.getEPSG4326Extent(quadId.row, quadId.column, quadId.level);\r\n const tilePixelSizeX = (tileExtent.longitudeRight - tileExtent.longitudeLeft) / this.tileSize;\r\n const tilePixelSizeY = (tileExtent.latitudeTop - tileExtent.latitudeBottom) / this.tileSize;\r\n const tolerancePixel = options?.tolerance ?? 7;\r\n const toleranceWorldX = tilePixelSizeX * tolerancePixel;\r\n const toleranceWorldY = tilePixelSizeY * tolerancePixel;\r\n\r\n // Note: We used to pass a single point as the query 'geometry' and leverage the 'distance' parameter, turns\r\n // out that approach was a lot slower on some server compared to using a single envelope.\r\n const bbox: WGS84Extent = {\r\n longitudeLeft: carto.longitudeDegrees - toleranceWorldX, latitudeBottom: carto.latitudeDegrees - toleranceWorldY,\r\n longitudeRight: carto.longitudeDegrees + toleranceWorldX, latitudeTop: carto.latitudeDegrees + toleranceWorldY,\r\n };\r\n\r\n const bboxStr = this.getEPSG4326ExtentString(bbox, false);\r\n const urlObj = new URL(this._itemsUrl);\r\n urlObj.searchParams.append(\"bbox\", `${bboxStr}`);\r\n urlObj.searchParams.append(\"bbox-crs\", this._itemsCrs);\r\n urlObj.searchParams.append(\"limit\", `${this._limitParamMaxValue}`);\r\n const url = this.appendCustomParams(urlObj.toString());\r\n\r\n let data: any;\r\n try {\r\n data = await this.fetchItems(url, this._tileModeFetchTimeout);\r\n } catch (_e) {\r\n }\r\n if (!data) {\r\n Logger.logError(loggerCategory, \"Could not fetch OgcApiFeatures data.\");\r\n }\r\n\r\n const featureReader = new OgcApiFeaturesReader();\r\n await featureReader.readFeatureInfo({\r\n collection:data,\r\n layerSettings: this._settings,\r\n queryables: this._queryables,\r\n geomRenderer: new FeatureGraphicsRenderer({viewport: hit.viewport, crs: \"wgs84\"})},\r\n featureInfos );\r\n }\r\n}\r\n\r\n"]}
1
+ {"version":3,"file":"OgcApiFeaturesProvider.js","sourceRoot":"","sources":["../../../src/OgcApiFeatures/OgcApiFeaturesProvider.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n\r\nimport { FeatureGraphicsRenderer, HitDetail, ImageryMapTileTree, MapCartoRectangle, MapFeatureInfoOptions, MapLayerFeatureInfo, MapLayerImageryProvider, QuadId, WGS84Extent } from \"@itwin/core-frontend\";\r\nimport { EsriPMS, EsriPMSProps, EsriRenderer, EsriSFS, EsriSFSProps, EsriSLS, EsriSLSProps, EsriSymbol } from \"../ArcGisFeature/EsriSymbology\";\r\nimport { Cartographic, ColorDef, ImageMapLayerSettings, ImageSource, ImageSourceFormat, ServerError, SubLayerId } from \"@itwin/core-common\";\r\nimport { Matrix4d, Point3d, Range2d } from \"@itwin/core-geometry\";\r\nimport { ArcGisSymbologyCanvasRenderer } from \"../ArcGisFeature/ArcGisSymbologyRenderer\";\r\nimport { FeatureCanvasRenderer } from \"../Feature/FeatureCanvasRenderer\";\r\nimport { base64StringToUint8Array, IModelStatus, Logger } from \"@itwin/core-bentley\";\r\nimport * as Geojson from \"geojson\";\r\nimport { FeatureDefaultSymbology } from \"../Feature/FeatureSymbology\";\r\nimport { OgcApiFeaturesReader } from \"./OgcApiFeaturesReader\";\r\nimport { RandomMapColor } from \"../Feature/RandomMapColor\";\r\nimport { DefaultMarkerIcon } from \"../Feature/DefaultMarkerIcon\";\r\n\r\nconst loggerCategory = \"MapLayersFormats.OgcApiFeatures\";\r\nconst dataUrlHeaderToken = \"base64,\";\r\n\r\n/** Provide tiles from a ESRI ArcGIS Feature service\r\n* @internal\r\n*/\r\nexport class DefaultOgcSymbology implements FeatureDefaultSymbology {\r\n\r\n private static readonly _defaultPMSProps: Omit<EsriPMSProps, \"imageData\" | \"contentType\"> = {\r\n type: \"esriPMS\",\r\n url: \"\",\r\n width: 16,\r\n height: 24,\r\n // We want the anchor point to be the bottom of the push pin, so apply offset on the y-axis (anchor point is already in the center of the icon)\r\n xoffset: 0,\r\n yoffset: -12,\r\n };\r\n private _defaultPMS: EsriPMS;\r\n\r\n private static readonly _defaultSLSProps: EsriSLSProps = {\r\n type: \"esriSLS\",\r\n color: [0, 0, 255, 255],\r\n width: 1,\r\n style: \"esriSLSSolid\",\r\n };\r\n private _defaultSLS: EsriSLS;\r\n\r\n private static readonly _defaultSFSProps: EsriSFSProps = {\r\n type: \"esriSFS\",\r\n color: [0, 0, 255, 255], // blue fill\r\n style: \"esriSFSSolid\",\r\n outline: DefaultOgcSymbology._defaultSLSProps,\r\n };\r\n private _defaultSFS = EsriSFS.fromJSON(DefaultOgcSymbology._defaultSFSProps);\r\n\r\n public constructor(randomColor?: RandomMapColor) {\r\n const color = randomColor ? randomColor.getColorDef() : ColorDef.blue;\r\n this._defaultPMS = EsriPMS.fromJSON( {\r\n ...DefaultMarkerIcon.getContent(color),\r\n type: \"esriPMS\",\r\n url: \"\",\r\n width: 16,\r\n height: 24,\r\n xoffset: 0,\r\n yoffset: -12,\r\n });\r\n\r\n const randomColors = color.colors;\r\n const newSLSProps = {\r\n ...DefaultOgcSymbology._defaultSLSProps,\r\n color: [randomColors.r, randomColors.g, randomColors.b, 255],\r\n };\r\n this._defaultSLS = EsriSLS.fromJSON(newSLSProps);\r\n this._defaultSFS = EsriSFS.fromJSON({\r\n ...DefaultOgcSymbology._defaultSFSProps,\r\n color: [randomColors.r, randomColors.g, randomColors.b, 255],\r\n outline: {\r\n ...DefaultOgcSymbology._defaultSLSProps,\r\n color: [0, 0, 0, 255],\r\n },\r\n });\r\n }\r\n\r\n public async initialize() {\r\n // Marker image need to be loaded upfront;\r\n await this._defaultPMS.loadImage();\r\n }\r\n\r\n public getSymbology(geometryType: string): EsriSymbol {\r\n if (geometryType === \"LineString\"|| geometryType === \"MultiLineString\" )\r\n return this._defaultSLS;\r\n else if (geometryType === \"Polygon\"|| geometryType === \"MultiPolygon\" )\r\n return this._defaultSFS;\r\n else if (geometryType === \"Point\"|| geometryType === \"MultiPoint\" )\r\n return this._defaultPMS;\r\n\r\n throw new Error(`Could not get default symbology for geometry type ${geometryType}`);\r\n }\r\n}\r\n/** @internal */\r\nexport class OgcApiFeaturesProvider extends MapLayerImageryProvider {\r\n\r\n // Debug flags, should always be committed to FALSE !\r\n private readonly _drawDebugInfo = false;\r\n /// ////////////////////////////\r\n\r\n private readonly _limitParamMaxValue = 10000; // This is documented in OGC Features specification; a single items request never returns more than 10 000 items\r\n private readonly _tiledModeMinLod = 14;\r\n private readonly _staticModeFetchTimeout = 10000;\r\n private readonly _tileModeFetchTimeout = 10000;\r\n private readonly _forceTileMode = false;\r\n private _spatialIdx: any;\r\n private _defaultSymbol = new DefaultOgcSymbology(new RandomMapColor());\r\n private _renderer: EsriRenderer|undefined;\r\n private _collectionUrl = \"\";\r\n private _itemsUrl = \"\";\r\n private readonly _itemsCrs = \"http://www.opengis.net/def/crs/OGC/1.3/CRS84\"; // Fixed fow now\r\n private _queryables: any;\r\n\r\n public serviceJson: any;\r\n private _staticData: Geojson.FeatureCollection|undefined;\r\n\r\n constructor(settings: ImageMapLayerSettings) {\r\n super(settings, true);\r\n }\r\n\r\n public override get supportsMapFeatureInfo() { return true;}\r\n public override get minimumZoomLevel(): number { return this.staticMode ? super.minimumZoomLevel : this._tiledModeMinLod; }\r\n public get staticMode(): boolean { return !!(this._spatialIdx && this._staticData && !this._forceTileMode); }\r\n\r\n public override async initialize(): Promise<void> {\r\n\r\n this._collectionUrl = this._settings.url;\r\n let layerId: SubLayerId|undefined;\r\n\r\n // OGC Feature service request can only serve data for a single feature\r\n // so if multiple sub-layer ids are specified, we pick the first one.\r\n if (this._settings.subLayers && this._settings.subLayers.length > 0) {\r\n layerId = this._settings.subLayers[0].id;\r\n }\r\n\r\n const readCollectionsPage = (data: any) => {\r\n const collection = data.collections.find((col: any)=> col.id === layerId);\r\n const collectionLinks = collection?.links;\r\n if (!collectionLinks) {\r\n const msg = `Missing layer id or matching collection could not be found`;\r\n Logger.logError(loggerCategory, msg);\r\n throw new Error(msg);\r\n }\r\n const collectionLink = collectionLinks.find((link: any)=> link.rel.includes(\"collection\") && link.type === \"application/json\",\r\n );\r\n this._collectionUrl = collectionLink.href;\r\n };\r\n\r\n const layerIdMismatch = () => {\r\n const msg = `Collection metadata and sub-layers id mismatch`;\r\n Logger.logError(loggerCategory, msg);\r\n throw new Error(msg);\r\n };\r\n let collectionMetadata: any;\r\n let json = await this.fetchMetadata(this._settings.url);\r\n if (json?.type === \"FeatureCollection\") {\r\n // We landed on the items page, we need to look for the collection metadata url\r\n if (Array.isArray(json.links)) {\r\n const collectionLink = json.links.find((link: any)=> link.rel.includes(\"collection\") && link.type === \"application/json\");\r\n this._collectionUrl = collectionLink.href;\r\n }\r\n } else if (json.itemType === \"feature\") {\r\n // We landed on a specific collection page.\r\n collectionMetadata = json;\r\n\r\n // Check if the collection id matches at least one sub-layer\r\n if (this._settings.subLayers && this._settings.subLayers.length > 0) {\r\n const subLayer = this._settings.subLayers.find((s)=>s.id === collectionMetadata.id);\r\n if (subLayer)\r\n layerId = subLayer.id;\r\n } else {\r\n // No sub-layers were specified, defaults to collection id.\r\n layerId = collectionMetadata.id;\r\n }\r\n\r\n } else if (Array.isArray(json.collections)) {\r\n // We landed in the \"Collections\" page\r\n // Find to find the specified layer id among the available collections\r\n readCollectionsPage(json);\r\n } else if (Array.isArray(json.links)) {\r\n // This might be the main landing page\r\n // We need to find the the \"Collections\" page\r\n const collectionsLink = json.links.find((link: any)=> link.rel.includes(\"data\") && link.type === \"application/json\");\r\n if (!collectionsLink) {\r\n Logger.logError(loggerCategory, \"Could not find collections link\");\r\n throw new ServerError(IModelStatus.ValidationFailed, \"\");\r\n }\r\n\r\n json = await this.fetchMetadata(collectionsLink.href);\r\n if (Array.isArray(json.collections)) {\r\n readCollectionsPage(json);\r\n }\r\n }\r\n\r\n // Read collection metadata\r\n if (!collectionMetadata)\r\n collectionMetadata = await this.fetchMetadata(this._collectionUrl);\r\n\r\n if (layerId !== undefined && layerId !== collectionMetadata.id) {\r\n layerIdMismatch();\r\n }\r\n\r\n // Read cartographic range\r\n if (Array.isArray(collectionMetadata?.extent?.spatial?.bbox)\r\n && collectionMetadata.extent.spatial.bbox.length > 0\r\n && collectionMetadata.extent.spatial.crs === this._itemsCrs\r\n ) {\r\n const firstBbox = collectionMetadata.extent.spatial?.bbox[0];\r\n this.cartoRange = MapCartoRectangle.fromDegrees(firstBbox[0], firstBbox[1], firstBbox[2], firstBbox[3]);\r\n }\r\n\r\n // Read important links\r\n let queryablesHref: string|undefined;\r\n let itemsHref: string|undefined;\r\n if (Array.isArray(collectionMetadata?.links)) {\r\n // Items links (Mandatory)\r\n const itemsLink = collectionMetadata.links.find((link: any)=> link.rel.includes(\"items\") && link.type === \"application/geo+json\");\r\n itemsHref = itemsLink.href;\r\n\r\n // Queryables link (Optional)\r\n const queryablesLink = collectionMetadata.links.find((link: any)=> link.rel.includes(\"queryables\") && link.type === \"application/schema+json\");\r\n queryablesHref = queryablesLink.href;\r\n\r\n }\r\n\r\n if (itemsHref)\r\n this._itemsUrl = itemsHref;\r\n else {\r\n const msg = \"Unable to find items link on collection\";\r\n Logger.logError(loggerCategory, msg);\r\n throw new Error(msg);\r\n }\r\n if (queryablesHref)\r\n this._queryables = await this.fetchMetadata(queryablesHref);\r\n\r\n if (!this._forceTileMode) {\r\n const status = await this.fetchAllItems();\r\n if (status) {\r\n await this.indexStaticData();\r\n }\r\n }\r\n\r\n await this._defaultSymbol.initialize(); // images must be loaded upfront\r\n }\r\n\r\n private async fetchMetadata(url: string): Promise<any> {\r\n const tmpUrl = this.appendCustomParams(url);\r\n const response = await this.makeRequest(tmpUrl);\r\n return response.json();\r\n }\r\n\r\n private async fetchAllItems() {\r\n const urlObj = new URL(this._itemsUrl);\r\n urlObj.searchParams.append(\"limit\", `${this._limitParamMaxValue}`);\r\n const url = this.appendCustomParams(urlObj.toString());\r\n this._staticData = await this.fetchItems(url, this._staticModeFetchTimeout);\r\n return this._staticData ? true : false;\r\n }\r\n\r\n private async fetchItems(url: string, timeout: number) {\r\n let data: any;\r\n let success = true;\r\n try {\r\n const fetchBegin = Date.now();\r\n let tmpUrl = this.appendCustomParams(url);\r\n let response = await this.makeTileRequest(tmpUrl, timeout);\r\n let json = await response.json();\r\n data = json;\r\n // Follow \"next\" link if any\r\n let nextLink = json.links?.find((link: any)=>link.rel === \"next\");\r\n while (nextLink && (Date.now() - fetchBegin) < timeout && success) {\r\n tmpUrl = this.appendCustomParams(nextLink.href);\r\n response = await this.makeTileRequest(tmpUrl, this._staticModeFetchTimeout);\r\n json = await response.json();\r\n if (json?.features)\r\n data!.features = this._staticData?.features ? [...this._staticData.features, ...json.features] : json.features;\r\n else\r\n success = false;\r\n nextLink = json.links?.find((link: any)=>link.rel === \"next\");\r\n }\r\n if (Date.now() - fetchBegin >= this._staticModeFetchTimeout) {\r\n // We ran out of time, let switch to tile mode\r\n success = false;\r\n }\r\n } catch (e) {\r\n success = false;\r\n if (e instanceof DOMException && e.name === \"AbortError\") {\r\n Logger.logInfo(loggerCategory, \"Request to fetch all features time out, switching to tile mode.\");\r\n } else {\r\n Logger.logError(loggerCategory, \"Unknown error occurred when fetching OgcApiFeatures data.\");\r\n }\r\n }\r\n return success ? data : undefined;\r\n }\r\n\r\n // Read features range and build in-memory spatial index\r\n private async indexStaticData() {\r\n // UGLY IMPORT:\r\n // flatbush only provides ECM modules, and since mocha is not very good with ECM modules,\r\n // we need to have this special import, until we replace mocha with something else.\r\n const flatbush = (await import(\"flatbush\")).default;\r\n let success = true;\r\n try {\r\n const datasetRange = new Range2d();\r\n const buildPositionRange = (coords: Geojson.Position, range: Range2d) => range.extendXY(coords[0], coords[1]);\r\n const buildPositionArrayRange = (coords: Geojson.Position[], range: Range2d) => coords.forEach((position) => buildPositionRange(position, range) );\r\n const buildDoublePositionRange = (coords: Geojson.Position[][], range: Range2d) => coords.forEach((position) => buildPositionArrayRange(position, range) );\r\n const buildTriplePositionRange = (coords: Geojson.Position[][][], range: Range2d) => coords.forEach((position) => buildDoublePositionRange(position, range) );\r\n\r\n const readGeomRange = (geom: Geojson.Geometry, range: Range2d) => {\r\n if (geom.type === \"Point\")\r\n buildPositionRange(geom.coordinates, range);\r\n else if (geom.type === \"LineString\" || geom.type === \"MultiPoint\")\r\n buildPositionArrayRange(geom.coordinates, range);\r\n else if (geom.type === \"Polygon\" || geom.type === \"MultiLineString\")\r\n buildDoublePositionRange(geom.coordinates, range);\r\n else if (geom.type === \"MultiPolygon\" )\r\n buildTriplePositionRange(geom.coordinates, range);\r\n };\r\n\r\n if (this._staticData && Array.isArray(this._staticData.features)) {\r\n this._spatialIdx = new flatbush(this._staticData.features.length);\r\n this._staticData.features.forEach((feature: Geojson.Feature) => {\r\n try {\r\n if (feature.geometry.type === \"LineString\"\r\n || feature.geometry.type === \"MultiLineString\"\r\n || feature.geometry.type === \"Point\"\r\n || feature.geometry.type === \"MultiPoint\"\r\n || feature.geometry.type === \"Polygon\"\r\n || feature.geometry.type === \"MultiPolygon\"\r\n ) {\r\n readGeomRange(feature.geometry, datasetRange);\r\n this._spatialIdx?.add(datasetRange.xLow, datasetRange.yLow, datasetRange.xHigh,datasetRange. yHigh);\r\n datasetRange.setNull();\r\n } else if (feature.geometry.type === \"GeometryCollection\") {\r\n feature.geometry.geometries.forEach((geom) => {\r\n readGeomRange(geom, datasetRange);\r\n this._spatialIdx?.add(datasetRange.xLow, datasetRange.yLow, datasetRange.xHigh,datasetRange. yHigh);\r\n });\r\n datasetRange.setNull();\r\n }\r\n } catch (e: any) {\r\n Logger.logInfo(loggerCategory, `Unknown error occurred indexing feature: ${e.message}`);\r\n success = false;\r\n }\r\n });\r\n\r\n if (success) {\r\n this._spatialIdx.finish();\r\n }\r\n }\r\n\r\n } catch {\r\n Logger.logError(loggerCategory, \"Unknown error occurred when index static data\");\r\n success = false;\r\n }\r\n return success;\r\n }\r\n\r\n public override get tileSize(): number { return 512; }\r\n\r\n // We don't use this method inside this provider (see constructFeatureUrl), but since this is an abstract method, we need to define something\r\n public async constructUrl(_row: number, _column: number, _zoomLevel: number): Promise<string> {\r\n return \"\";\r\n }\r\n\r\n public drawTileDebugInfo(row: number, column: number, zoomLevel: number, context: CanvasRenderingContext2D) {\r\n context.fillStyle = \"cyan\";\r\n context.strokeRect(0, 0, this.tileSize, this.tileSize);\r\n context.font = \"30px Arial\";\r\n context.lineWidth = 5;\r\n context.fillText(`${zoomLevel}-${row}-${column}`, 10, 50);\r\n }\r\n\r\n // Compute transform that provides coordinates in the canvas coordinate system (pixels, origin = top-left)\r\n // from coordinate in world\r\n public computeTileWorld2CanvasTransform(row: number, column: number, zoomLevel: number) {\r\n\r\n const tileExtentWorld4326 = this.getEPSG4326Extent(row, column, zoomLevel);\r\n const worldTileWidth = tileExtentWorld4326.longitudeRight - tileExtentWorld4326.longitudeLeft;\r\n const worldTileHeight = tileExtentWorld4326.latitudeTop - tileExtentWorld4326.latitudeBottom;\r\n const canvasTileWidth = this.tileSize;\r\n const canvasTileHeight = this.tileSize;\r\n const world2CanvasRatioX = canvasTileWidth / worldTileWidth;\r\n const world2CanvasRatioY = canvasTileHeight / worldTileHeight;\r\n const worldTileOrigin = Point3d.create(tileExtentWorld4326.longitudeLeft, tileExtentWorld4326.latitudeBottom);\r\n const worldTileExtent = Point3d.create(tileExtentWorld4326.longitudeRight, tileExtentWorld4326.latitudeTop);\r\n const canvasTileOriginOffset = worldTileOrigin.clone();\r\n const canvasTileExtentOffset = worldTileExtent.clone();\r\n canvasTileOriginOffset.x *= world2CanvasRatioX;\r\n canvasTileOriginOffset.y *= world2CanvasRatioY;\r\n canvasTileExtentOffset.x *= world2CanvasRatioX;\r\n canvasTileExtentOffset.y *= world2CanvasRatioY;\r\n const xTranslate = -1 * canvasTileOriginOffset.x;\r\n\r\n // Canvas origin is upper left corner, so we need to flip the y axis\r\n const yTranslate = canvasTileExtentOffset.y; // y-axis flip\r\n const yWorld2CanvasRatio = -1 * world2CanvasRatioY; // y-axis flip\r\n\r\n const matrix = Matrix4d.createTranslationAndScaleXYZ(xTranslate, yTranslate, 0, world2CanvasRatioX, yWorld2CanvasRatio, 1);\r\n return matrix.asTransform;\r\n }\r\n\r\n public override async loadTile(row: number, column: number, zoomLevel: number): Promise<ImageSource | undefined> {\r\n\r\n const extent4326 = this.getEPSG4326Extent(row, column, zoomLevel);\r\n\r\n let data: any;\r\n if (this.staticMode) {\r\n // Static data mode\r\n const filteredData: Geojson.FeatureCollection = {type: \"FeatureCollection\", features: []};\r\n\r\n this._spatialIdx?.search(extent4326.longitudeLeft, extent4326.latitudeBottom, extent4326.longitudeRight, extent4326.latitudeTop,\r\n (index: number) => {\r\n filteredData.features.push(this._staticData!.features[index]);\r\n return true;\r\n });\r\n\r\n data = filteredData;\r\n } else {\r\n // Tiled data mode\r\n const extent4326Str = this.getEPSG4326TileExtentString(row, column, zoomLevel, false);\r\n const urlObj = new URL(this._itemsUrl);\r\n urlObj.searchParams.append(\"bbox\", `${extent4326Str}`);\r\n urlObj.searchParams.append(\"bbox-crs\", this._itemsCrs);\r\n urlObj.searchParams.append(\"limit\", `${this._limitParamMaxValue}`);\r\n const url = this.appendCustomParams(urlObj.toString());\r\n\r\n try {\r\n data = await this.fetchItems(url, this._tileModeFetchTimeout);\r\n } catch {\r\n }\r\n if (!data) {\r\n Logger.logError(loggerCategory, \"Could not fetch OgcApiFeatures data.\");\r\n }\r\n }\r\n\r\n if (!data || !Array.isArray(data.features) || data.features.length === 0) {\r\n Logger.logInfo(loggerCategory, `No data to render for tile (${zoomLevel}/${row}/${column}).`);\r\n }\r\n\r\n // Rendering starts here\r\n const canvas = document.createElement(\"canvas\");\r\n canvas.width = this.tileSize;\r\n canvas.height = this.tileSize;\r\n const ctx = canvas.getContext(\"2d\");\r\n if (ctx == null) {\r\n Logger.logError(loggerCategory, \"No canvas context available for loading tile.\");\r\n return undefined;\r\n }\r\n\r\n try {\r\n // Compute transform if CoordinatesQuantization is not supported by service\r\n const transfo = this.computeTileWorld2CanvasTransform(row, column, zoomLevel);\r\n if (!transfo) {\r\n Logger.logError(loggerCategory, `Could not compute data transformation for tile (${zoomLevel}/${row}/${column})`);\r\n }\r\n\r\n // Create the renderer\r\n\r\n // Instead of passing a Transform oject to the render, it should be possible\r\n // instead to set the Transform directly on the Canvas, when I tried the display was incorrect, floating point issue?\r\n // const transfoRow = transfo!.toRows();\r\n // ctx.setTransform(transfoRow[0][0], transfoRow[1][0], transfoRow[0][1], transfoRow[1][1], transfoRow[0][3], transfoRow[1][3]);\r\n const symbRenderer = ArcGisSymbologyCanvasRenderer.create(this._renderer, this._defaultSymbol);\r\n const renderer = new FeatureCanvasRenderer(ctx, symbRenderer, transfo);\r\n\r\n const featureReader = new OgcApiFeaturesReader();\r\n\r\n await featureReader.readAndRender(data, renderer);\r\n if (this._drawDebugInfo)\r\n this.drawTileDebugInfo(row, column, zoomLevel, ctx);\r\n } catch (e) {\r\n Logger.logError(loggerCategory, `Exception occurred while loading tile (${zoomLevel}/${row}/${column}) : ${e}`);\r\n }\r\n\r\n try {\r\n return this.createImageSourceFromDataURL(canvas.toDataURL(\"image/png\"), ImageSourceFormat.Png);\r\n } catch (e) {\r\n Logger.logError(loggerCategory, `Exception occurred while rendering tile (${zoomLevel}/${row}/${column}) : ${e}.`);\r\n }\r\n\r\n return undefined;\r\n }\r\n\r\n private createImageSourceFromDataURL(dataUrl: string, format: ImageSourceFormat) {\r\n if (!dataUrl)\r\n return undefined;\r\n\r\n const dataStartPos = dataUrl.indexOf(dataUrlHeaderToken) + dataUrlHeaderToken.length;\r\n\r\n if (dataStartPos < 0)\r\n return undefined;\r\n\r\n const base64Png = dataUrl.substring(dataStartPos);\r\n return new ImageSource(base64StringToUint8Array(base64Png), format);\r\n }\r\n\r\n public override async getFeatureInfo(featureInfos: MapLayerFeatureInfo[], quadId: QuadId, carto: Cartographic, _tree: ImageryMapTileTree, hit: HitDetail, options?: MapFeatureInfoOptions): Promise<void> {\r\n const tileExtent = this.getEPSG4326Extent(quadId.row, quadId.column, quadId.level);\r\n const tilePixelSizeX = (tileExtent.longitudeRight - tileExtent.longitudeLeft) / this.tileSize;\r\n const tilePixelSizeY = (tileExtent.latitudeTop - tileExtent.latitudeBottom) / this.tileSize;\r\n const tolerancePixel = options?.tolerance ?? 7;\r\n const toleranceWorldX = tilePixelSizeX * tolerancePixel;\r\n const toleranceWorldY = tilePixelSizeY * tolerancePixel;\r\n\r\n // Note: We used to pass a single point as the query 'geometry' and leverage the 'distance' parameter, turns\r\n // out that approach was a lot slower on some server compared to using a single envelope.\r\n const bbox: WGS84Extent = {\r\n longitudeLeft: carto.longitudeDegrees - toleranceWorldX, latitudeBottom: carto.latitudeDegrees - toleranceWorldY,\r\n longitudeRight: carto.longitudeDegrees + toleranceWorldX, latitudeTop: carto.latitudeDegrees + toleranceWorldY,\r\n };\r\n\r\n const bboxStr = this.getEPSG4326ExtentString(bbox, false);\r\n const urlObj = new URL(this._itemsUrl);\r\n urlObj.searchParams.append(\"bbox\", `${bboxStr}`);\r\n urlObj.searchParams.append(\"bbox-crs\", this._itemsCrs);\r\n urlObj.searchParams.append(\"limit\", `${this._limitParamMaxValue}`);\r\n const url = this.appendCustomParams(urlObj.toString());\r\n\r\n let data: any;\r\n try {\r\n data = await this.fetchItems(url, this._tileModeFetchTimeout);\r\n } catch {\r\n }\r\n if (!data) {\r\n Logger.logError(loggerCategory, \"Could not fetch OgcApiFeatures data.\");\r\n }\r\n\r\n const featureReader = new OgcApiFeaturesReader();\r\n await featureReader.readFeatureInfo({\r\n collection:data,\r\n layerSettings: this._settings,\r\n queryables: this._queryables,\r\n geomRenderer: new FeatureGraphicsRenderer({viewport: hit.viewport, crs: \"wgs84\"})},\r\n featureInfos );\r\n }\r\n}\r\n\r\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"ArcGisFeatureProvider.d.ts","sourceRoot":"","sources":["../../../src/ArcGisFeature/ArcGisFeatureProvider.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,YAAY,EAAE,qBAAqB,EAAE,WAAW,EAAkC,MAAM,oBAAoB,CAAC;AAEtH,OAAO,EAA8B,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAC7E,OAAO,EAAmB,qBAAqB,EAAmE,SAAS,EAAE,kBAAkB,EAAqB,qBAAqB,EAAE,mBAAmB,EAAiC,MAAM,EAAqB,MAAM,sBAAsB,CAAC;AACvS,OAAO,EAAE,YAAY,EAAE,mBAAmB,EAAsB,uBAAuB,EAAE,cAAc,EAAkC,MAAM,sBAAsB,CAAC;AAMtK,OAAO,EAAE,OAAO,EAAgB,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AACpG,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AAKtE;;EAEE;AACF,UAAU,gBAAgB;IACxB,GAAG,EAAE,MAAM,CAAC;IACZ,QAAQ,CAAC,EAAE,YAAY,CAAC;CACzB;AAED;;EAEE;AACF,qBAAa,qBAAsB,YAAW,uBAAuB;IACnE,gBAAuB,UAAU,UAS9B;IAEH,gBAAuB,eAAe,EAAE,YAAY,CAKlD;IACF,gBAAuB,UAAU,UAA0C;IAE3E,gBAAuB,UAAU,UAK9B;IAEU,UAAU;IAKhB,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,UAAU;CAWlD;AAED;;EAEE;AACF,qBAAa,qBAAsB,SAAQ,qBAAqB;IAE9D,OAAO,CAAC,cAAc,CAAS;IAC/B,OAAO,CAAC,iBAAiB,CAAS;IAElC,OAAO,CAAC,gCAAgC,CAAS;IAEjD,OAAO,CAAC,QAAQ,CAAK;IACrB,OAAO,CAAC,cAAc,CAAM;IAC5B,OAAO,CAAC,OAAO,CAAkC;IACjD,OAAO,CAAC,MAAM,CAAU;IAExB,OAAO,CAAC,gBAAgB,CAAK;IAC7B,OAAO,CAAC,gBAAgB,CAAK;IAE7B,OAAO,CAAC,cAAc,CAA+B;IACrD,OAAO,CAAC,SAAS,CAAyB;IAC1C,OAAO,CAAC,kBAAkB,CAA0C;IAEpE,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,WAAW,CAAK;IACjC,WAAW,EAAE,GAAG,CAAC;IAExB,IAAoB,gBAAgB,IAAI,MAAM,CAAkC;IAChF,IAAoB,gBAAgB,IAAI,MAAM,CAAkC;IAEhF,OAAO,CAAC,MAAM,CAAC,YAAY,CAA0B;gBAEzC,QAAQ,EAAE,qBAAqB;IAIrB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;YAqKnC,gBAAgB;IAwB9B,OAAO,CAAC,2BAA2B;cAanB,gBAAgB,CAAC,OAAO,EAAE,MAAM;IAehD,IAAoB,QAAQ,IAAI,MAAM,CAAgB;IACtD,IAAW,MAAM,IAAI,mBAAmB,GAAG,SAAS,CAAyB;IAGhE,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAItF,mBAAmB,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,mBAAmB,EAAE,UAAU,EAAE,uBAAuB,EAAE,YAAY,CAAC,EAAE,cAAc,EAAE,SAAS,CAAC,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM,EAAE,cAAc,CAAC,EAAE,OAAO,EAAE,kBAAkB,CAAC,EAAE,MAAM,GAAG,gBAAgB,GAAG,SAAS;IA4DlR,cAAc,CAAC,YAAY,EAAE,mBAAmB,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,kBAAkB,EAAE,GAAG,EAAE,SAAS,EAAE,OAAO,CAAC,EAAE,qBAAqB,GAAG,OAAO,CAAC,IAAI,CAAC;YA+E3L,SAAS;IAkBhB,iBAAiB,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,wBAAwB;IAU1G,SAAS,CAAC,gCAAgC,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM;IAsBnE,QAAQ,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,GAAG,SAAS,CAAC;CA8GjH"}
1
+ {"version":3,"file":"ArcGisFeatureProvider.d.ts","sourceRoot":"","sources":["../../../src/ArcGisFeature/ArcGisFeatureProvider.ts"],"names":[],"mappings":"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"}
@@ -7,7 +7,7 @@ import { ImageSource, ImageSourceFormat, ServerError } from "@itwin/core-common"
7
7
  import { base64StringToUint8Array, IModelStatus, Logger } from "@itwin/core-bentley";
8
8
  import { Matrix4d, Point3d, Range2d } from "@itwin/core-geometry";
9
9
  import { ArcGisErrorCode, ArcGISImageryProvider, ArcGisUtilities, FeatureGraphicsRenderer, MapCartoRectangle, MapLayerImageryProviderStatus, setRequestTimeout } from "@itwin/core-frontend";
10
- import { ArcGisFeatureQuery } from "./ArcGisFeatureQuery";
10
+ import { arcgisFeatureFormats, ArcGisFeatureQuery } from "./ArcGisFeatureQuery";
11
11
  import { ArcGisPbfFeatureReader } from "./ArcGisPbfFeatureReader";
12
12
  import { ArcGisJsonFeatureReader } from "./ArcGisJsonFeatureReader";
13
13
  import { ArcGisFeatureResponse } from "./ArcGisFeatureResponse";
@@ -171,12 +171,12 @@ export class ArcGisFeatureProvider extends ArcGISImageryProvider {
171
171
  // Note: needs to be checked on the layer metadata, service metadata advertises a different set of formats
172
172
  // Also, since PBF format does not support floating points, there is no point using this format if supportsCoordinatesQuantization is not available.
173
173
  if (this._layerMetadata.supportedQueryFormats) {
174
- const formats = this._layerMetadata.supportedQueryFormats.split(", ");
175
- if (formats.includes("PBF") && this._supportsCoordinatesQuantization) {
176
- this._format = "PBF";
174
+ const formats = this._layerMetadata.supportedQueryFormats.split(",").map((s) => s.trim().toLowerCase());
175
+ if (formats.includes(arcgisFeatureFormats.pbf) && this._supportsCoordinatesQuantization) {
176
+ this._format = arcgisFeatureFormats.pbf;
177
177
  }
178
- else if (formats.includes("JSON")) {
179
- this._format = "JSON";
178
+ else if (formats.includes(arcgisFeatureFormats.json)) {
179
+ this._format = arcgisFeatureFormats.json;
180
180
  }
181
181
  }
182
182
  if (!this._format) {
@@ -231,7 +231,7 @@ export class ArcGisFeatureProvider extends ArcGISImageryProvider {
231
231
  tmpUrl.searchParams.append("where", "1=1");
232
232
  tmpUrl.searchParams.append("outSR", "3857");
233
233
  tmpUrl.searchParams.append("returnExtentOnly", "true");
234
- tmpUrl.searchParams.append("f", "json");
234
+ tmpUrl.searchParams.append("f", arcgisFeatureFormats.json);
235
235
  const cached = ArcGisFeatureProvider._extentCache.get(tmpUrl.toString());
236
236
  if (cached) {
237
237
  extentJson = cached;
@@ -360,12 +360,12 @@ export class ArcGisFeatureProvider extends ArcGISImageryProvider {
360
360
  };
361
361
  if (this._debugFeatureGeom) {
362
362
  try {
363
- let responseData = await doFeatureInfoQuery("PBF", "", true);
363
+ let responseData = await doFeatureInfoQuery(arcgisFeatureFormats.pbf, "", true);
364
364
  if (responseData) {
365
365
  const json = JSON.stringify(responseData.data.toObject());
366
366
  Logger.logInfo(loggerCategory, json);
367
367
  }
368
- responseData = await doFeatureInfoQuery("JSON", "", true);
368
+ responseData = await doFeatureInfoQuery(arcgisFeatureFormats.json, "", true);
369
369
  if (responseData) {
370
370
  const json = JSON.stringify(responseData.data);
371
371
  Logger.logInfo(loggerCategory, json);
@@ -377,7 +377,7 @@ export class ArcGisFeatureProvider extends ArcGISImageryProvider {
377
377
  }
378
378
  try {
379
379
  // Feature Info requests are always made in JSON for now.
380
- const responseData = await doFeatureInfoQuery("JSON", "*", true);
380
+ const responseData = await doFeatureInfoQuery(arcgisFeatureFormats.json, "*", true);
381
381
  if (!responseData) {
382
382
  Logger.logError(loggerCategory, `Could not get feature info data`);
383
383
  return;
@@ -465,7 +465,9 @@ export class ArcGisFeatureProvider extends ArcGISImageryProvider {
465
465
  return undefined;
466
466
  }
467
467
  const renderer = new FeatureCanvasRenderer(ctx, this._symbologyRenderer, transfo);
468
- const featureReader = this.format === "PBF" ? new ArcGisPbfFeatureReader(this._settings, this._layerMetadata) : new ArcGisJsonFeatureReader(this._settings, this._layerMetadata);
468
+ const featureReader = this.format === arcgisFeatureFormats.pbf
469
+ ? new ArcGisPbfFeatureReader(this._settings, this._layerMetadata)
470
+ : new ArcGisJsonFeatureReader(this._settings, this._layerMetadata);
469
471
  const getSubEnvelopes = (envelope) => {
470
472
  const dx = (envelope.xmax - envelope.xmin) * 0.5;
471
473
  const dy = (envelope.xmax - envelope.xmin) * 0.5;
@@ -1 +1 @@
1
- {"version":3,"file":"ArcGisFeatureProvider.js","sourceRoot":"","sources":["../../../src/ArcGisFeature/ArcGisFeatureProvider.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n\r\nimport { Cartographic, ImageMapLayerSettings, ImageSource, ImageSourceFormat, ServerError } from \"@itwin/core-common\";\r\nimport { base64StringToUint8Array, IModelStatus, Logger } from \"@itwin/core-bentley\";\r\nimport { Matrix4d, Point3d, Range2d, Transform } from \"@itwin/core-geometry\";\r\nimport { ArcGisErrorCode, ArcGISImageryProvider, ArcGISServiceMetadata, ArcGisUtilities, FeatureGraphicsRenderer, HitDetail, ImageryMapTileTree, MapCartoRectangle, MapFeatureInfoOptions, MapLayerFeatureInfo, MapLayerImageryProviderStatus, QuadId, setRequestTimeout } from \"@itwin/core-frontend\";\r\nimport { ArcGisExtent, ArcGisFeatureFormat, ArcGisFeatureQuery, ArcGisFeatureResultType, ArcGisGeometry, FeatureQueryQuantizationParams } from \"./ArcGisFeatureQuery\";\r\nimport { ArcGisPbfFeatureReader } from \"./ArcGisPbfFeatureReader\";\r\nimport { ArcGisJsonFeatureReader } from \"./ArcGisJsonFeatureReader\";\r\nimport { ArcGisFeatureResponse, ArcGisResponseData } from \"./ArcGisFeatureResponse\";\r\nimport { ArcGisFeatureReader } from \"./ArcGisFeatureReader\";\r\n\r\nimport { EsriPMS, EsriRenderer, EsriSFS, EsriSLS, EsriSLSProps, EsriSymbol } from \"./EsriSymbology\";\r\nimport { FeatureDefaultSymbology } from \"../Feature/FeatureSymbology\";\r\nimport { FeatureCanvasRenderer } from \"../Feature/FeatureCanvasRenderer\";\r\nimport { ArcGisSymbologyCanvasRenderer } from \"./ArcGisSymbologyRenderer\";\r\nconst loggerCategory = \"MapLayersFormats.ArcGISFeature\";\r\n\r\n/**\r\n* @internal\r\n*/\r\ninterface ArcGisFeatureUrl {\r\n url: string;\r\n envelope?: ArcGisExtent; // envelope representing the current computed URL, required to refine request.\r\n}\r\n\r\n/**\r\n* @internal\r\n*/\r\nexport class DefaultArcGiSymbology implements FeatureDefaultSymbology {\r\n public static readonly defaultPMS = EsriPMS.fromJSON( {\r\n type: \"esriPMS\",\r\n url: \"\",\r\n contentType: \"image/png\",\r\n imageData: \"iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAmBJREFUOE+Nk01IVFEUx//n3jfvOZOaJkMtiiJ7o9RG3LgoqKhFSFJBTS1ahFBBi0ijfJXCIyQr+hBbSIsoW7iQoKKFCw2CkAI3tZAgy8Ei+xhoTCbnje/NPfHGnA816KzuPR+/c8/HJRQJE7o+VUhym0DcCOYGgBQEXjOLlyqo+nHanCkMoaL4rslKjZwOQLT4ek3Mmz3FACFNLB67ut6M1nWphbg8wI6VyJK5KEH0EQFVJRKbwzokAW++p/ErraAYSQK3u47bC3vLnA+ZB9i2gHF0oyQMCfCGNaUa+vauxs71wWz2V18cnBj8gQ8J1/eeBnHUa4sMFQDGdGno+4gwEAoQzjVUon3rqlx1KY9x7+0MWobjAPg3QJ2eZV4tAEyFNCN5FkSXyw2B3j1hRGvLcgBXMV5MptA4MOXr0gT0u5bZnAf0jBsyiSgJPAxqhON1K3FlRxUMvwFAtv7u0Wl0jvwEmJNEuOhakTt5wKEBifr6Oo14BIBRpgt07w6jcVMIngKGY7NofR5HwlF+zDcpsC193vyYB/innvHywCzdZfAR/+onX1segBTAxHzzfPE7/8yzzIPLjJE1LTixHZx5CtCK4gXLzovBiDPUsYxVM7gUkB3nWKlm6DYEnQGzXARxCOK+a1WfKtQXb6LNAvr7iCboCUA1Ocdsdv5KLPe7F6pH/w3wLbc+BwOuc5IZ1wEE/jonQbjptZn24tKKX7BgvR2r0NKZRwDvAqCI+Z30VJPTURv7P4A9psuQcYAUPwAoReBLrmX2Lmls7i8sZ7kWLwuoxA1FVJGxzMPLufi6P2r+2xFbOUjGAAAAAElFTkSuQmCC\",\r\n width: 16,\r\n height: 16,\r\n xoffset: -8,\r\n yoffset: -16,\r\n });\r\n\r\n public static readonly defaultSLSProps: EsriSLSProps = {\r\n type: \"esriSLS\",\r\n color: [0, 0, 255, 255],\r\n width: 1,\r\n style: \"esriSLSSolid\",\r\n };\r\n public static readonly defaultSLS = EsriSLS.fromJSON(this.defaultSLSProps);\r\n\r\n public static readonly defaultSFS = EsriSFS.fromJSON({\r\n type: \"esriSFS\",\r\n color: [0, 0, 255, 100], // blue fill\r\n style: \"esriSFSSolid\",\r\n outline: this.defaultSLSProps,\r\n });\r\n\r\n public async initialize() {\r\n // Marker image need to be loaded upfront;\r\n await DefaultArcGiSymbology.defaultPMS.loadImage();\r\n }\r\n\r\n public getSymbology(geomType: string): EsriSymbol {\r\n if (geomType === \"esriGeometryPoint\" || geomType === \"esriGeometryMultipoint\") {\r\n return DefaultArcGiSymbology.defaultPMS;\r\n } else if (geomType === \"esriGeometryLine\" || geomType === \"esriGeometryPolyline\") {\r\n return DefaultArcGiSymbology.defaultSLS;\r\n } else if (geomType === \"esriGeometryPolygon\") {\r\n return DefaultArcGiSymbology.defaultSFS;\r\n }\r\n\r\n throw new Error(`Could not get default symbology for geometry type: '${geomType}'`);\r\n }\r\n}\r\n\r\n/** Provide tiles from a ESRI ArcGIS Feature service\r\n* @internal\r\n*/\r\nexport class ArcGisFeatureProvider extends ArcGISImageryProvider {\r\n // Debug flags, should always be committed to FALSE !\r\n private _drawDebugInfo = false;\r\n private _debugFeatureGeom = false;\r\n\r\n private _supportsCoordinatesQuantization = false;\r\n\r\n private _layerId = 0;\r\n private _layerMetadata: any;\r\n private _format: ArcGisFeatureFormat | undefined;\r\n private _outSR = 102100;\r\n\r\n private _maxDepthFromLod = 0;\r\n private _minDepthFromLod = 0;\r\n\r\n private _defaultSymbol = new DefaultArcGiSymbology();\r\n private _renderer: EsriRenderer|undefined;\r\n private _symbologyRenderer: ArcGisSymbologyCanvasRenderer|undefined;\r\n\r\n private static readonly _nbSubTiles = 2; // Number of subtiles for a single axis\r\n public serviceJson: any;\r\n\r\n public override get minimumZoomLevel(): number { return this._minDepthFromLod; }\r\n public override get maximumZoomLevel(): number { return this._maxDepthFromLod; }\r\n\r\n private static _extentCache = new Map<string, any>();\r\n\r\n constructor(settings: ImageMapLayerSettings) {\r\n super(settings, true);\r\n }\r\n\r\n public override async initialize(): Promise<void> {\r\n const metadata = await this.getServiceJson();\r\n const json = metadata?.content;\r\n\r\n if (json === undefined) {\r\n Logger.logError(loggerCategory, \"Could not get service JSON\");\r\n throw new ServerError(IModelStatus.ValidationFailed, \"\");\r\n }\r\n\r\n if (json?.error?.code === ArcGisErrorCode.TokenRequired\r\n || json?.error?.code === ArcGisErrorCode.InvalidToken\r\n || json?.error?.code === ArcGisErrorCode.MissingPermissions\r\n ) {\r\n // Check again layer status, it might have change during await.\r\n if (this.status === MapLayerImageryProviderStatus.Valid) {\r\n this.setStatus(MapLayerImageryProviderStatus.RequireAuth);\r\n return;\r\n }\r\n }\r\n\r\n if (json.capabilities) {\r\n this._querySupported = json.capabilities.indexOf(\"Query\") >= 0;\r\n if (!this._querySupported)\r\n throw new ServerError(IModelStatus.ValidationFailed, \"\");\r\n }\r\n\r\n this.serviceJson = json;\r\n\r\n let foundVisibleSubLayer = false;\r\n if (this._settings.subLayers.length >= 0) {\r\n // There is more than sub-layer for this layer, pick the first visible one.\r\n for (const layer of this._settings.subLayers) {\r\n if (layer.visible && typeof layer.id === \"number\") {\r\n this._layerId = layer.id;\r\n foundVisibleSubLayer = true;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n if (!foundVisibleSubLayer && json !== undefined) {\r\n // No suitable sublayer was specified on the layerSettings object, lets find a default one in the capabilities\r\n\r\n // Check layer metadata\r\n if (Array.isArray(this.serviceJson.layers) && this.serviceJson.layers.length >= 1) {\r\n\r\n const hasDefaultVisibility = Object.keys(this.serviceJson.layers[0]).includes(\"defaultVisibility\");\r\n if (hasDefaultVisibility) {\r\n for (const layer of this.serviceJson.layers) {\r\n if (layer.defaultVisibility) {\r\n this._layerId = layer.id;\r\n break;\r\n }\r\n }\r\n } else {\r\n // On some older servers, the default visiblity is on the layer capabilities (i.e. not the service capabilities)\r\n for (const layer of this.serviceJson.layers) {\r\n const layerJson = await this.getLayerMetadata(layer.id);\r\n if (!layerJson) {\r\n continue;\r\n }\r\n\r\n if (layerJson.defaultVisibility) {\r\n this._layerId = layer.id;\r\n this._layerMetadata = layerJson;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n } else {\r\n // There is no layer to publish? Something is off with this server..\r\n throw new ServerError(IModelStatus.ValidationFailed, \"\");\r\n }\r\n }\r\n\r\n // Make sure we cache layer info (i.e. rendering info)\r\n if (!this._layerMetadata) {\r\n\r\n this._layerMetadata = await this.getLayerMetadata(this._layerId);\r\n if (!this._layerMetadata) {\r\n Logger.logError(loggerCategory, \"Could not layer metadata\");\r\n throw new ServerError(IModelStatus.ValidationFailed, \"\");\r\n }\r\n }\r\n\r\n // Parse server version\r\n let majorVersion: number | undefined;\r\n if (this.serviceJson?.currentVersion) {\r\n try {\r\n majorVersion = Math.trunc(this.serviceJson?.currentVersion);\r\n } catch {\r\n }\r\n }\r\n\r\n // Coordinates Quantization: If supported, server will transform for us the coordinates in the Tile coordinate space (pixels, origin = upper left corner\r\n // If not supported, transformation will be applied client side.\r\n // 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\r\n if (majorVersion && majorVersion >= 11 && this._layerMetadata.supportsCoordinatesQuantization) {\r\n this._supportsCoordinatesQuantization = true;\r\n }\r\n\r\n // Check supported query formats: JSON and PBF are currently implemented by this provider\r\n // Note: needs to be checked on the layer metadata, service metadata advertises a different set of formats\r\n // Also, since PBF format does not support floating points, there is no point using this format if supportsCoordinatesQuantization is not available.\r\n if (this._layerMetadata.supportedQueryFormats) {\r\n const formats: string[] = this._layerMetadata.supportedQueryFormats.split(\", \");\r\n if (formats.includes(\"PBF\") && this._supportsCoordinatesQuantization) {\r\n this._format = \"PBF\";\r\n } else if (formats.includes(\"JSON\")) {\r\n this._format = \"JSON\";\r\n }\r\n }\r\n\r\n if (!this._format) {\r\n Logger.logError(loggerCategory, \"Could not get request format from service JSON\");\r\n throw new ServerError(IModelStatus.ValidationFailed, \"\");\r\n }\r\n\r\n // Read range using full extent from service metadata\r\n if (this._layerMetadata?.extent) {\r\n const layerExtent = this._layerMetadata.extent;\r\n if (layerExtent.spatialReference.latestWkid === 3857 || layerExtent.spatialReference.wkid === 102100) {\r\n this.setCartoRangeFromExtentJson(layerExtent);\r\n }\r\n }\r\n\r\n if (!this.cartoRange) {\r\n // Range could not be found (or is not in a coordinate system we support), make a request to compute the extent\r\n try {\r\n const extentJson = await this.fetchLayerExtent();\r\n\r\n if (extentJson)\r\n this.setCartoRangeFromExtentJson(extentJson);\r\n else\r\n Logger.logWarning(loggerCategory, `Could not get features extent, disabling extent filtering`);\r\n } catch {\r\n Logger.logError(loggerCategory, `Could not get feature extent`);\r\n }\r\n }\r\n\r\n // Check for minScale / max scale\r\n const minScale = this._layerMetadata?.minScale || undefined; // undefined, 0 -> undefined\r\n const maxScale = this._layerMetadata?.maxScale || undefined; // undefined, 0 -> undefined\r\n const scales = ArcGisUtilities.getZoomLevelsScales(this.defaultMaximumZoomLevel, this.tileSize, minScale, maxScale, 1.0);\r\n if (scales.minLod)\r\n this._minDepthFromLod = scales.minLod;\r\n\r\n // 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)\r\n this._maxDepthFromLod = (scales.maxLod ? scales.maxLod : this.defaultMaximumZoomLevel);\r\n\r\n try {\r\n this._renderer = EsriRenderer.fromJSON(this._layerMetadata?.drawingInfo?.renderer);\r\n await this._renderer.initialize();\r\n } catch (e) {\r\n Logger.logError(loggerCategory, `Could not initialize symbology renderer for '${this._settings.name}': ${e}`);\r\n }\r\n\r\n // Sanity check: make sure we got default symbology for this geometry type\r\n // if not, it will throw\r\n this._defaultSymbol.getSymbology(this._layerMetadata?.geometryType);\r\n await this._defaultSymbol.initialize(); // images must be loaded upfront\r\n this._symbologyRenderer = ArcGisSymbologyCanvasRenderer.create(this._renderer, this._defaultSymbol, this._layerMetadata?.geometryType);\r\n }\r\n\r\n private async fetchLayerExtent() {\r\n let extentJson: any;\r\n const tmpUrl = new URL(this._settings.url);\r\n tmpUrl.pathname = `${tmpUrl.pathname}/${this._layerId}/query`;\r\n tmpUrl.searchParams.append(\"where\", \"1=1\");\r\n tmpUrl.searchParams.append(\"outSR\", \"3857\");\r\n tmpUrl.searchParams.append(\"returnExtentOnly\", \"true\");\r\n tmpUrl.searchParams.append(\"f\", \"json\");\r\n const cached = ArcGisFeatureProvider._extentCache.get(tmpUrl.toString());\r\n if (cached) {\r\n extentJson = cached;\r\n } else {\r\n // Some server are struggling computing the extent for a layer (outdated spatial index I presume), lets wait 10s max.\r\n // Worst case scenario we will end up with a map-layer with no 'Zoom-To-Layer' functionality.\r\n const opts: RequestInit = { method: \"GET\" };\r\n setRequestTimeout(opts, 10000);\r\n const response = await this.fetch(tmpUrl, opts);\r\n\r\n extentJson = await response.json();\r\n ArcGisFeatureProvider._extentCache.set(tmpUrl.toString(), extentJson);\r\n }\r\n return (extentJson ? extentJson.extent : undefined);\r\n }\r\n\r\n private setCartoRangeFromExtentJson(extent: any) {\r\n const range3857 = Range2d.createFrom({\r\n low: { x: extent.xmin, y: extent.ymin },\r\n high: { x: extent.xmax, y: extent.ymax },\r\n });\r\n\r\n const west = this.getEPSG4326Lon(range3857.xLow);\r\n const south = this.getEPSG4326Lat(range3857.yLow);\r\n const east = this.getEPSG4326Lon(range3857.xHigh);\r\n const north = this.getEPSG4326Lat(range3857.yHigh);\r\n this.cartoRange = MapCartoRectangle.fromDegrees(west, south, east, north);\r\n }\r\n\r\n protected async getLayerMetadata(layerId: number) {\r\n let metadata: ArcGISServiceMetadata | undefined;\r\n try {\r\n const url = new URL(this._settings.url);\r\n url.pathname = `${url.pathname}/${layerId}`;\r\n metadata = await ArcGisUtilities.getServiceJson({\r\n url: url.toString(), formatId: this._settings.formatId,\r\n userName: this._settings.userName, password: this._settings.password,\r\n queryParams: this._settings.collectQueryParams(), requireToken: this._accessTokenRequired});\r\n } catch {\r\n\r\n }\r\n return metadata?.content;\r\n }\r\n\r\n public override get tileSize(): number { return 512; }\r\n public get format(): ArcGisFeatureFormat | undefined { return this._format; }\r\n\r\n // We don't use this method inside this provider (see constructFeatureUrl), but since this is an abstract method, we need to define something\r\n public async constructUrl(_row: number, _column: number, _zoomLevel: number): Promise<string> {\r\n return \"\";\r\n }\r\n\r\n public constructFeatureUrl(row: number, column: number, zoomLevel: number, format: ArcGisFeatureFormat, resultType: ArcGisFeatureResultType, geomOverride?: ArcGisGeometry, outFields?: string, tolerance?: number, returnGeometry?: boolean, maxAllowableOffset?: number): ArcGisFeatureUrl | undefined {\r\n\r\n const tileExtent = this.getEPSG3857Extent(row, column, zoomLevel);\r\n const tileEnvelope = {\r\n xmin: tileExtent.left, ymin: tileExtent.bottom,\r\n xmax: tileExtent.right, ymax: tileExtent.top,\r\n spatialReference: { wkid: 102100, latestWkid: 3857 },\r\n };\r\n\r\n // Actual spatial filter.\r\n // By default, we request the tile extent. If 'cartoPoint' is specified,\r\n // we restrict the spatial to specific point. (i.e. GetFeatureInfo requests)\r\n // If envelope is provided, it has the priority over 'cartoPoint'\r\n let geometry: ArcGisGeometry | undefined;\r\n if (geomOverride) {\r\n geometry = geomOverride;\r\n } else {\r\n geometry = { geom: tileEnvelope, type: \"esriGeometryEnvelope\" };\r\n }\r\n\r\n let quantizationParameters: FeatureQueryQuantizationParams | undefined;\r\n const toleranceWorld = (tileExtent.top - tileExtent.bottom) / this.tileSize;\r\n if (resultType === \"tile\" && this._supportsCoordinatesQuantization) {\r\n quantizationParameters = {\r\n mode: \"view\",\r\n originPosition: \"upperLeft\",\r\n tolerance: toleranceWorld, // pixel size in world units\r\n extent: tileEnvelope,\r\n };\r\n }\r\n const url = new ArcGisFeatureQuery(\r\n this._settings.url,\r\n this._layerId,\r\n format,\r\n this._outSR,\r\n {\r\n geometry,\r\n geometryType: \"esriGeometryEnvelope\",\r\n returnExceededLimitFeatures: false,\r\n maxRecordCountFactor: 3, // This was grabbed from the ESRI web viewer request, not sure where this factor come from\r\n resultType,\r\n quantizationParameters,\r\n outFields,\r\n returnGeometry,\r\n distance: (tolerance ? tolerance * toleranceWorld : undefined),\r\n maxAllowableOffset,\r\n });\r\n\r\n let envelope: ArcGisExtent | undefined;\r\n if (geomOverride && geomOverride.type === \"esriGeometryEnvelope\") {\r\n envelope = geomOverride.geom as ArcGisExtent;\r\n } else {\r\n envelope = tileEnvelope;\r\n }\r\n\r\n return { url: url.toString(), envelope };\r\n\r\n }\r\n\r\n // Makes an identify request to ESRI MapService , and return it as a list MapLayerFeatureInfo object\r\n public override async getFeatureInfo(featureInfos: MapLayerFeatureInfo[], quadId: QuadId, carto: Cartographic, _tree: ImageryMapTileTree, hit: HitDetail, options?: MapFeatureInfoOptions): Promise<void> {\r\n if (!this._querySupported || this.format === undefined)\r\n return;\r\n\r\n const epsg3857X = this.getEPSG3857X(carto.longitudeDegrees);\r\n const epsg3857Y = this.getEPSG3857Y(carto.latitudeDegrees);\r\n\r\n const tileExtent = this.getEPSG3857Extent(quadId.row, quadId.column, quadId.level);\r\n const tilePixelSize = (tileExtent.top - tileExtent.bottom) / this.tileSize;\r\n const tolerancePixel = options?.tolerance ?? 7;\r\n const toleranceWorld = tilePixelSize * tolerancePixel;\r\n\r\n // Note: We used to pass a single point as the query 'geometry' and leverage the 'distance' parameter, turns\r\n // out that approach was a lot slower on some server compared to using a single envelope.\r\n const queryEnvelope: ArcGisGeometry = {\r\n type: \"esriGeometryEnvelope\",\r\n geom: {\r\n xmin: epsg3857X - toleranceWorld, ymin: epsg3857Y - toleranceWorld,\r\n xmax: epsg3857X + toleranceWorld, ymax: epsg3857Y + toleranceWorld,\r\n spatialReference: { wkid: 102100, latestWkid: 3857 },\r\n }};\r\n\r\n const doFeatureInfoQuery = async (format: ArcGisFeatureFormat, outFields?: string, returnGeometry?: boolean) => {\r\n const infoUrl = this.constructFeatureUrl(quadId.row, quadId.column, quadId.level, format, \"standard\", queryEnvelope,\r\n outFields, undefined, returnGeometry, tilePixelSize);\r\n\r\n if (!infoUrl || infoUrl.url.length === 0) {\r\n Logger.logError(loggerCategory, `Could not construct feature info query URL`);\r\n return undefined;\r\n }\r\n\r\n const response = this.fetch(new URL(infoUrl.url), { method: \"GET\" });\r\n\r\n const featureResponse = new ArcGisFeatureResponse(format, response);\r\n return featureResponse.getResponseData();\r\n };\r\n\r\n if (this._debugFeatureGeom) {\r\n try {\r\n let responseData = await doFeatureInfoQuery(\"PBF\", \"\", true);\r\n if (responseData) {\r\n const json = JSON.stringify(responseData.data.toObject());\r\n Logger.logInfo(loggerCategory, json);\r\n }\r\n responseData = await doFeatureInfoQuery(\"JSON\", \"\", true);\r\n if (responseData) {\r\n const json = JSON.stringify(responseData.data);\r\n Logger.logInfo(loggerCategory, json);\r\n }\r\n } catch (e) {\r\n Logger.logInfo(loggerCategory, `Error occurred with debug FeatureInfo: ${e}`);\r\n }\r\n }\r\n\r\n try {\r\n // Feature Info requests are always made in JSON for now.\r\n const responseData = await doFeatureInfoQuery(\"JSON\", \"*\", true);\r\n if (!responseData) {\r\n Logger.logError(loggerCategory, `Could not get feature info data`);\r\n return;\r\n }\r\n if (responseData.exceedTransferLimit) {\r\n Logger.logError(loggerCategory, `Could not get feature info : transfer limit exceeded.`);\r\n return;\r\n }\r\n\r\n const featureReader = new ArcGisJsonFeatureReader(this._settings, this._layerMetadata);\r\n\r\n const renderer = new FeatureGraphicsRenderer({viewport: hit.viewport, crs: \"webMercator\"});\r\n await featureReader.readFeatureInfo(responseData, featureInfos, renderer);\r\n\r\n } catch (e) {\r\n Logger.logError(loggerCategory, `Exception occurred while loading feature info data : ${e}`);\r\n return;\r\n }\r\n\r\n return;\r\n }\r\n\r\n private async fetchTile(row: number, column: number, zoomLevel: number, refineEnvelope?: ArcGisExtent): Promise<ArcGisFeatureResponse | undefined> {\r\n if (!this.format) {\r\n return undefined;\r\n }\r\n\r\n const geomOverride: ArcGisGeometry | undefined = (refineEnvelope ? { geom: refineEnvelope, type: \"esriGeometryEnvelope\" } : undefined);\r\n const fields = this._renderer?.fields;\r\n const outFields = fields ? fields.join(\",\") : undefined;\r\n const tileUrl = this.constructFeatureUrl(row, column, zoomLevel, this.format, \"tile\", geomOverride, outFields);\r\n if (!tileUrl || tileUrl.url.length === 0) {\r\n Logger.logError(loggerCategory, `Could not construct feature query URL for tile ${zoomLevel}/${row}/${column}`);\r\n return undefined;\r\n }\r\n\r\n const response = this.fetch(new URL(tileUrl.url), { method: \"GET\" });\r\n return new ArcGisFeatureResponse(this.format, response, tileUrl.envelope);\r\n }\r\n\r\n public drawTileDebugInfo(row: number, column: number, zoomLevel: number, context: CanvasRenderingContext2D) {\r\n context.fillStyle = \"cyan\";\r\n context.strokeRect(0, 0, this.tileSize, this.tileSize);\r\n context.font = \"30px Arial\";\r\n context.lineWidth = 5;\r\n context.fillText(`${zoomLevel}-${row}-${column}`, 10, 50);\r\n }\r\n\r\n // Compute transform that provides coordinates in the canvas coordinate system (pixels, origin = top-left)\r\n // from coordinate in world (i.e EPSG:3857)\r\n protected computeTileWorld2CanvasTransform(row: number, column: number, zoomLevel: number) {\r\n\r\n const tileExtentWorld3857 = this.getEPSG3857Extent(row, column, zoomLevel);\r\n const worldTileWidth = tileExtentWorld3857.right - tileExtentWorld3857.left;\r\n const canvasTileWidth = this.tileSize;\r\n const world2CanvasRatio = canvasTileWidth / worldTileWidth;\r\n const worldTileOrigin = Point3d.create(tileExtentWorld3857.left, tileExtentWorld3857.bottom);\r\n const worldTileExtent = Point3d.create(tileExtentWorld3857.right, tileExtentWorld3857.top);\r\n const canvasTileOriginOffset = worldTileOrigin.clone();\r\n const canvasTileExtentOffset = worldTileExtent.clone();\r\n canvasTileOriginOffset.scaleInPlace(world2CanvasRatio);\r\n canvasTileExtentOffset.scaleInPlace(world2CanvasRatio);\r\n const xTranslate = -1 * canvasTileOriginOffset.x;\r\n\r\n // Canvas origin is uppler left corner, so we need to flip the y axsis\r\n const yTranslate = canvasTileExtentOffset.y; // y-axis flip\r\n const yWorld2CanvasRatio = -1 * world2CanvasRatio; // y-axis flip\r\n\r\n const matrix = Matrix4d.createTranslationAndScaleXYZ(xTranslate, yTranslate, 0, world2CanvasRatio, yWorld2CanvasRatio, 1);\r\n return matrix.asTransform;\r\n }\r\n\r\n public override async loadTile(row: number, column: number, zoomLevel: number): Promise<ImageSource | undefined> {\r\n\r\n if ((this.status === MapLayerImageryProviderStatus.RequireAuth)) {\r\n return undefined;\r\n }\r\n const canvas = document.createElement(\"canvas\");\r\n canvas.width = this.tileSize;\r\n canvas.height = this.tileSize;\r\n\r\n const ctx = canvas.getContext(\"2d\");\r\n if (ctx == null) {\r\n Logger.logError(loggerCategory, \"No canvas context available for loading tile.\");\r\n return undefined;\r\n }\r\n\r\n try {\r\n\r\n // Compute transform if CoordinatesQuantization is not supported by service\r\n let transfo: Transform | undefined;\r\n if (!this._supportsCoordinatesQuantization) {\r\n transfo = this.computeTileWorld2CanvasTransform(row, column, zoomLevel);\r\n if (!transfo) {\r\n Logger.logError(loggerCategory, `Could not compute data transformation for tile (${zoomLevel}/${row}/${column})`);\r\n }\r\n }\r\n\r\n // Create the renderer\r\n if (!this._symbologyRenderer) {\r\n Logger.logError(loggerCategory, `Unable to load tile: symbology renderer not aailable.`);\r\n return undefined;\r\n }\r\n\r\n const renderer = new FeatureCanvasRenderer(ctx, this._symbologyRenderer, transfo);\r\n const featureReader: ArcGisFeatureReader = this.format === \"PBF\" ? new ArcGisPbfFeatureReader(this._settings, this._layerMetadata) : new ArcGisJsonFeatureReader(this._settings, this._layerMetadata);\r\n\r\n const getSubEnvelopes = (envelope: ArcGisExtent): ArcGisExtent[] => {\r\n const dx = (envelope.xmax - envelope.xmin) * 0.5;\r\n const dy = (envelope.xmax - envelope.xmin) * 0.5;\r\n const subEnvelopes: ArcGisExtent[] = [];\r\n for (let posX = 0; posX < ArcGisFeatureProvider._nbSubTiles; posX++) {\r\n for (let posY = 0; posY < ArcGisFeatureProvider._nbSubTiles; posY++) {\r\n subEnvelopes.push({\r\n xmin: envelope.xmin + (dx * posX), ymin: envelope.ymin + (dy * posY),\r\n xmax: envelope.xmin + (dx * (posX + 1)), ymax: envelope.ymin + (dy * (posY + 1)),\r\n spatialReference: { wkid: 102100, latestWkid: 3857 },\r\n });\r\n }\r\n }\r\n return subEnvelopes;\r\n };\r\n\r\n // The strategy here is simple: we make a request for an area that represents the current tile (i.e envelope),\r\n // the server will either return the requested data OR a 'exceedTransferLimit' message (too much data to transfers).\r\n // In the latter case, we subdivide the previous request envelope in for 4 sub-envelopes,\r\n // and repeat again until we get data.\r\n const renderData = async (envelope?: ArcGisExtent) => {\r\n let response: ArcGisFeatureResponse | undefined;\r\n let responseData: ArcGisResponseData | undefined;\r\n try {\r\n response = await this.fetchTile(row, column, zoomLevel, envelope);\r\n\r\n if (!response) {\r\n Logger.logError(loggerCategory, `Error occurred while fetching tile (${zoomLevel}/${row}/${column})`);\r\n return;\r\n }\r\n\r\n responseData = await response.getResponseData();\r\n if (!responseData) {\r\n Logger.logError(loggerCategory, `Could not get response data for tile (${zoomLevel}/${row}/${column})`);\r\n return;\r\n }\r\n } catch (e) {\r\n Logger.logError(loggerCategory, `Exception occurred while loading tile (${zoomLevel}/${row}/${column}) : ${e}`);\r\n return;\r\n }\r\n\r\n if (responseData.exceedTransferLimit) {\r\n if (response.envelope) {\r\n const subEnvelopes = getSubEnvelopes(response.envelope);\r\n const renderPromises = [];\r\n for (const subEnvelope of subEnvelopes) {\r\n renderPromises.push(renderData(subEnvelope));\r\n }\r\n await Promise.all(renderPromises);\r\n } else {\r\n Logger.logError(loggerCategory, `Request exceeded transfer limit, could not refine request`);\r\n }\r\n } else {\r\n await featureReader.readAndRender(responseData, renderer);\r\n }\r\n };\r\n await renderData();\r\n if (this._drawDebugInfo)\r\n this.drawTileDebugInfo(row, column, zoomLevel, ctx);\r\n } catch (e) {\r\n Logger.logError(loggerCategory, `Exception occurred while loading tile (${zoomLevel}/${row}/${column}) : ${e}`);\r\n }\r\n\r\n try {\r\n const dataUrl = canvas.toDataURL(\"image/png\");\r\n const header = \"data:image/png;base64,\";\r\n const dataUrl2 = dataUrl.substring(header.length);\r\n return new ImageSource(base64StringToUint8Array(dataUrl2), ImageSourceFormat.Png);\r\n } catch (e) {\r\n Logger.logError(loggerCategory, `Exception occurred while rendering tile (${zoomLevel}/${row}/${column}) : ${e}.`);\r\n }\r\n\r\n return undefined;\r\n }\r\n\r\n}\r\n\r\n"]}
1
+ {"version":3,"file":"ArcGisFeatureProvider.js","sourceRoot":"","sources":["../../../src/ArcGisFeature/ArcGisFeatureProvider.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n\r\nimport { Cartographic, ImageMapLayerSettings, ImageSource, ImageSourceFormat, ServerError } from \"@itwin/core-common\";\r\nimport { base64StringToUint8Array, IModelStatus, Logger } from \"@itwin/core-bentley\";\r\nimport { Matrix4d, Point3d, Range2d, Transform } from \"@itwin/core-geometry\";\r\nimport { ArcGisErrorCode, ArcGISImageryProvider, ArcGISServiceMetadata, ArcGisUtilities, FeatureGraphicsRenderer, HitDetail, ImageryMapTileTree, MapCartoRectangle, MapFeatureInfoOptions, MapLayerFeatureInfo, MapLayerImageryProviderStatus, QuadId, setRequestTimeout } from \"@itwin/core-frontend\";\r\nimport { ArcGisExtent, ArcGisFeatureFormat, arcgisFeatureFormats, ArcGisFeatureQuery, ArcGisFeatureResultType, ArcGisGeometry, FeatureQueryQuantizationParams } from \"./ArcGisFeatureQuery\";\r\nimport { ArcGisPbfFeatureReader } from \"./ArcGisPbfFeatureReader\";\r\nimport { ArcGisJsonFeatureReader } from \"./ArcGisJsonFeatureReader\";\r\nimport { ArcGisFeatureResponse, ArcGisResponseData } from \"./ArcGisFeatureResponse\";\r\nimport { ArcGisFeatureReader } from \"./ArcGisFeatureReader\";\r\n\r\nimport { EsriPMS, EsriRenderer, EsriSFS, EsriSLS, EsriSLSProps, EsriSymbol } from \"./EsriSymbology\";\r\nimport { FeatureDefaultSymbology } from \"../Feature/FeatureSymbology\";\r\nimport { FeatureCanvasRenderer } from \"../Feature/FeatureCanvasRenderer\";\r\nimport { ArcGisSymbologyCanvasRenderer } from \"./ArcGisSymbologyRenderer\";\r\nconst loggerCategory = \"MapLayersFormats.ArcGISFeature\";\r\n\r\n/**\r\n* @internal\r\n*/\r\ninterface ArcGisFeatureUrl {\r\n url: string;\r\n envelope?: ArcGisExtent; // envelope representing the current computed URL, required to refine request.\r\n}\r\n\r\n/**\r\n* @internal\r\n*/\r\nexport class DefaultArcGiSymbology implements FeatureDefaultSymbology {\r\n public static readonly defaultPMS = EsriPMS.fromJSON( {\r\n type: \"esriPMS\",\r\n url: \"\",\r\n contentType: \"image/png\",\r\n imageData: \"iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAmBJREFUOE+Nk01IVFEUx//n3jfvOZOaJkMtiiJ7o9RG3LgoqKhFSFJBTS1ahFBBi0ijfJXCIyQr+hBbSIsoW7iQoKKFCw2CkAI3tZAgy8Ei+xhoTCbnje/NPfHGnA816KzuPR+/c8/HJRQJE7o+VUhym0DcCOYGgBQEXjOLlyqo+nHanCkMoaL4rslKjZwOQLT4ek3Mmz3FACFNLB67ut6M1nWphbg8wI6VyJK5KEH0EQFVJRKbwzokAW++p/ErraAYSQK3u47bC3vLnA+ZB9i2gHF0oyQMCfCGNaUa+vauxs71wWz2V18cnBj8gQ8J1/eeBnHUa4sMFQDGdGno+4gwEAoQzjVUon3rqlx1KY9x7+0MWobjAPg3QJ2eZV4tAEyFNCN5FkSXyw2B3j1hRGvLcgBXMV5MptA4MOXr0gT0u5bZnAf0jBsyiSgJPAxqhON1K3FlRxUMvwFAtv7u0Wl0jvwEmJNEuOhakTt5wKEBifr6Oo14BIBRpgt07w6jcVMIngKGY7NofR5HwlF+zDcpsC193vyYB/innvHywCzdZfAR/+onX1segBTAxHzzfPE7/8yzzIPLjJE1LTixHZx5CtCK4gXLzovBiDPUsYxVM7gUkB3nWKlm6DYEnQGzXARxCOK+a1WfKtQXb6LNAvr7iCboCUA1Ocdsdv5KLPe7F6pH/w3wLbc+BwOuc5IZ1wEE/jonQbjptZn24tKKX7BgvR2r0NKZRwDvAqCI+Z30VJPTURv7P4A9psuQcYAUPwAoReBLrmX2Lmls7i8sZ7kWLwuoxA1FVJGxzMPLufi6P2r+2xFbOUjGAAAAAElFTkSuQmCC\",\r\n width: 16,\r\n height: 16,\r\n xoffset: -8,\r\n yoffset: -16,\r\n });\r\n\r\n public static readonly defaultSLSProps: EsriSLSProps = {\r\n type: \"esriSLS\",\r\n color: [0, 0, 255, 255],\r\n width: 1,\r\n style: \"esriSLSSolid\",\r\n };\r\n public static readonly defaultSLS = EsriSLS.fromJSON(this.defaultSLSProps);\r\n\r\n public static readonly defaultSFS = EsriSFS.fromJSON({\r\n type: \"esriSFS\",\r\n color: [0, 0, 255, 100], // blue fill\r\n style: \"esriSFSSolid\",\r\n outline: this.defaultSLSProps,\r\n });\r\n\r\n public async initialize() {\r\n // Marker image need to be loaded upfront;\r\n await DefaultArcGiSymbology.defaultPMS.loadImage();\r\n }\r\n\r\n public getSymbology(geomType: string): EsriSymbol {\r\n if (geomType === \"esriGeometryPoint\" || geomType === \"esriGeometryMultipoint\") {\r\n return DefaultArcGiSymbology.defaultPMS;\r\n } else if (geomType === \"esriGeometryLine\" || geomType === \"esriGeometryPolyline\") {\r\n return DefaultArcGiSymbology.defaultSLS;\r\n } else if (geomType === \"esriGeometryPolygon\") {\r\n return DefaultArcGiSymbology.defaultSFS;\r\n }\r\n\r\n throw new Error(`Could not get default symbology for geometry type: '${geomType}'`);\r\n }\r\n}\r\n\r\n/** Provide tiles from a ESRI ArcGIS Feature service\r\n* @internal\r\n*/\r\nexport class ArcGisFeatureProvider extends ArcGISImageryProvider {\r\n // Debug flags, should always be committed to FALSE !\r\n private _drawDebugInfo = false;\r\n private _debugFeatureGeom = false;\r\n\r\n private _supportsCoordinatesQuantization = false;\r\n\r\n private _layerId = 0;\r\n private _layerMetadata: any;\r\n private _format: ArcGisFeatureFormat | undefined;\r\n private _outSR = 102100;\r\n\r\n private _maxDepthFromLod = 0;\r\n private _minDepthFromLod = 0;\r\n\r\n private _defaultSymbol = new DefaultArcGiSymbology();\r\n private _renderer: EsriRenderer|undefined;\r\n private _symbologyRenderer: ArcGisSymbologyCanvasRenderer|undefined;\r\n\r\n private static readonly _nbSubTiles = 2; // Number of subtiles for a single axis\r\n public serviceJson: any;\r\n\r\n public override get minimumZoomLevel(): number { return this._minDepthFromLod; }\r\n public override get maximumZoomLevel(): number { return this._maxDepthFromLod; }\r\n\r\n private static _extentCache = new Map<string, any>();\r\n\r\n constructor(settings: ImageMapLayerSettings) {\r\n super(settings, true);\r\n }\r\n\r\n public override async initialize(): Promise<void> {\r\n const metadata = await this.getServiceJson();\r\n const json = metadata?.content;\r\n\r\n if (json === undefined) {\r\n Logger.logError(loggerCategory, \"Could not get service JSON\");\r\n throw new ServerError(IModelStatus.ValidationFailed, \"\");\r\n }\r\n\r\n if (json?.error?.code === ArcGisErrorCode.TokenRequired\r\n || json?.error?.code === ArcGisErrorCode.InvalidToken\r\n || json?.error?.code === ArcGisErrorCode.MissingPermissions\r\n ) {\r\n // Check again layer status, it might have change during await.\r\n if (this.status === MapLayerImageryProviderStatus.Valid) {\r\n this.setStatus(MapLayerImageryProviderStatus.RequireAuth);\r\n return;\r\n }\r\n }\r\n\r\n if (json.capabilities) {\r\n this._querySupported = json.capabilities.indexOf(\"Query\") >= 0;\r\n if (!this._querySupported)\r\n throw new ServerError(IModelStatus.ValidationFailed, \"\");\r\n }\r\n\r\n this.serviceJson = json;\r\n\r\n let foundVisibleSubLayer = false;\r\n if (this._settings.subLayers.length >= 0) {\r\n // There is more than sub-layer for this layer, pick the first visible one.\r\n for (const layer of this._settings.subLayers) {\r\n if (layer.visible && typeof layer.id === \"number\") {\r\n this._layerId = layer.id;\r\n foundVisibleSubLayer = true;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n if (!foundVisibleSubLayer && json !== undefined) {\r\n // No suitable sublayer was specified on the layerSettings object, lets find a default one in the capabilities\r\n\r\n // Check layer metadata\r\n if (Array.isArray(this.serviceJson.layers) && this.serviceJson.layers.length >= 1) {\r\n\r\n const hasDefaultVisibility = Object.keys(this.serviceJson.layers[0]).includes(\"defaultVisibility\");\r\n if (hasDefaultVisibility) {\r\n for (const layer of this.serviceJson.layers) {\r\n if (layer.defaultVisibility) {\r\n this._layerId = layer.id;\r\n break;\r\n }\r\n }\r\n } else {\r\n // On some older servers, the default visiblity is on the layer capabilities (i.e. not the service capabilities)\r\n for (const layer of this.serviceJson.layers) {\r\n const layerJson = await this.getLayerMetadata(layer.id);\r\n if (!layerJson) {\r\n continue;\r\n }\r\n\r\n if (layerJson.defaultVisibility) {\r\n this._layerId = layer.id;\r\n this._layerMetadata = layerJson;\r\n break;\r\n }\r\n }\r\n }\r\n\r\n } else {\r\n // There is no layer to publish? Something is off with this server..\r\n throw new ServerError(IModelStatus.ValidationFailed, \"\");\r\n }\r\n }\r\n\r\n // Make sure we cache layer info (i.e. rendering info)\r\n if (!this._layerMetadata) {\r\n\r\n this._layerMetadata = await this.getLayerMetadata(this._layerId);\r\n if (!this._layerMetadata) {\r\n Logger.logError(loggerCategory, \"Could not layer metadata\");\r\n throw new ServerError(IModelStatus.ValidationFailed, \"\");\r\n }\r\n }\r\n\r\n // Parse server version\r\n let majorVersion: number | undefined;\r\n if (this.serviceJson?.currentVersion) {\r\n try {\r\n majorVersion = Math.trunc(this.serviceJson?.currentVersion);\r\n } catch {\r\n }\r\n }\r\n\r\n // Coordinates Quantization: If supported, server will transform for us the coordinates in the Tile coordinate space (pixels, origin = upper left corner\r\n // If not supported, transformation will be applied client side.\r\n // 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\r\n if (majorVersion && majorVersion >= 11 && this._layerMetadata.supportsCoordinatesQuantization) {\r\n this._supportsCoordinatesQuantization = true;\r\n }\r\n\r\n // Check supported query formats: JSON and PBF are currently implemented by this provider\r\n // Note: needs to be checked on the layer metadata, service metadata advertises a different set of formats\r\n // Also, since PBF format does not support floating points, there is no point using this format if supportsCoordinatesQuantization is not available.\r\n if (this._layerMetadata.supportedQueryFormats) {\r\n const formats: string[] = this._layerMetadata.supportedQueryFormats.split(\",\").map((s: string) => s.trim().toLowerCase());\r\n if (formats.includes(arcgisFeatureFormats.pbf) && this._supportsCoordinatesQuantization) {\r\n this._format = arcgisFeatureFormats.pbf;\r\n } else if (formats.includes(arcgisFeatureFormats.json)) {\r\n this._format = arcgisFeatureFormats.json;\r\n }\r\n }\r\n\r\n if (!this._format) {\r\n Logger.logError(loggerCategory, \"Could not get request format from service JSON\");\r\n throw new ServerError(IModelStatus.ValidationFailed, \"\");\r\n }\r\n\r\n // Read range using full extent from service metadata\r\n if (this._layerMetadata?.extent) {\r\n const layerExtent = this._layerMetadata.extent;\r\n if (layerExtent.spatialReference.latestWkid === 3857 || layerExtent.spatialReference.wkid === 102100) {\r\n this.setCartoRangeFromExtentJson(layerExtent);\r\n }\r\n }\r\n\r\n if (!this.cartoRange) {\r\n // Range could not be found (or is not in a coordinate system we support), make a request to compute the extent\r\n try {\r\n const extentJson = await this.fetchLayerExtent();\r\n\r\n if (extentJson)\r\n this.setCartoRangeFromExtentJson(extentJson);\r\n else\r\n Logger.logWarning(loggerCategory, `Could not get features extent, disabling extent filtering`);\r\n } catch {\r\n Logger.logError(loggerCategory, `Could not get feature extent`);\r\n }\r\n }\r\n\r\n // Check for minScale / max scale\r\n const minScale = this._layerMetadata?.minScale || undefined; // undefined, 0 -> undefined\r\n const maxScale = this._layerMetadata?.maxScale || undefined; // undefined, 0 -> undefined\r\n const scales = ArcGisUtilities.getZoomLevelsScales(this.defaultMaximumZoomLevel, this.tileSize, minScale, maxScale, 1.0);\r\n if (scales.minLod)\r\n this._minDepthFromLod = scales.minLod;\r\n\r\n // 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)\r\n this._maxDepthFromLod = (scales.maxLod ? scales.maxLod : this.defaultMaximumZoomLevel);\r\n\r\n try {\r\n this._renderer = EsriRenderer.fromJSON(this._layerMetadata?.drawingInfo?.renderer);\r\n await this._renderer.initialize();\r\n } catch (e) {\r\n Logger.logError(loggerCategory, `Could not initialize symbology renderer for '${this._settings.name}': ${e}`);\r\n }\r\n\r\n // Sanity check: make sure we got default symbology for this geometry type\r\n // if not, it will throw\r\n this._defaultSymbol.getSymbology(this._layerMetadata?.geometryType);\r\n await this._defaultSymbol.initialize(); // images must be loaded upfront\r\n this._symbologyRenderer = ArcGisSymbologyCanvasRenderer.create(this._renderer, this._defaultSymbol, this._layerMetadata?.geometryType);\r\n }\r\n\r\n private async fetchLayerExtent() {\r\n let extentJson: any;\r\n const tmpUrl = new URL(this._settings.url);\r\n tmpUrl.pathname = `${tmpUrl.pathname}/${this._layerId}/query`;\r\n tmpUrl.searchParams.append(\"where\", \"1=1\");\r\n tmpUrl.searchParams.append(\"outSR\", \"3857\");\r\n tmpUrl.searchParams.append(\"returnExtentOnly\", \"true\");\r\n tmpUrl.searchParams.append(\"f\", arcgisFeatureFormats.json);\r\n const cached = ArcGisFeatureProvider._extentCache.get(tmpUrl.toString());\r\n if (cached) {\r\n extentJson = cached;\r\n } else {\r\n // Some server are struggling computing the extent for a layer (outdated spatial index I presume), lets wait 10s max.\r\n // Worst case scenario we will end up with a map-layer with no 'Zoom-To-Layer' functionality.\r\n const opts: RequestInit = { method: \"GET\" };\r\n setRequestTimeout(opts, 10000);\r\n const response = await this.fetch(tmpUrl, opts);\r\n\r\n extentJson = await response.json();\r\n ArcGisFeatureProvider._extentCache.set(tmpUrl.toString(), extentJson);\r\n }\r\n return (extentJson ? extentJson.extent : undefined);\r\n }\r\n\r\n private setCartoRangeFromExtentJson(extent: any) {\r\n const range3857 = Range2d.createFrom({\r\n low: { x: extent.xmin, y: extent.ymin },\r\n high: { x: extent.xmax, y: extent.ymax },\r\n });\r\n\r\n const west = this.getEPSG4326Lon(range3857.xLow);\r\n const south = this.getEPSG4326Lat(range3857.yLow);\r\n const east = this.getEPSG4326Lon(range3857.xHigh);\r\n const north = this.getEPSG4326Lat(range3857.yHigh);\r\n this.cartoRange = MapCartoRectangle.fromDegrees(west, south, east, north);\r\n }\r\n\r\n protected async getLayerMetadata(layerId: number) {\r\n let metadata: ArcGISServiceMetadata | undefined;\r\n try {\r\n const url = new URL(this._settings.url);\r\n url.pathname = `${url.pathname}/${layerId}`;\r\n metadata = await ArcGisUtilities.getServiceJson({\r\n url: url.toString(), formatId: this._settings.formatId,\r\n userName: this._settings.userName, password: this._settings.password,\r\n queryParams: this._settings.collectQueryParams(), requireToken: this._accessTokenRequired});\r\n } catch {\r\n\r\n }\r\n return metadata?.content;\r\n }\r\n\r\n public override get tileSize(): number { return 512; }\r\n public get format(): ArcGisFeatureFormat | undefined { return this._format; }\r\n\r\n // We don't use this method inside this provider (see constructFeatureUrl), but since this is an abstract method, we need to define something\r\n public async constructUrl(_row: number, _column: number, _zoomLevel: number): Promise<string> {\r\n return \"\";\r\n }\r\n\r\n public constructFeatureUrl(row: number, column: number, zoomLevel: number, format: ArcGisFeatureFormat, resultType: ArcGisFeatureResultType, geomOverride?: ArcGisGeometry, outFields?: string, tolerance?: number, returnGeometry?: boolean, maxAllowableOffset?: number): ArcGisFeatureUrl | undefined {\r\n\r\n const tileExtent = this.getEPSG3857Extent(row, column, zoomLevel);\r\n const tileEnvelope = {\r\n xmin: tileExtent.left, ymin: tileExtent.bottom,\r\n xmax: tileExtent.right, ymax: tileExtent.top,\r\n spatialReference: { wkid: 102100, latestWkid: 3857 },\r\n };\r\n\r\n // Actual spatial filter.\r\n // By default, we request the tile extent. If 'cartoPoint' is specified,\r\n // we restrict the spatial to specific point. (i.e. GetFeatureInfo requests)\r\n // If envelope is provided, it has the priority over 'cartoPoint'\r\n let geometry: ArcGisGeometry | undefined;\r\n if (geomOverride) {\r\n geometry = geomOverride;\r\n } else {\r\n geometry = { geom: tileEnvelope, type: \"esriGeometryEnvelope\" };\r\n }\r\n\r\n let quantizationParameters: FeatureQueryQuantizationParams | undefined;\r\n const toleranceWorld = (tileExtent.top - tileExtent.bottom) / this.tileSize;\r\n if (resultType === \"tile\" && this._supportsCoordinatesQuantization) {\r\n quantizationParameters = {\r\n mode: \"view\",\r\n originPosition: \"upperLeft\",\r\n tolerance: toleranceWorld, // pixel size in world units\r\n extent: tileEnvelope,\r\n };\r\n }\r\n const url = new ArcGisFeatureQuery(\r\n this._settings.url,\r\n this._layerId,\r\n format,\r\n this._outSR,\r\n {\r\n geometry,\r\n geometryType: \"esriGeometryEnvelope\",\r\n returnExceededLimitFeatures: false,\r\n maxRecordCountFactor: 3, // This was grabbed from the ESRI web viewer request, not sure where this factor come from\r\n resultType,\r\n quantizationParameters,\r\n outFields,\r\n returnGeometry,\r\n distance: (tolerance ? tolerance * toleranceWorld : undefined),\r\n maxAllowableOffset,\r\n });\r\n\r\n let envelope: ArcGisExtent | undefined;\r\n if (geomOverride && geomOverride.type === \"esriGeometryEnvelope\") {\r\n envelope = geomOverride.geom as ArcGisExtent;\r\n } else {\r\n envelope = tileEnvelope;\r\n }\r\n\r\n return { url: url.toString(), envelope };\r\n\r\n }\r\n\r\n // Makes an identify request to ESRI MapService , and return it as a list MapLayerFeatureInfo object\r\n public override async getFeatureInfo(featureInfos: MapLayerFeatureInfo[], quadId: QuadId, carto: Cartographic, _tree: ImageryMapTileTree, hit: HitDetail, options?: MapFeatureInfoOptions): Promise<void> {\r\n if (!this._querySupported || this.format === undefined)\r\n return;\r\n\r\n const epsg3857X = this.getEPSG3857X(carto.longitudeDegrees);\r\n const epsg3857Y = this.getEPSG3857Y(carto.latitudeDegrees);\r\n\r\n const tileExtent = this.getEPSG3857Extent(quadId.row, quadId.column, quadId.level);\r\n const tilePixelSize = (tileExtent.top - tileExtent.bottom) / this.tileSize;\r\n const tolerancePixel = options?.tolerance ?? 7;\r\n const toleranceWorld = tilePixelSize * tolerancePixel;\r\n\r\n // Note: We used to pass a single point as the query 'geometry' and leverage the 'distance' parameter, turns\r\n // out that approach was a lot slower on some server compared to using a single envelope.\r\n const queryEnvelope: ArcGisGeometry = {\r\n type: \"esriGeometryEnvelope\",\r\n geom: {\r\n xmin: epsg3857X - toleranceWorld, ymin: epsg3857Y - toleranceWorld,\r\n xmax: epsg3857X + toleranceWorld, ymax: epsg3857Y + toleranceWorld,\r\n spatialReference: { wkid: 102100, latestWkid: 3857 },\r\n }};\r\n\r\n const doFeatureInfoQuery = async (format: ArcGisFeatureFormat, outFields?: string, returnGeometry?: boolean) => {\r\n const infoUrl = this.constructFeatureUrl(quadId.row, quadId.column, quadId.level, format, \"standard\", queryEnvelope,\r\n outFields, undefined, returnGeometry, tilePixelSize);\r\n\r\n if (!infoUrl || infoUrl.url.length === 0) {\r\n Logger.logError(loggerCategory, `Could not construct feature info query URL`);\r\n return undefined;\r\n }\r\n\r\n const response = this.fetch(new URL(infoUrl.url), { method: \"GET\" });\r\n\r\n const featureResponse = new ArcGisFeatureResponse(format, response);\r\n return featureResponse.getResponseData();\r\n };\r\n\r\n if (this._debugFeatureGeom) {\r\n try {\r\n let responseData = await doFeatureInfoQuery(arcgisFeatureFormats.pbf, \"\", true);\r\n if (responseData) {\r\n const json = JSON.stringify(responseData.data.toObject());\r\n Logger.logInfo(loggerCategory, json);\r\n }\r\n responseData = await doFeatureInfoQuery(arcgisFeatureFormats.json, \"\", true);\r\n if (responseData) {\r\n const json = JSON.stringify(responseData.data);\r\n Logger.logInfo(loggerCategory, json);\r\n }\r\n } catch (e) {\r\n Logger.logInfo(loggerCategory, `Error occurred with debug FeatureInfo: ${e}`);\r\n }\r\n }\r\n\r\n try {\r\n // Feature Info requests are always made in JSON for now.\r\n const responseData = await doFeatureInfoQuery(arcgisFeatureFormats.json, \"*\", true);\r\n if (!responseData) {\r\n Logger.logError(loggerCategory, `Could not get feature info data`);\r\n return;\r\n }\r\n if (responseData.exceedTransferLimit) {\r\n Logger.logError(loggerCategory, `Could not get feature info : transfer limit exceeded.`);\r\n return;\r\n }\r\n\r\n const featureReader = new ArcGisJsonFeatureReader(this._settings, this._layerMetadata);\r\n\r\n const renderer = new FeatureGraphicsRenderer({viewport: hit.viewport, crs: \"webMercator\"});\r\n await featureReader.readFeatureInfo(responseData, featureInfos, renderer);\r\n\r\n } catch (e) {\r\n Logger.logError(loggerCategory, `Exception occurred while loading feature info data : ${e}`);\r\n return;\r\n }\r\n\r\n return;\r\n }\r\n\r\n private async fetchTile(row: number, column: number, zoomLevel: number, refineEnvelope?: ArcGisExtent): Promise<ArcGisFeatureResponse | undefined> {\r\n if (!this.format) {\r\n return undefined;\r\n }\r\n\r\n const geomOverride: ArcGisGeometry | undefined = (refineEnvelope ? { geom: refineEnvelope, type: \"esriGeometryEnvelope\" } : undefined);\r\n const fields = this._renderer?.fields;\r\n const outFields = fields ? fields.join(\",\") : undefined;\r\n const tileUrl = this.constructFeatureUrl(row, column, zoomLevel, this.format, \"tile\", geomOverride, outFields);\r\n if (!tileUrl || tileUrl.url.length === 0) {\r\n Logger.logError(loggerCategory, `Could not construct feature query URL for tile ${zoomLevel}/${row}/${column}`);\r\n return undefined;\r\n }\r\n\r\n const response = this.fetch(new URL(tileUrl.url), { method: \"GET\" });\r\n return new ArcGisFeatureResponse(this.format, response, tileUrl.envelope);\r\n }\r\n\r\n public drawTileDebugInfo(row: number, column: number, zoomLevel: number, context: CanvasRenderingContext2D) {\r\n context.fillStyle = \"cyan\";\r\n context.strokeRect(0, 0, this.tileSize, this.tileSize);\r\n context.font = \"30px Arial\";\r\n context.lineWidth = 5;\r\n context.fillText(`${zoomLevel}-${row}-${column}`, 10, 50);\r\n }\r\n\r\n // Compute transform that provides coordinates in the canvas coordinate system (pixels, origin = top-left)\r\n // from coordinate in world (i.e EPSG:3857)\r\n protected computeTileWorld2CanvasTransform(row: number, column: number, zoomLevel: number) {\r\n\r\n const tileExtentWorld3857 = this.getEPSG3857Extent(row, column, zoomLevel);\r\n const worldTileWidth = tileExtentWorld3857.right - tileExtentWorld3857.left;\r\n const canvasTileWidth = this.tileSize;\r\n const world2CanvasRatio = canvasTileWidth / worldTileWidth;\r\n const worldTileOrigin = Point3d.create(tileExtentWorld3857.left, tileExtentWorld3857.bottom);\r\n const worldTileExtent = Point3d.create(tileExtentWorld3857.right, tileExtentWorld3857.top);\r\n const canvasTileOriginOffset = worldTileOrigin.clone();\r\n const canvasTileExtentOffset = worldTileExtent.clone();\r\n canvasTileOriginOffset.scaleInPlace(world2CanvasRatio);\r\n canvasTileExtentOffset.scaleInPlace(world2CanvasRatio);\r\n const xTranslate = -1 * canvasTileOriginOffset.x;\r\n\r\n // Canvas origin is uppler left corner, so we need to flip the y axsis\r\n const yTranslate = canvasTileExtentOffset.y; // y-axis flip\r\n const yWorld2CanvasRatio = -1 * world2CanvasRatio; // y-axis flip\r\n\r\n const matrix = Matrix4d.createTranslationAndScaleXYZ(xTranslate, yTranslate, 0, world2CanvasRatio, yWorld2CanvasRatio, 1);\r\n return matrix.asTransform;\r\n }\r\n\r\n public override async loadTile(row: number, column: number, zoomLevel: number): Promise<ImageSource | undefined> {\r\n\r\n if ((this.status === MapLayerImageryProviderStatus.RequireAuth)) {\r\n return undefined;\r\n }\r\n const canvas = document.createElement(\"canvas\");\r\n canvas.width = this.tileSize;\r\n canvas.height = this.tileSize;\r\n\r\n const ctx = canvas.getContext(\"2d\");\r\n if (ctx == null) {\r\n Logger.logError(loggerCategory, \"No canvas context available for loading tile.\");\r\n return undefined;\r\n }\r\n\r\n try {\r\n\r\n // Compute transform if CoordinatesQuantization is not supported by service\r\n let transfo: Transform | undefined;\r\n if (!this._supportsCoordinatesQuantization) {\r\n transfo = this.computeTileWorld2CanvasTransform(row, column, zoomLevel);\r\n if (!transfo) {\r\n Logger.logError(loggerCategory, `Could not compute data transformation for tile (${zoomLevel}/${row}/${column})`);\r\n }\r\n }\r\n\r\n // Create the renderer\r\n if (!this._symbologyRenderer) {\r\n Logger.logError(loggerCategory, `Unable to load tile: symbology renderer not aailable.`);\r\n return undefined;\r\n }\r\n\r\n const renderer = new FeatureCanvasRenderer(ctx, this._symbologyRenderer, transfo);\r\n const featureReader: ArcGisFeatureReader = this.format === arcgisFeatureFormats.pbf\r\n ? new ArcGisPbfFeatureReader(this._settings, this._layerMetadata)\r\n : new ArcGisJsonFeatureReader(this._settings, this._layerMetadata);\r\n\r\n const getSubEnvelopes = (envelope: ArcGisExtent): ArcGisExtent[] => {\r\n const dx = (envelope.xmax - envelope.xmin) * 0.5;\r\n const dy = (envelope.xmax - envelope.xmin) * 0.5;\r\n const subEnvelopes: ArcGisExtent[] = [];\r\n for (let posX = 0; posX < ArcGisFeatureProvider._nbSubTiles; posX++) {\r\n for (let posY = 0; posY < ArcGisFeatureProvider._nbSubTiles; posY++) {\r\n subEnvelopes.push({\r\n xmin: envelope.xmin + (dx * posX), ymin: envelope.ymin + (dy * posY),\r\n xmax: envelope.xmin + (dx * (posX + 1)), ymax: envelope.ymin + (dy * (posY + 1)),\r\n spatialReference: { wkid: 102100, latestWkid: 3857 },\r\n });\r\n }\r\n }\r\n return subEnvelopes;\r\n };\r\n\r\n // The strategy here is simple: we make a request for an area that represents the current tile (i.e envelope),\r\n // the server will either return the requested data OR a 'exceedTransferLimit' message (too much data to transfers).\r\n // In the latter case, we subdivide the previous request envelope in for 4 sub-envelopes,\r\n // and repeat again until we get data.\r\n const renderData = async (envelope?: ArcGisExtent) => {\r\n let response: ArcGisFeatureResponse | undefined;\r\n let responseData: ArcGisResponseData | undefined;\r\n try {\r\n response = await this.fetchTile(row, column, zoomLevel, envelope);\r\n\r\n if (!response) {\r\n Logger.logError(loggerCategory, `Error occurred while fetching tile (${zoomLevel}/${row}/${column})`);\r\n return;\r\n }\r\n\r\n responseData = await response.getResponseData();\r\n if (!responseData) {\r\n Logger.logError(loggerCategory, `Could not get response data for tile (${zoomLevel}/${row}/${column})`);\r\n return;\r\n }\r\n } catch (e) {\r\n Logger.logError(loggerCategory, `Exception occurred while loading tile (${zoomLevel}/${row}/${column}) : ${e}`);\r\n return;\r\n }\r\n\r\n if (responseData.exceedTransferLimit) {\r\n if (response.envelope) {\r\n const subEnvelopes = getSubEnvelopes(response.envelope);\r\n const renderPromises = [];\r\n for (const subEnvelope of subEnvelopes) {\r\n renderPromises.push(renderData(subEnvelope));\r\n }\r\n await Promise.all(renderPromises);\r\n } else {\r\n Logger.logError(loggerCategory, `Request exceeded transfer limit, could not refine request`);\r\n }\r\n } else {\r\n await featureReader.readAndRender(responseData, renderer);\r\n }\r\n };\r\n await renderData();\r\n if (this._drawDebugInfo)\r\n this.drawTileDebugInfo(row, column, zoomLevel, ctx);\r\n } catch (e) {\r\n Logger.logError(loggerCategory, `Exception occurred while loading tile (${zoomLevel}/${row}/${column}) : ${e}`);\r\n }\r\n\r\n try {\r\n const dataUrl = canvas.toDataURL(\"image/png\");\r\n const header = \"data:image/png;base64,\";\r\n const dataUrl2 = dataUrl.substring(header.length);\r\n return new ImageSource(base64StringToUint8Array(dataUrl2), ImageSourceFormat.Png);\r\n } catch (e) {\r\n Logger.logError(loggerCategory, `Exception occurred while rendering tile (${zoomLevel}/${row}/${column}) : ${e}.`);\r\n }\r\n\r\n return undefined;\r\n }\r\n\r\n}\r\n\r\n"]}