@itwin/map-layers-formats 3.6.0-dev.8 → 4.0.0-dev.2
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.
- package/.rush/temp/operation/build_ci/state.json +1 -1
- package/.rush/temp/operation/cover/state.json +3 -0
- package/.rush/temp/operation/docs/state.json +1 -1
- package/.rush/temp/package-deps_build_ci.json +7 -6
- package/.rush/temp/package-deps_cover.json +36 -0
- package/.rush/temp/package-deps_docs.json +7 -6
- package/.rush/temp/shrinkwrap-deps.json +22 -20
- package/CHANGELOG.json +30 -0
- package/CHANGELOG.md +26 -1
- package/config/rush-project.json +7 -0
- package/lib/cjs/ArcGisFeature/ArcGisFeatureProvider.d.ts.map +1 -1
- package/lib/cjs/ArcGisFeature/ArcGisFeatureProvider.js +10 -15
- package/lib/cjs/ArcGisFeature/ArcGisFeatureProvider.js.map +1 -1
- package/lib/cjs/test/ArcGisFeature/ArcGisFeatureProvider.test.js +52 -52
- package/lib/cjs/test/ArcGisFeature/ArcGisFeatureProvider.test.js.map +1 -1
- package/lib/cjs/test/coverage/.nyc_output/9c5a05db-1e47-4160-957c-83c30da86064.json +1 -0
- package/lib/cjs/test/coverage/.nyc_output/{5915ac9b-d491-4417-9c9b-5f1c8af16991.json → af97f0b0-7d6a-4076-b6e0-386cc7b97d91.json} +0 -0
- package/lib/cjs/test/coverage/.nyc_output/processinfo/9c5a05db-1e47-4160-957c-83c30da86064.json +1 -0
- package/lib/cjs/test/coverage/.nyc_output/processinfo/af97f0b0-7d6a-4076-b6e0-386cc7b97d91.json +1 -0
- package/lib/cjs/test/coverage/.nyc_output/processinfo/index.json +1 -1
- package/lib/cjs/test/coverage/cobertura-coverage.xml +209 -210
- package/lib/cjs/test/coverage/lcov-report/index.html +14 -14
- package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureFormat.ts.html +1 -1
- package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureJSON.ts.html +1 -1
- package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeaturePBF.ts.html +1 -1
- package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureProvider.ts.html +15 -36
- package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureQuery.ts.html +1 -1
- package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureReader.ts.html +1 -1
- package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureRenderer.ts.html +1 -1
- package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisFeatureResponse.ts.html +1 -1
- package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/ArcGisSymbologyRenderer.ts.html +1 -1
- package/lib/cjs/test/coverage/lcov-report/src/ArcGisFeature/index.html +14 -14
- package/lib/cjs/test/coverage/lcov-report/src/index.html +1 -1
- package/lib/cjs/test/coverage/lcov-report/src/map-layers-formats.ts.html +1 -1
- package/lib/cjs/test/coverage/lcov-report/src/mapLayersFormats.ts.html +1 -1
- package/lib/cjs/test/coverage/lcov.info +377 -370
- package/lib/cjs/tsconfig.tsbuildinfo +1 -1
- package/lib/esm/ArcGisFeature/ArcGisFeatureProvider.d.ts.map +1 -1
- package/lib/esm/ArcGisFeature/ArcGisFeatureProvider.js +10 -15
- package/lib/esm/ArcGisFeature/ArcGisFeatureProvider.js.map +1 -1
- package/lib/esm/test/ArcGisFeature/ArcGisFeatureProvider.test.js +52 -52
- package/lib/esm/test/ArcGisFeature/ArcGisFeatureProvider.test.js.map +1 -1
- package/lib/esm/tsconfig.tsbuildinfo +1 -1
- package/lib/test/junit_results.xml +38 -38
- package/map-layers-formats.build.log +2 -2
- package/package.json +12 -12
- package/src/ArcGisFeature/ArcGisFeatureProvider.ts +7 -14
- package/src/test/ArcGisFeature/ArcGisFeatureProvider.test.ts +45 -45
- package/lib/cjs/test/coverage/.nyc_output/f467b483-7a60-4740-a604-ffc7965ecd6c.json +0 -1
- package/lib/cjs/test/coverage/.nyc_output/processinfo/5915ac9b-d491-4417-9c9b-5f1c8af16991.json +0 -1
- package/lib/cjs/test/coverage/.nyc_output/processinfo/f467b483-7a60-4740-a604-ffc7965ecd6c.json +0 -1
|
@@ -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 { assert, base64StringToUint8Array, IModelStatus, Logger } from \"@itwin/core-bentley\";\r\nimport { Matrix4d, Point3d, Range2d, Transform } from \"@itwin/core-geometry\";\r\nimport { ArcGisErrorCode, ArcGISImageryProvider, ArcGisUtilities, ImageryMapTileTree, MapCartoRectangle, MapLayerFeatureInfo, MapLayerImageryProviderStatus, QuadId } from \"@itwin/core-frontend\";\r\nimport { ArcGisSymbologyRenderer } from \"./ArcGisSymbologyRenderer\";\r\nimport { ArcGisExtent, ArcGisFeatureFormat, ArcGisFeatureQuery, ArcGisGeometry, FeatureQueryQuantizationParams } from \"./ArcGisFeatureQuery\";\r\nimport { ArcGisFeatureRenderer } from \"./ArcGisFeatureRenderer\";\r\nimport { ArcGisFeaturePBF } from \"./ArcGisFeaturePBF\";\r\nimport { ArcGisFeatureJSON } from \"./ArcGisFeatureJSON\";\r\nimport { ArcGisFeatureResponse, ArcGisResponseData } from \"./ArcGisFeatureResponse\";\r\nimport { ArcGisFeatureReader } from \"./ArcGisFeatureReader\";\r\nconst loggerCategory = \"MapLayersFormats.ArcGISFeature\";\r\n/**\r\n* @internal\r\n*/\r\ninterface ArcGisFeatureUrl {\r\n url: string;\r\n envelope?: ArcGisExtent; // envelope representing the current computed URL, requiered to refine request.\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 commited to FALSE !\r\n private _drawDebugInfo = false;\r\n private _debugFeatureGeom = false;\r\n\r\n private _supportsCoordinatesQuantization = false;\r\n private _querySupported = false;\r\n private _layerId = 0;\r\n private _layerMetadata: any;\r\n private _format: ArcGisFeatureFormat|undefined;\r\n public serviceJson: any;\r\n private _symbologyRenderer: ArcGisSymbologyRenderer|undefined;\r\n private static readonly _nbSubTiles = 2;\r\n private _outSR = 102100;\r\n\r\n private _maxDepthFromLod = 0;\r\n private _minDepthFromLod = 0;\r\n public override get minimumZoomLevel(): number { return this._minDepthFromLod; }\r\n public override get maximumZoomLevel(): number { return this._maxDepthFromLod; }\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\r\n let json;\r\n try {\r\n json = await ArcGisUtilities.getServiceJson(this._settings.url, this._settings.formatId, this._settings.userName, this._settings.password);\r\n\r\n } catch (_e) {\r\n\r\n }\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 || json?.error?.code === ArcGisErrorCode.InvalidToken) {\r\n // Check again layer status, it might have change during await.\r\n if (this.status === MapLayerImageryProviderStatus.Valid) {\r\n this.status = MapLayerImageryProviderStatus.RequireAuth;\r\n this.onStatusChanged.raiseEvent(this);\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 }\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 (json.fullExtent) {\r\n if (json.fullExtent.spatialReference.latestWkid === 3857 || json.fullExtent.spatialReference.wkid === 102100) {\r\n const range3857 = Range2d.createFrom({\r\n low: {x: json.fullExtent.xmin, y: json.fullExtent.ymin},\r\n high: {x: json.fullExtent.xmax, y: json.fullExtent.ymax} });\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\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 this._symbologyRenderer = new ArcGisSymbologyRenderer(this._layerMetadata?.geometryType, this._layerMetadata?.drawingInfo?.renderer);\r\n }\r\n\r\n protected async getLayerMetadata(layerId: number) {\r\n let json;\r\n try {\r\n const url = new URL(this._settings.url);\r\n url.pathname = `${url.pathname}/${layerId}`;\r\n json = await ArcGisUtilities.getServiceJson(url.toString(), this._settings.formatId, this._settings.userName, this._settings.password);\r\n } catch {\r\n\r\n }\r\n return json;\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, geomOverride?: ArcGisGeometry, outFields?: string, tolerance?: number, returnGeometry?: boolean): 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 (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 { 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: \"tile\",\r\n quantizationParameters,\r\n outFields,\r\n returnGeometry,\r\n distance: (tolerance ? tolerance*toleranceWorld :undefined) });\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): Promise<void> {\r\n if (!this._querySupported || this.format === undefined)\r\n return;\r\n\r\n const cartoPoint = {\r\n x: this.getEPSG3857X(carto.longitudeDegrees),\r\n y: this.getEPSG3857Y(carto.latitudeDegrees),\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, {geom: cartoPoint, type: \"esriGeometryPoint\"}, outFields, 3 /* tolerance in pixel*/, returnGeometry);\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 Logger.logInfo(loggerCategory, JSON.stringify(responseData.data.toObject()));\r\n }\r\n responseData = await doFeatureInfoQuery(\"JSON\", \"\", true);\r\n if (responseData) {\r\n Logger.logInfo(loggerCategory, JSON.stringify(responseData.data));\r\n }\r\n } catch (e) {\r\n Logger.logInfo(loggerCategory, `Error occured with debug FeatureInfo: ${e}`);\r\n }\r\n }\r\n\r\n try {\r\n const responseData = await doFeatureInfoQuery(this.format, \"*\", false);\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 : transfert limit exeeded.`);\r\n return;\r\n }\r\n const featureReader: ArcGisFeatureReader = this.format === \"PBF\" ? new ArcGisFeaturePBF(this._settings, this._layerMetadata) : new ArcGisFeatureJSON(this._settings, this._layerMetadata);\r\n featureReader.readFeatureInfo(responseData, featureInfos);\r\n\r\n } catch (e) {\r\n Logger.logError(loggerCategory, `Exception occured 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 assert(!\"No supported query format\");\r\n return undefined;\r\n }\r\n\r\n const geomOverride: ArcGisGeometry|undefined = (refineEnvelope ? {geom: refineEnvelope, type: \"esriGeometryEnvelope\"} : undefined);\r\n const tileUrl = this.constructFeatureUrl(row, column, zoomLevel, this.format, geomOverride);\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 assert(!\"no canvas context\");\r\n return undefined;\r\n }\r\n\r\n if (!this._symbologyRenderer) {\r\n Logger.logError(loggerCategory, \"No symbology renderer available for loading tile.\");\r\n assert(!\"No symbology renderer\");\r\n return undefined;\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 assert(!\"Could not compute world to canvas transform\");\r\n }\r\n }\r\n\r\n const renderer = new ArcGisFeatureRenderer(ctx, this._symbologyRenderer, transfo);\r\n const featureReader: ArcGisFeatureReader = this.format === \"PBF\" ? new ArcGisFeaturePBF(this._settings, this._layerMetadata) : new ArcGisFeatureJSON(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 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 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"]}
|
|
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 { assert, base64StringToUint8Array, IModelStatus, Logger } from \"@itwin/core-bentley\";\r\nimport { Matrix4d, Point3d, Range2d, Transform } from \"@itwin/core-geometry\";\r\nimport { ArcGisErrorCode, ArcGISImageryProvider, ArcGISServiceMetadata, ArcGisUtilities, ImageryMapTileTree, MapCartoRectangle, MapLayerFeatureInfo, MapLayerImageryProviderStatus, QuadId } from \"@itwin/core-frontend\";\r\nimport { ArcGisSymbologyRenderer } from \"./ArcGisSymbologyRenderer\";\r\nimport { ArcGisExtent, ArcGisFeatureFormat, ArcGisFeatureQuery, ArcGisGeometry, FeatureQueryQuantizationParams } from \"./ArcGisFeatureQuery\";\r\nimport { ArcGisFeatureRenderer } from \"./ArcGisFeatureRenderer\";\r\nimport { ArcGisFeaturePBF } from \"./ArcGisFeaturePBF\";\r\nimport { ArcGisFeatureJSON } from \"./ArcGisFeatureJSON\";\r\nimport { ArcGisFeatureResponse, ArcGisResponseData } from \"./ArcGisFeatureResponse\";\r\nimport { ArcGisFeatureReader } from \"./ArcGisFeatureReader\";\r\nconst loggerCategory = \"MapLayersFormats.ArcGISFeature\";\r\n/**\r\n* @internal\r\n*/\r\ninterface ArcGisFeatureUrl {\r\n url: string;\r\n envelope?: ArcGisExtent; // envelope representing the current computed URL, requiered to refine request.\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 commited to FALSE !\r\n private _drawDebugInfo = false;\r\n private _debugFeatureGeom = false;\r\n\r\n private _supportsCoordinatesQuantization = false;\r\n private _querySupported = false;\r\n private _layerId = 0;\r\n private _layerMetadata: any;\r\n private _format: ArcGisFeatureFormat|undefined;\r\n public serviceJson: any;\r\n private _symbologyRenderer: ArcGisSymbologyRenderer|undefined;\r\n private static readonly _nbSubTiles = 2;\r\n private _outSR = 102100;\r\n\r\n private _maxDepthFromLod = 0;\r\n private _minDepthFromLod = 0;\r\n public override get minimumZoomLevel(): number { return this._minDepthFromLod; }\r\n public override get maximumZoomLevel(): number { return this._maxDepthFromLod; }\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 || json?.error?.code === ArcGisErrorCode.InvalidToken) {\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 }\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 (json.fullExtent) {\r\n if (json.fullExtent.spatialReference.latestWkid === 3857 || json.fullExtent.spatialReference.wkid === 102100) {\r\n const range3857 = Range2d.createFrom({\r\n low: {x: json.fullExtent.xmin, y: json.fullExtent.ymin},\r\n high: {x: json.fullExtent.xmax, y: json.fullExtent.ymax} });\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\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 this._symbologyRenderer = new ArcGisSymbologyRenderer(this._layerMetadata?.geometryType, this._layerMetadata?.drawingInfo?.renderer);\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(url.toString(), this._settings.formatId, this._settings.userName, this._settings.password, 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, geomOverride?: ArcGisGeometry, outFields?: string, tolerance?: number, returnGeometry?: boolean): 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 (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 { 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: \"tile\",\r\n quantizationParameters,\r\n outFields,\r\n returnGeometry,\r\n distance: (tolerance ? tolerance*toleranceWorld :undefined) });\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): Promise<void> {\r\n if (!this._querySupported || this.format === undefined)\r\n return;\r\n\r\n const cartoPoint = {\r\n x: this.getEPSG3857X(carto.longitudeDegrees),\r\n y: this.getEPSG3857Y(carto.latitudeDegrees),\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, {geom: cartoPoint, type: \"esriGeometryPoint\"}, outFields, 3 /* tolerance in pixel*/, returnGeometry);\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 Logger.logInfo(loggerCategory, JSON.stringify(responseData.data.toObject()));\r\n }\r\n responseData = await doFeatureInfoQuery(\"JSON\", \"\", true);\r\n if (responseData) {\r\n Logger.logInfo(loggerCategory, JSON.stringify(responseData.data));\r\n }\r\n } catch (e) {\r\n Logger.logInfo(loggerCategory, `Error occured with debug FeatureInfo: ${e}`);\r\n }\r\n }\r\n\r\n try {\r\n const responseData = await doFeatureInfoQuery(this.format, \"*\", false);\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 : transfert limit exeeded.`);\r\n return;\r\n }\r\n const featureReader: ArcGisFeatureReader = this.format === \"PBF\" ? new ArcGisFeaturePBF(this._settings, this._layerMetadata) : new ArcGisFeatureJSON(this._settings, this._layerMetadata);\r\n featureReader.readFeatureInfo(responseData, featureInfos);\r\n\r\n } catch (e) {\r\n Logger.logError(loggerCategory, `Exception occured 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 assert(!\"No supported query format\");\r\n return undefined;\r\n }\r\n\r\n const geomOverride: ArcGisGeometry|undefined = (refineEnvelope ? {geom: refineEnvelope, type: \"esriGeometryEnvelope\"} : undefined);\r\n const tileUrl = this.constructFeatureUrl(row, column, zoomLevel, this.format, geomOverride);\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 assert(!\"no canvas context\");\r\n return undefined;\r\n }\r\n\r\n if (!this._symbologyRenderer) {\r\n Logger.logError(loggerCategory, \"No symbology renderer available for loading tile.\");\r\n assert(!\"No symbology renderer\");\r\n return undefined;\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 assert(!\"Could not compute world to canvas transform\");\r\n }\r\n }\r\n\r\n const renderer = new ArcGisFeatureRenderer(ctx, this._symbologyRenderer, transfo);\r\n const featureReader: ArcGisFeatureReader = this.format === \"PBF\" ? new ArcGisFeaturePBF(this._settings, this._layerMetadata) : new ArcGisFeatureJSON(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 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 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"]}
|
|
@@ -28,8 +28,8 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
28
28
|
sandbox.restore();
|
|
29
29
|
});
|
|
30
30
|
it("should initialize with valid data", async () => {
|
|
31
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
32
|
-
return NewYorkDataset_1.NewYorkDataset.serviceCapabilities;
|
|
31
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
32
|
+
return { accessTokenRequired: false, content: NewYorkDataset_1.NewYorkDataset.serviceCapabilities };
|
|
33
33
|
});
|
|
34
34
|
sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function _(_layerId) {
|
|
35
35
|
return NewYorkDataset_1.NewYorkDataset.streetsLayerCapabilities;
|
|
@@ -41,7 +41,7 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
41
41
|
expect(provider._maxDepthFromLod).to.equals(22);
|
|
42
42
|
});
|
|
43
43
|
it("should not initialize with no service metadata", async () => {
|
|
44
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
44
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
45
45
|
return undefined;
|
|
46
46
|
});
|
|
47
47
|
const settings = core_common_1.ImageMapLayerSettings.fromJSON(esriFeatureSampleSource);
|
|
@@ -49,8 +49,8 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
49
49
|
await expect(provider.initialize()).to.be.rejectedWith(core_common_1.ServerError);
|
|
50
50
|
});
|
|
51
51
|
it("should update status when invalid token error from service", async () => {
|
|
52
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
53
|
-
return { error: { code: 499 } };
|
|
52
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
53
|
+
return { accessTokenRequired: false, content: { error: { code: 499 } } };
|
|
54
54
|
});
|
|
55
55
|
const settings = core_common_1.ImageMapLayerSettings.fromJSON(esriFeatureSampleSource);
|
|
56
56
|
const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
|
|
@@ -60,16 +60,16 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
60
60
|
expect(raiseEventSpy.calledOnceWith(provider)).to.be.true;
|
|
61
61
|
});
|
|
62
62
|
it("should throw query capability not supported", async () => {
|
|
63
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
64
|
-
return { capabilities: "Test" };
|
|
63
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
64
|
+
return { accessTokenRequired: false, content: { capabilities: "Test" } };
|
|
65
65
|
});
|
|
66
66
|
const settings = core_common_1.ImageMapLayerSettings.fromJSON(esriFeatureSampleSource);
|
|
67
67
|
const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
|
|
68
68
|
await expect(provider.initialize()).to.be.rejectedWith(core_common_1.ServerError);
|
|
69
69
|
});
|
|
70
70
|
it("should pick the first visible sub-layer when multiple visible sub-layers", async () => {
|
|
71
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
72
|
-
return { capabilities: "Query" };
|
|
71
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
72
|
+
return { accessTokenRequired: false, content: { capabilities: "Query" } };
|
|
73
73
|
});
|
|
74
74
|
const settings = core_common_1.ImageMapLayerSettings.fromJSON({
|
|
75
75
|
...esriFeatureSampleSource,
|
|
@@ -81,16 +81,17 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
81
81
|
expect(provider._layerId).to.equals(settings.subLayers[0].id);
|
|
82
82
|
});
|
|
83
83
|
it("should pick sub-layers from service metadata if none provided on layer settings", async () => {
|
|
84
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
85
|
-
return { capabilities: "Query",
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
84
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
85
|
+
return { accessTokenRequired: false, content: { capabilities: "Query",
|
|
86
|
+
layers: [
|
|
87
|
+
{
|
|
88
|
+
id: 0,
|
|
89
|
+
},
|
|
90
|
+
{
|
|
91
|
+
id: 1,
|
|
92
|
+
},
|
|
93
|
+
] },
|
|
94
|
+
};
|
|
94
95
|
});
|
|
95
96
|
sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (id) {
|
|
96
97
|
if (id === 1) {
|
|
@@ -106,9 +107,8 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
106
107
|
expect(provider._layerMetadata).to.eql({ defaultVisibility: true });
|
|
107
108
|
});
|
|
108
109
|
it("should throw error if no layers in capabilities", async () => {
|
|
109
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
110
|
-
return { capabilities: "Query",
|
|
111
|
-
layers: [] };
|
|
110
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
111
|
+
return { accessTokenRequired: false, content: { capabilities: "Query", layers: [] } };
|
|
112
112
|
});
|
|
113
113
|
const settings = core_common_1.ImageMapLayerSettings.fromJSON(esriFeatureSampleSource);
|
|
114
114
|
const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
|
|
@@ -119,8 +119,8 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
119
119
|
...esriFeatureSampleSource,
|
|
120
120
|
subLayers: [{ id: 0, name: "layer1", visible: true }, { id: 2, name: "layer2", visible: true }]
|
|
121
121
|
});
|
|
122
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
123
|
-
return { capabilities: "Query" };
|
|
122
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
123
|
+
return { accessTokenRequired: false, content: { capabilities: "Query" } };
|
|
124
124
|
});
|
|
125
125
|
sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
|
|
126
126
|
return undefined;
|
|
@@ -136,16 +136,16 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
136
136
|
let getLayerMetadataStub = sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
|
|
137
137
|
return { defaultVisibility: true, supportedQueryFormats: "PBF, JSON" };
|
|
138
138
|
});
|
|
139
|
-
const getServiceJsonStub = sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
140
|
-
return { capabilities: "Query" };
|
|
139
|
+
const getServiceJsonStub = sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
140
|
+
return { accessTokenRequired: false, content: { capabilities: "Query" } };
|
|
141
141
|
});
|
|
142
142
|
let provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
|
|
143
143
|
await provider.initialize();
|
|
144
144
|
expect(provider.format).to.equals("JSON");
|
|
145
145
|
// PBF requires 'supportsCoordinatesQuantization'
|
|
146
146
|
getServiceJsonStub.restore();
|
|
147
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
148
|
-
return { currentVersion: 11, capabilities: "Query" };
|
|
147
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
148
|
+
return { accessTokenRequired: false, content: { currentVersion: 11, capabilities: "Query" } };
|
|
149
149
|
});
|
|
150
150
|
getLayerMetadataStub.restore();
|
|
151
151
|
getLayerMetadataStub = sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "getLayerMetadata").callsFake(async function (_id) {
|
|
@@ -159,8 +159,8 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
159
159
|
return { defaultVisibility: true, supportedQueryFormats: "JSON" };
|
|
160
160
|
});
|
|
161
161
|
getServiceJsonStub.restore();
|
|
162
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
163
|
-
return { currentVersion: 10.91, capabilities: "Query", supportsCoordinatesQuantization: true };
|
|
162
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
163
|
+
return { accessTokenRequired: false, content: { currentVersion: 10.91, capabilities: "Query", supportsCoordinatesQuantization: true } };
|
|
164
164
|
});
|
|
165
165
|
provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
|
|
166
166
|
await provider.initialize();
|
|
@@ -192,8 +192,8 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
192
192
|
maxScale: 5000,
|
|
193
193
|
};
|
|
194
194
|
});
|
|
195
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
196
|
-
return { capabilities: "Query" };
|
|
195
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
196
|
+
return { accessTokenRequired: false, content: { capabilities: "Query" } };
|
|
197
197
|
});
|
|
198
198
|
const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
|
|
199
199
|
await provider.initialize();
|
|
@@ -218,8 +218,8 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
218
218
|
supportedQueryFormats: "PBF, JSON",
|
|
219
219
|
};
|
|
220
220
|
});
|
|
221
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
222
|
-
return { currentVersion: 11, capabilities: "Query" };
|
|
221
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
222
|
+
return { accessTokenRequired: false, content: { currentVersion: 11, capabilities: "Query" } };
|
|
223
223
|
});
|
|
224
224
|
const provider = new map_layers_formats_1.ArcGisFeatureProvider(settings);
|
|
225
225
|
await provider.initialize();
|
|
@@ -307,8 +307,8 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
307
307
|
maxScale: 5000,
|
|
308
308
|
};
|
|
309
309
|
});
|
|
310
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
311
|
-
return { currentVersion: 11, capabilities: "Query" };
|
|
310
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
311
|
+
return { accessTokenRequired: false, content: { currentVersion: 11, capabilities: "Query" } };
|
|
312
312
|
});
|
|
313
313
|
sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "constructFeatureUrl").callsFake(function _(_row, _column, _zoomLevel, _format, _geomOverride, _outFields, _tolerance, _returnGeometry) {
|
|
314
314
|
return undefined;
|
|
@@ -335,8 +335,8 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
335
335
|
maxScale: 5000,
|
|
336
336
|
};
|
|
337
337
|
});
|
|
338
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
339
|
-
return { currentVersion: 11, capabilities: "Query" };
|
|
338
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
339
|
+
return { accessTokenRequired: false, content: { currentVersion: 11, capabilities: "Query" } };
|
|
340
340
|
});
|
|
341
341
|
sandbox.stub(core_frontend_1.ArcGISImageryProvider.prototype, "fetch").callsFake(async function _(_url, _options) {
|
|
342
342
|
const test = {
|
|
@@ -370,8 +370,8 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
370
370
|
maxScale: 5000,
|
|
371
371
|
};
|
|
372
372
|
});
|
|
373
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
374
|
-
return { capabilities: "Query" };
|
|
373
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
374
|
+
return { accessTokenRequired: false, content: { capabilities: "Query" } };
|
|
375
375
|
});
|
|
376
376
|
sandbox.stub(ArcGisFeatureResponse_1.ArcGisFeatureResponse.prototype, "getResponseData").callsFake(async function _() {
|
|
377
377
|
return { exceedTransferLimit: true, data: undefined };
|
|
@@ -397,8 +397,8 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
397
397
|
maxScale: 5000,
|
|
398
398
|
};
|
|
399
399
|
});
|
|
400
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
401
|
-
return { capabilities: "Query" };
|
|
400
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
401
|
+
return { accessTokenRequired: false, content: { capabilities: "Query" } };
|
|
402
402
|
});
|
|
403
403
|
sandbox.stub(ArcGisFeatureResponse_1.ArcGisFeatureResponse.prototype, "getResponseData").callsFake(async function _() {
|
|
404
404
|
throw new Error();
|
|
@@ -424,8 +424,8 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
424
424
|
maxScale: 5000,
|
|
425
425
|
};
|
|
426
426
|
});
|
|
427
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
428
|
-
return { capabilities: "Query" };
|
|
427
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
428
|
+
return { accessTokenRequired: false, content: { capabilities: "Query" } };
|
|
429
429
|
});
|
|
430
430
|
sandbox.stub(ArcGisFeatureResponse_1.ArcGisFeatureResponse.prototype, "getResponseData").callsFake(async function _() {
|
|
431
431
|
return { data: {
|
|
@@ -494,8 +494,8 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
494
494
|
supportsCoordinatesQuantization: true,
|
|
495
495
|
};
|
|
496
496
|
});
|
|
497
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
498
|
-
return { currentVersion: 11, capabilities: "Query" };
|
|
497
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
498
|
+
return { accessTokenRequired: false, content: { currentVersion: 11, capabilities: "Query" } };
|
|
499
499
|
});
|
|
500
500
|
sandbox.stub(HTMLCanvasElement.prototype, "getContext").callsFake(function _(_contextId, _options) {
|
|
501
501
|
return {};
|
|
@@ -537,8 +537,8 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
537
537
|
supportedQueryFormats: "JSON",
|
|
538
538
|
};
|
|
539
539
|
});
|
|
540
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
541
|
-
return { capabilities: "Query" };
|
|
540
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
541
|
+
return { accessTokenRequired: false, content: { capabilities: "Query" } };
|
|
542
542
|
});
|
|
543
543
|
sandbox.stub(HTMLCanvasElement.prototype, "getContext").callsFake(function _(_contextId, _options) {
|
|
544
544
|
return {};
|
|
@@ -579,8 +579,8 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
579
579
|
supportedQueryFormats: "JSON",
|
|
580
580
|
};
|
|
581
581
|
});
|
|
582
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
583
|
-
return { capabilities: "Query" };
|
|
582
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
583
|
+
return { accessTokenRequired: false, content: { capabilities: "Query" } };
|
|
584
584
|
});
|
|
585
585
|
sandbox.stub(HTMLCanvasElement.prototype, "getContext").callsFake(function _(_contextId, _options) {
|
|
586
586
|
return {};
|
|
@@ -662,8 +662,8 @@ describe("ArcGisFeatureProvider", () => {
|
|
|
662
662
|
supportedQueryFormats: "JSON",
|
|
663
663
|
};
|
|
664
664
|
});
|
|
665
|
-
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache) {
|
|
666
|
-
return { capabilities: "Query" };
|
|
665
|
+
sandbox.stub(core_frontend_1.ArcGisUtilities, "getServiceJson").callsFake(async function _(_url, _formatId, _userName, _password, _ignoreCache, _requireToken) {
|
|
666
|
+
return { accessTokenRequired: false, content: { capabilities: "Query" } };
|
|
667
667
|
});
|
|
668
668
|
const fetchStub = sandbox.stub(core_frontend_1.ArcGISImageryProvider.prototype, "fetch");
|
|
669
669
|
sandbox.stub(map_layers_formats_1.ArcGisFeatureProvider.prototype, "constructFeatureUrl").callsFake(function _(_row, _column, _zoomLevel, _format, _geomOverride, _outFields, _tolerance, _returnGeometry) {
|